c – 如果未初始化的局部变量,Windows线程堆栈保护页面机制如何工作?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了c – 如果未初始化的局部变量,Windows线程堆栈保护页面机制如何工作?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含920字,纯文字阅读大概需要2分钟。
内容图文
![c – 如果未初始化的局部变量,Windows线程堆栈保护页面机制如何工作?](/upload/InfoBanner/zyjiaocheng/955/88c6bdd4f91f41d5bb581dcfbb085a8a.jpg)
在Windows OS for x86 | x64体系结构中,线程堆栈虚拟内存由“保留部分”“提交部分”,“保护页面”和“保留页面”组成.
题:
想象一下,我有1页提交内存,1MB的预留内存用于线程堆栈.
我在堆栈上分配一些内存等于K页面而没有初始化. K等于例如10.似乎在堆栈开始时堆栈上的内存将由用户空间代码分配,如下所示:
sub esp, K*4096
当存在对保护页面的读写请求时,保护页面机制起作用.
但是我将会执行什么读取写入超出此保护页面的某些内存?
解决方法:
您通常会开始测试在启用运行时检查的情况下编译的代码. /RTC on MSVC++,默认情况下在Debug配置中启用,它在函数序言中为_chkstk()注入一个调用. GCC / g有something very similar.
其中探测函数序言中的分配页面,每隔4096个字节读取一次.这可以确保您在出错时始终点击防护页面,触发此站点的名称并帮助您修复错误.
如果没有该检查,您可以在技术上解决不属于堆栈的页面.虽然它很可能触发处理器的#GP陷阱,但由于页面可能已被另一个不相关的分配映射,因此无法保证.你必须不走运,已经完成了.基本的UB,诊断绝对可怕,因为你从不怀疑堆栈,/ RTC是非常有价值的.
内容总结
以上是互联网集市为您收集整理的c – 如果未初始化的局部变量,Windows线程堆栈保护页面机制如何工作?全部内容,希望文章能够帮你解决c – 如果未初始化的局部变量,Windows线程堆栈保护页面机制如何工作?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。