int *p[5];
由于下标运算符 [] 比 * 运算符的优先级髙,p 首先与下标运算符 [] 相结合,说明 p 为数组,该数组中有 5 个元素,每个为 int * 型。即 p 为指针数组。
int (*ap)[2];()优先级高。定义了一个指向包含有两个元素的数组的数组指针。数组指针是指向一个数组的指针,亦称行指针。 是“指向数组的指针”的简称
指针数组:它是“储存指针的数组”的简称。
char *chararr[] = {"Fortan", "C++","Basic"};定义了一个指针数组并且对其进行初始化
从网络上看到这样一道有意思的题目,是关于数组与指针的问题,描述如下:
main()
{
int a[5]={1,2,3,4,5};
int *ptr=(int *)(&a+1);
printf("%d,%d",*(a+1),*(ptr-1));
}
输出为:2,5
请解释以上代码的输出结果。
答案如下:
*(a+1)其实很简单就是指a[1],输出为2.
问题关键就在于第二个点,*(ptr-1)输出为多少?
解释如下,&a+1不是首地址+1,系统会认为加了一个整个a数组,偏移了整个数组a的大小(也就是5个int的大小)。所以int *ptr=(int *)(&a+1);其实ptr实际是&(a[5]),也就是a+5.
原因为何呢?
&a是数组指针,其类型为int(*)[5];
而指针加1要根据指针类型加上一定的值,不同类型的指针+1之后增加的大小不同,a是长度为5的int数组指针,所以要加5*sizeof(int),所 以ptr实际是a[5],但是ptr与(&a+1)类型是不一样的,这点非常重要,所以ptr-1只会减去 sizeof(int*),a,&a的地址是一样的,但意思就不一样了,a是数组首地址,也就是a[0]的地址,&a是对象(数组)首地 址,a+1是数组下一元素的地址,即a[1],&a+1是下一个对象的地址,即a[5]。
2016-10-22 21:01:03
1 #include <iostream> 2 #include <stdio.h> 3 using namespace std; 4 int main (int argc, char *argv[]) 5 { 6 char a[2][3]={"xy","pq"}; 7 char *p[10]; 8 p[0] = "a"; 9 p[1] = "12345"; 10 for (int i = 0; i < 2; ++i) {//不能i < 10, 11 printf("%s\n", p[i]);//a 12345 12 } 13 printf("&p[0]:%#x %#x\n", p, &p[0]);//if addr(p)=0x6c3aa870 14 printf("&p+1:%#x\n", &p+1);//add(&p+1) will be 0x6c3aa8c0,ie,addr(p)+8*10=0x6c3aa870+0x50 15 printf("&p[1]:%#x %#x\n", p+1, &p[1]);//then addr(p+1)=addr(p)+0x8=0x6c3aa878 16 printf("&p[2]:%#x %#x\n", p+2, &p[2]);//addr(p+2)=addr(p)+2*0x8=0x6c3aa880 17 18 char (*x)[3]; 19 x = a; 20 for (int i = 0; i < 2; ++i) { 21 for (int j = 0; j < 3; ++j) { 22 printf("%c", *(*(x+i)+j)); 23 //printf("%c", x[i][j]); 24 } 25 } 26 printf("\n"); 27 printf("%ld\n", sizeof(x)); 28 printf("%#x %#x\n", x[0], x[1]);//addr(x[0])=0x6c3aa850 addr(x[1])=0x6c3aa853 29 30 char *p1=(char*)malloc(sizeof(char)*7); 31 printf("%u\n", sizeof(p1)); 32 printf("%#x %#x %#x\n", p1, p1+1, p1+2);//0x1478010 0x1478011 0x1478012 33 if(p1){ 34 free(p1); 35 p1=NULL; 36 } 37 38 int u = 10+010+0x10; 39 printf("%d\n", u);//34,we need pay attention to 010,the highest 0,which is a Octal(8) symbol, 40 return 0; 41 }
可参考其他文章: