1.int a = 10;
int* p = &a;
p++;则是说明p指针往后跳过一个整形大小
而int** q = &p;
q++;
说明q往后跳过一个int*的变量(大小)
2.int a[3][4] = { 0 };
printf("%d\n", sizeof(a + 1));
输出4/8
注意好那个sizeof要求的是 单独 放在其内部
printf("%zd\n",sizeof(*(a + 1)));
注:*(a + 1) == a[1]
第二行的数组名,单独放在sizeof内部,计算的是第二行的大小即16个字节
初步总结:放在*()括号内部的地址的那些规则先不要着急用,尝试下等价思想
printf("%zd\n", sizeof(*(&a[0] + 1)));
访问的是第二行,计算的是第二行的大小,16个字节
因为类型:
int(*p)[4] = &a[0] + 1
printf("%zd\n", sizeof(&a[0] + 1));
&a[0]是第一行的地址,&a[0]+1就是第二行的地址.4/8个字节
printf("%zd\n", sizeof(*a));
这里的a是第一行的地址,*a就是第一行,sizeof(*a)计算的是第一行的大小,16个字节
*a == *(a+0) == a[0]
printf("%zd\n", sizeof(a[3]));
这里不存在越界,因为sizeof内的表达式不会真实计算的,计算的是第四行的大小即16个字节
此类多练搜:
3.数组名的意义:
1.sizeof(数组名),这里的数组名表示整个数组,计算的是整个数组的大小
2.&数组名,这里的数组名表示整个数组,取出的是整个数组的地址.
3.除此之外所有的数组名都表示首元素的地址.
4.unsigned int*类型的指针+1跳过4个字节
5.打印时用%p来打印的是打印8位(在x86环境下)
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
int a = 0;
//x86环境下
printf("%p\n", &a);//输出:008FF8E4
printf("%x\n", &a);//输出:8ff8e4
return 0;
}
64位环境下
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
int a = 0;
//x64环境下
printf("%p\n", &a);//输出:0000008BDB34F7C4
printf("%x\n", &a);//输出:db34f7c4
return 0;
}
如若想要加上%x则在%x中间加上#即可
6.逗号表达式是从前往后计算(已验)
7.%d打印的是原码,%p打印的是补码
例:
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
int c = -4;
printf("%p\n", c);//输出FFFFFFFC
return 0;
}
8.画图很重要
9.很好一例题:
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
int a[5][5];
int(*p)[4] ;
p = a;
printf("%p %d\n", &p[4][2] - &a[4][2], &p[4][2] - &a[4][2]);
//结果FFFFFFFC -4
return 0;
}
10.碰到像*(aa + 2)的,将之转换为aa[2]
11.
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
char* ra[] = { "lisi", "wangwu", "zhangsan", "xiaobai"};//输出wangwu
char** pra = ra;
pra++;
printf("%s\n", *pra);
return 0;
}
12.题3连线3搜:
13.字符分类函数12月搜
14.getchar对应putchar
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
int a = getchar();//输入O
putchar(a);//输出O
return 0;
}
15.gets对应puts
#define _CRT_SECURE_NO_WARNINGS 1
#include
int main()
{
char a[100] = { 0 };
gets(a);//输入asdfghj
puts(a);//输出asdfghj
return 0;
}
16..字符转换函数12月搜