有这样的代码:
char text[] = "zim"; int x = 777;
如果我查看堆栈中的x和文本放置的输出是:
09 03 00 00 7a 69 6d 00
哪里:
> 09 03 00 00 = 0x309 = 777 < - int x = 777
> 7a 69 6d 00 = char text [] =“zim”(ASCII码)
现在有了try..catch的代码:
char text[] = "zim"; try{ int x = 777; } catch(int){ }
堆栈:
09 03 00 00 **97 85 04 08** 7a 69 6d 00
现在在text和x之间放置新的4字节值.如果我添加另一个catch,那么会有以下的东西:
09 03 00 00 **97 85 04 08** **xx xx xx xx** 7a 69 6d 00
等等.我认为这是与异常处理相关联的一些值,并且在堆栈展开期间使用它来在try块中抛出异常时找到适当的catch.但是问题是,这个4字节值是什么(可能是一些地址去排除处理程序结构或某些id)?
我在32位Linux机器上使用了g 4.6.
解决方法
AFAICT,这是一个指向“展开表”的指针.根据
the Itanium ABI implementation suggestions,过程“[使用]展开表,找到有关如何处理在该PC发生的异常的信息,特别是获取该地址范围的个性例程的地址.
展开桌面的想法是很少使用堆栈展开所需的数据.因此,将指针放在堆栈上更有效率,并将数据的存储存储在另一个页面中.在最好的情况下,该页面可以保留在磁盘上,甚至不需要在RAM中加载.相比之下,C风格错误处理通常在L1缓存中终止,因为它全部是内联的.