指针变量与变量有区别吗?
举例:
int main()
{
int a=10;
int b;
int *p=NULL;
p=&a;
}
先用gdb调试看看 变量a ,与指针变量p之间的区别:
56 int a=10;
(gdb) n
58 int *p=NULL;
(gdb) n
59 p=&a;
(gdb) print a //可以看出变量名a与其值是绑定的,访问变量名就是访问相应变量的值
$8 = 10
(gdb) print &a //a变量存放的地址
$9 = (int *) 0xbffff2d0
(gdb) print p //这里可以看出指针变量p其值为0,即指针变量也是变量的一种,
$10 = (int *) 0x0
(gdb) print &p //从这里看出,指针变量p存放的地址与变量a是相邻的!
$11 = (int **) 0xbffff2d4
(gdb) print *a //从这里可以看出把a的值看作一个地址,即把a看作一个指针,取相应地址上的值,此处因为0xa是禁止访问的
Cannot access memory at address 0xa
(gdb) print *p //这里就是真正的指针咯,即我本来就把p的值规定为地址,但是不保证p的地址是否合法.
Cannot access memory at address 0x0
反汇编代码:
0x080483b4 <+0>: push %ebp
0x080483b5 <+1>: mov %esp,%ebp
0x080483b7 <+3>: sub $0x10,%esp
0x080483ba <+6>: movl $0xa,-0x8(%ebp) //int a=10
=> 0x080483c1 <+13>: movl $0x0,-0x4(%ebp) //int *p=NULL;
0x080483c8 <+20>: lea -0x8(%ebp),%eax //&a ,lea是取a的地址
0x080483cb <+23>: mov %eax,-0x4(%ebp) //把&a赋给p;
0x080483ce <+26>: leave
0x080483cf <+27>: ret
这里