这里的堆栈指的就是栈 Stack
线程堆栈默认大小是保留1M,初始提交2个页面,如8KB,1读写,1具有PAGE_GUARD保护属性
堆栈扩展的时候,会因为保护属性触发异常,线程根据这个自动增长
2000的堆栈
在Win2000里,最后一个页面不会被用到,会被最终标记reserve,当提交到倒数第二个页面的时候,会触发EXCEPTION_STACK_ OVERFLOW,虽然这还不是最后一个page,但是这个时候就应该妥善处理这个问题了,否则容易发生严重的问题
98的堆栈--A Thread's Stack Under Windows 98
在Win98里,线程堆栈的前后是额外个增加了64KB的,即1MB+128KB,98没有PAGE_GUARD保护属性,使用PAGE_NOACCESS属性模拟
98的堆栈比较特殊,有一段为兼容16位程序而模拟特殊的16KB读写段。最高的16KB地址用来做underflow保护,最低的16KB用来做overflow检测,它可用用全1MB的堆栈空间,而2000的最低一个页面则不会被使用
线程堆栈检测函数--The C/C++ Run-Time Library's Stack-Checking Function
在必要的时候,编译器会加入合适的代码来时堆栈进行合适的扩展
如如下代码,
线程堆栈默认大小是保留1M,初始提交2个页面,如8KB,1读写,1具有PAGE_GUARD保护属性
堆栈扩展的时候,会因为保护属性触发异常,线程根据这个自动增长
2000的堆栈
在Win2000里,最后一个页面不会被用到,会被最终标记reserve,当提交到倒数第二个页面的时候,会触发EXCEPTION_STACK_ OVERFLOW,虽然这还不是最后一个page,但是这个时候就应该妥善处理这个问题了,否则容易发生严重的问题
98的堆栈--A Thread's Stack Under Windows 98
在Win98里,线程堆栈的前后是额外个增加了64KB的,即1MB+128KB,98没有PAGE_GUARD保护属性,使用PAGE_NOACCESS属性模拟
98的堆栈比较特殊,有一段为兼容16位程序而模拟特殊的16KB读写段。最高的16KB地址用来做underflow保护,最低的16KB用来做overflow检测,它可用用全1MB的堆栈空间,而2000的最低一个页面则不会被使用
线程堆栈检测函数--The C/C++ Run-Time Library's Stack-Checking Function
在必要的时候,编译器会加入合适的代码来时堆栈进行合适的扩展
如如下代码,
void SomeFunction () {
int nValues[4000];
// Do some processing with the array.
nValues[0] = 0; // Some assignment
}
会被类似的扩展为
// The C run-time library knows the page size for the target system.
#ifdef _M_ALPHA
#define PAGESIZE (8 * 1024) // 8-KB page
#else
#define PAGESIZE (4 * 1024) // 4-KB page
#endif
void StackCheck(int nBytesNeededFromStack) {
// Get the stack pointer position.
// At this point, the stack pointer has NOT been decremented
// to account for the function's local variables.
PBYTE pbStackPtr = (CPU's stack pointer);
while (nBytesNeededFromStack >= PAGESIZE) {
// Move down a page on the stack--should be a guard page.
pbStackPtr -= PAGESIZE;
// Access a byte on the guard page--forces new page to be
// committed and guard page to move down a page.
pbStackPtr[0] = 0;
// Reduce the number of bytes needed from the stack.
nBytesNeededFromStack -= PAGESIZE;
}
// Before returning, the StackCheck function sets the CPU's
// stack pointer to the address below the function's
// local variables.
}