以下信息仅限于在linux平台上,gcc4编译器。对于各位调试release版本的core可能会有些许帮助
- ebp中存储一个函数的栈头位置,不管发生了海啸还是地震,该位置永恒不变。
- ebp中的地址+8存储第一个参数的地址,依次类推第二个,第三个参数的位置。(此条件并不恒成立,在某些情况下,参数压栈是反过来的。何种情况,期待牛人解答)。另外ebp起始的8个字节保留来干什么的,也请汇编牛人一并解答。
- 如果该函数是成员函数。this指针是第一个压栈的函数参数,也就是说ebp+8存的是this指针(该条件是否恒成立,我就母鸡了)
- 有继承关系的类的布局关系是首先是虚表指针,然后是父类成员,然后是继承类成员。比如一个类的起始地址为0,那么0这个位置放的是虚表指针,4这个位置就开始是父类的成员了。放完了之后就是继承类的成员(对于多继承,虚继承情况如何,需要的时候再研究吧)
- linux上用的标准的stl库的std::string中的size只有4,要想看string中的字符串值,只需要把string的首地址找到,然后用字符串模式查看该首地址中所存放的地址。所以估计string中存放的是一个指针。该指针指向的结构的头一位存放的就是实际字符串。如果对string实现非常有兴趣,也可以自己去stl库里面看了,不过linux上,windows实现还不一样,有时候多元化真是不好。
总而言之,言而总之。这篇文章充分说明我们需要牛人,时代呼唤牛人。太多的疑问需要牛人来解答。
牛人,我们的好牛人,
你在哪里,你在哪里?
你可知道,我们想念你,
———你的人民想念你!
我们对着高山喊:
牛人———
山谷回音:
“他刚离去,他刚离去,
革命征途千万里,
他大步前进不停息。
-------------------------------------------华丽的分割线-------------------------------------------
啊……因为有你
驱散阴霾
啊……因为有你
我们永不言败……
啊……因为有你
让世界充满爱