参考:《Linux® Debugging and Performance Tuning: Tips and Techniques》 chapter 3
1. 测试程序
/home/a/j/nomad2:cat gdb_sample2.c #include <stdio.h> #include <pthread.h> #include <unistd.h> void* Thread_function1(void * arg) { unsigned int i=1; while(i < 11) { printf("Child Thread Iteration %d\n",i); i++; if(i%2) sleep(2); else sleep(1); } return arg; } void* Thread_function2(void * arg) { unsigned int i=1; while(i < 11) { printf("Child Thread 2 Iteration %d\n",i); i++; if(i%2) sleep(2); else sleep(1); } return arg; } int main (int argc, char *argv[]) { pthread_t thread; pthread_t thread2; if(pthread_create(&thread,NULL,Thread_function1,NULL)) { return(1); } if(pthread_create(&thread2,NULL,Thread_function2,NULL)) { return(1); } unsigned int i = 1; while(i < 11) { printf("Main Loop Iteration %d\n",i); i++; if(i%2) sleep(1); else sleep(2); } return 0; }
2.build with debug info increase the executable size.
/home/a/j/nomad2:ls -lrt a.out
-rwxr-xr-x 1 nomad2 member 11341 Oct 1 19:34 a.out
/home/a/j/nomad2:strip --strip-debug a.out
/home/a/j/nomad2:ls -lrt a.out
-rwxr-xr-x 1 nomad2 member 7522 Oct 1 19:42 a.out
3. 关于调试:
1). When debugging, it is often a good practice to stop program execution at the bottom of a function so that a print or multiple displays can be done to see the current values stored in the data the function has altered.
list <func name>
break <line of }>
2). When gdb is used, the print command must
be invoked to display the variable's value. The user can see much more information at one time.