admin管理员组

文章数量:1665523

1,新版本v8确实恐怖,一上来就需要大堆栈,至少4M起步。

动态申请大堆栈的地方,是chrome\app\chrome_exe_main_win的入口里。这里用到了技巧,就是用ConvertThreadToFiberEx可以申请大内存。

在v8的StackGuard::ThreadLocal::Initialize( ParseInfo::SetPerThreadState)里,会直接用当前堆栈地址GetCurrentStackPosition减去一个常量值,就成了堆栈溢出的检测值。

(题外话,触发堆栈溢出的话,会导致Genesis::InstallExtension里加载失败,从而v8启动失败。)

这时候,在xp上问题来了,xp的堆栈分配的比较小,如果不用ConvertThreadToFiberEx申请大内存堆栈(因为xp没有ConvertThreadToFiberEx),v8很容易就堆栈溢出了。

解决办法是用ConvertThreadToFiber来实现。

本文标签: 堆栈大小XP