1.
先写一个不能正确change的代码:
linux@ubuntu:~/workspace/pointer$ cat main2.c
#include<stdio.h>
void change(int a ,int b)
{
int tmp=a;
a=b;
b=tmp;
}
int main()
{
int a=5;
int b=3;
change(a,b);
printf("num a=%d\nnum b=%d\n",a,b);
return 0;
}
然后使用gdb工具编译:
gcc -g main2.c -o main2.out
然后进入gdb调试:
gdb ./main2.out
然后开始gdb调试:
start
显示函数、查看a变量、执行下一句、进入函数等语句进行调试
l //显示函数,显示不完全时继续l
p a// 查看a变量的值
n //执行一句代码
s //进入函数里面
bt //查看函数堆栈
q //退出调试
由下面可以看出只是把5和3两个数传到了a和b:
(gdb) s
change (a=5, b=3) at main2.c:5
bt(堆栈)的作用(在子函数里使用bt):
(gdb) bt
#0 change (a=5, b=3) at main2.c:5
#1 0x0804842b in main () at main2.c:13
此时change函数压在main函数上边,此时p a 打印的是change里面的a;
按 f 1 切回到main函数;按f 0 切回到main函数;
2
写一个能正确change的代码:
linux@ubuntu:~/workspace/pointer$ cat main.c
#include<stdio.h>
void change(int* a ,int* b)
{
int tmp=*a;
*a=*b;
*b=tmp;
}
int main()
{
int a=5;
int b=3;
change(&a,&b);
printf("num a=%d\nnum b=%d\n",a,b);
return 0;
}
进入gdb调试后进入change函数内部:
(gdb) n
13 change(&a,&b);
(gdb) s
change (a=0xbffff338, b=0xbffff33c) at main.c:5
5 int tmp=*a;
(gdb) n
6 *a=*b;
(gdb) p tmp
$1 = 5
(gdb) p a
$2 = (int *) 0xbffff338
(gdb) p b
$3 = (int *) 0xbffff33c
可以看出来,int a在内存中分配的地址是0xbffff338,int b的地址是0xbffff33c,正好相差4个字节。
(gdb) n
7 *b=tmp;
(gdb) p a
$4 = (int *) 0xbffff338
(gdb) p b
$5 = (int *) 0xbffff33c
执行完*a=*b后, p a 没变化?a的地址没有变化,里面的内容发生了变化,下面证实了:
(gdb) p *a //&是取地址,*是取地址里的内容
$11 = 3
(gdb) p *b
$12 = 3