最近在重温C语言,所谓基础不牢地动山摇,C语言相对简单,但是指针却是相对复杂的存在,为了以后方便自己查看,做个笔记。
指针存储地址,可以使用指针实现原变量的值传递,在复杂算法中,使用指针可以很方便快捷的实现算法设计。
为了方便理解指针,先看下面的例子
int a=3;
int *p;
p=&a;
printf("%d %p",*p,p);
输出结果是
3 0x7ffda13d105c
这里面p存储的是a的地址,*p则是将a地址里的变量进行提取
那么继续往下看:
int a=3;
int *p;
p=&a;
printf("%d %p",*p,p);
printf("n");
*p=5;
printf("%d",a);
输出结果是
3 0x7ffca35bc36c 5
地址每次运行是随机分配的,不要在意,但是通过程序看到了什么?*p=5;导致a的值发生了变化,所以在函数中可以不利用return进行值传递可以使用指针直接进行变量的值传递。
#include#define ROW 3 #define COL 4 int main(int argc, char** argv) { int i, j; int mat[ROW][COL] = { {1, 2, 3, 4}, {5, 6, 7, 8}, {9, 10, 11, 12}}; for (i = 0; i < ROW; ++i) { for (j = 0; j < COL; ++j) { printf("%dt", **(mat + i) ); //需要知道为什么会有两个星号,一个星号输出的还是数组地址,两个星号才输出数组值 printf("%dt", *(*(mat+i) + j) ); printf("n"); } printf("n"); } return 0; }
输出结果:
1 1 1 2 1 3 1 4 5 5 5 6 5 7 5 8 9 9 9 10 9 11 9 12



