最近在研究算法时,遇到稍微深一点的递归就会Stack Overflow,由于不是实际项目,所以并不想用绕道而行的方法解决,于是便在代码里动了点手脚,把栈空间弄大了。实际项目中最好别这么干,容易搞乱堆栈调用,最好从算法上避免过深的递归或者自己用栈结构模拟进栈出栈。当然更好的方法是不用Windows(笑)。
//VC++
//预留100MB,当前提交100MB
#pragma comment(linker,"/STACK:102400000,102400000")
//G++
//256MB
int size=256<<20;
//申请空间
char *p=(char*)malloc(size)+size;
__asm__("movl %0,%%esp\n"::"r"(p));
/*
内联汇编,格式 __asm__ __volatile__("Instruction List":Output:Input:Clobber/Modify);
movl xxx,%eax
movl %eax,%esp
其中%0为占位符,r为寄存器约束
约束 Input/Output 意义
r I,O 表示使用一个通用寄存器,由GCC在%eax/%ax/%al, %ebx/%bx/%bl, %ecx/%cx/%cl, %edx/%dx/%dl中选取一个GCC认为合适的
q I,O 表示使用一个通用寄存器,和r的意义相同
a I,O 表示使用%eax / %ax / %al
b I,O 表示使用%ebx / %bx / %bl
c I,O 表示使用%ecx / %cx / %cl
d I,O 表示使用%edx / %dx / %dl
D I,O 表示使用%edi / %di
S I,O 表示使用%esi / %si
f I,O 表示使用浮点寄存器
t I,O 表示使用第一个浮点寄存器
u I,O 表示使用第二个浮点寄存器
*/