目录
今天接着继续指针练习。🙂🙂🙂
指针笔试题
NO1.
//指针的类型
//转化后的类型
//解引用访问根据指针类型访问几个字节
//整型在内存中的存储------小端存储
//*解引用向后访问几个字节
cs
int main()
{
int a[5] = { 1, 2, 3, 4, 5 };
int *ptr = (int *)(&a + 1);
printf( "%d,%d", *(a + 1), *(ptr - 1));
return 0;
}
//程序的结果是什么?
NO2.
cs
一定一定要注意变量的类型
cs
//由于还没学习结构体,这里告知结构体的大小是20个字节
struct Test
{
int Num;
char* pcName;
short sDate;
char cha[2];
short sBa[4];
}*p;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
int main()
{
printf("%p\n", p + 0x1);
printf("%p\n", (unsigned long)p + 0x1);
printf("%p\n", (unsigned int*)p + 0x1);
return 0;
}
NO3.
bash
整数在内存的存储方式
解引用访问几个字节----根据指针的类型
注意变量的类型
+1,到底加几个字节
cs
int main()
{
int a[4] = { 1, 2, 3, 4 };
int *ptr1 = (int *)(&a + 1);
int *ptr2 = (int *)((int)a + 1);
printf( "%x,%x", ptr1[-1], *ptr2);
return 0;
}
NO4.
bash
逗号表达式
二维数组
p[0]=*(p-0)
cs
#include <stdio.h>
int main()
{
int a[3][2] = { (0, 1), (2, 3), (4, 5) };
int *p;
p = a[0];
printf( "%d", p[0]);
return 0;
}
NO5.✔
cs
&p[4][2]理解
%p就是打印地址,认为内存中存储的-4的补码就是地址
cs
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]);
return 0;
}
NO6.
bash
二维数组的整个数组的地址
第一行的地址
cs
int main()
{
int aa[2][5] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
int *ptr1 = (int *)(&aa + 1);
int *ptr2 = (int *)(*(aa + 1));
printf( "%d,%d", *(ptr1 - 1), *(ptr2 - 1));
return 0;
}
NO7.
bash
俄罗斯套娃
++
char*
char**
cs
#include <stdio.h>
int main()
{
char* a[] = { "work","at","alibaba" };
char** pa = a;
pa++;
printf("%s\n", *pa);
return 0;
}
NO8.✔
bash
+1 和 -1往哪个方向看清除
cs
int main()
{
char* c[] = { "ENTER","NEW","POINT","FIRST" };
char** cp[] = { c + 3,c + 2,c + 1,c };
char*** cpp = cp;
printf("%s\n", **++cpp);
printf("%s\n", *-- * ++cpp + 3);
printf("%s\n", *cpp[-2] + 3);
printf("%s\n", cpp[-1][-1] + 1);
return 0;
}
✔✔✔✔✔最后,感谢大家的阅读,若有错误和不足,欢迎指正!动手写一写.少说话多做事🆗🆗
代码------→【gitee:唐棣棣 (TSQXG) - Gitee.com】
联系------→【邮箱:2784139418@qq.com