C语言中一维指针与二维指针的转化

首先说个最特殊的指针 void×,这个是当初为了指针转化的方便,设立的一个万能指针。任何指针都能与之转化。

看两个定义:typedef int ×t; t a[10];

typedef int t[10] ;   t  *a;

首行先定义了一个整型指针类型,然后在定义了一个整型数组指针类型;后面一行首先定义了一个整型数组,然后定义了一个指向整型数组的指针。总结下两行代码,分别用一句代替就是int* a[10]和 int(*a)[10]。当我们使用指向数组的指针的时候,可以与指向函数的指针对比联想。若是想初始化指向数组的指针,则可以参考下面的例子:

int a[5]= {1,2,3,4,5};

int * pr =(int*) &a;

int (*pr1)[5]=&a;

注意的是&a表示取数组a的首地址,而当数组名作为右值时,是作为数组首个元素的地址,这两种用法是有区别的。上面的例子中,&a+1就表示移动到数组的最后面了,实际上是移动了一整行,然后使用pr来移动行里面,这样有点一维指针与二维指针的转化的意思了,前不久在网上看到了一个关于指针的题目:

int a[5]= {1,2,3,4,5};

int * pr =(int*) (&a+1);

printf("%d\n",*(pr-1));

结果是5,这就是上面说的那个意思,其实这里的关键是要记住一句话,&a表示取数组a的首地址,而当数组名作为右值时,是作为数组首个元素的地址。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章