33,311
社区成员
发帖
与我相关
我的任务
分享
//char (*(*x[3])())[5];//x是什么类型的变量?
//
//分析C语言声明,关键是搞清楚这个变量是个什么东西(函数、指针、数组),
//是函数那么剩下的就是他的参数和返回值,
//是指针那剩下部分是说明他指向什么,
//是数组剩下的部分就是说明数组的成员是什么类型。
//解析C语言声明规则:
//从左侧第一个标识符开始,按照优先级进行结合。*表示是..的指针,const表示只读的,volatile表示可变的,[]表示是数组,()表示是函数。
//
//x和[3]结合说明是一个大小为3的数组,该数组的每个元素为一类指针,该类指针指向一类函数,该类函数无参数,返回一类指针,该类指针指向一个大小为5的char型数组
#include <stdio.h>
#include <typeinfo.h>
char num[5];
char (*x00())[5] {
return #
}
int main() {
char (*(*x[3])())[5];//是个数组,大小为3
char (*(*x0 )())[5];//数组的元素,是个函数指针
char (*( x00 )())[5];//函数原型,参数为空,返回值为指针
char (* x000 )[5];//返回值
x0 = x00;
x[0] = x0;
x[1] = x0;
x[2] = x0;
printf("typeid(x).name() is %s\n",typeid(x).name());
return 0;
}
//typeid(x).name() is char (* (__cdecl**)(void))[5]
#include <stdio.h>
int main(void)
{
int a[3][2] = {1, 2, 3, 4, 5, 6};
int *p = a[1] + 1;
int *q = *(a+1) + 1;
printf("*p = %d\n", *p);
printf("*q = %d\n", *q);
return 0;
}
看一下p和q指向的内容是不是一样的。
变量+1时,需要注意变量的类型。a=&a[0],所以a+1即为&a[1],即为数组a[1]首地址
描述有点问题吧:a + 1即a[1]去掉&;即a + 1 等价a[1];
p = a+1即p = a[1];
那照你这么说a+1==a[1];
那么假设这是个a[3][2]数组,在p=a[1]的基础上再+1;
按理来说答案得到的是a[2]的地址,而由我一开始的测试可知
3.a[0]+1
输出 20
即在p=a[1]的基础上再+1输出的是a[1][1];
这不就与答案有冲突了吗?a=&a[0],所以a+1即为&a[1],即为数组a[1]首地址
描述有点问题吧:a + 1即a[1]去掉&;即a + 1 等价a[1];
p = a+1即p = a[1];
2. *p指向下一个数组的首元素,所以里面存的是乱码
若p = &a+1;那么p指向的是数组的a偏移sizeof(int) * 2 * 2后面的地址。该地址内的值是随机值,所以输出的是6356748
4. &a[0]+1等价(a+0) + 1;即a[1],p = a[1];而不是&a[1],若是&a[1]赋值给p那么类型也不匹配呢。
6. a[0][0]+1不是地址,相当于把20 + 1赋值给p那么,很可能会导致段错误;因为地址为21的地址空间可能是不可读的。
以上是个人理解,供参考;