今天遇到一个小问题... 关于指针的
简述:
当p1 = p2;时,通过printf("%x,%x\n",p1,p2);打印出来的值是一样的,
通过查看反汇编代码,发现这样打印出来的都是它们所保存的内容;
p1 = p2;这样的操作也就是把p2所保存的值复制给了p1;
对应操作:
mov eax , dowrd ptr [ebp-4]
mov dowrd ptr [ebp-8] , eax
若想得到指针的地址,则需要&p1这样的做法
反汇编代码中对应操作:
lea ecx , [ebp-8]//lea是取偏移地址的指令
总结:
1、指针定义的时候,分配了4字节内存,该4字节区域内容是随机的
2、指针指向变量时,实际上是 mov 指针 , 变量地址 //即将变量地址保存到指针内存区域
3、指针指向指针时,实际上是 mov 指针1,指针2 //将指针2内存中保存的值复制到指针1的内存中
4、多级指针,说白了,就是内存的跳转,从前一指针跳转到下一指针
5、关于指针内的动态分配和释放的内幕操作(即malloc、free和new、delete的实现)
参考: http://blog.csdn.net/llhyy17/article/details/5375298 http://blog.csdn.net/sunmenggmail/article/details/7888763