数组指针与指针数组

本文详细解析了一段使用数组与指针进行运算的C语言代码,重点解释了`*(a+1)`与`*(ptr-1)`的输出结果及背后的原因,深入探讨了数组指针与指针数组的特性及其操作机制。

 

 

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 }

 

转载于:https://www.cnblogs.com/guxuanqing/p/4914800.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值