2022.4.26:chrome100支持xp,堆栈大小问题

博客探讨了Chrome的新版本v8在XP系统上遇到的堆栈溢出问题。由于XP系统堆栈分配较小,v8在初始化时可能导致堆栈溢出。解决方法是通过ConvertThreadToFiber进行堆栈大小调整。文章还提到,堆栈溢出会导致v8启动失败,影响扩展安装。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

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

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

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

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

解决办法是用ConvertThreadToFiber来实现。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值