玩转指针重难点(3)

习题篇

1.

#include
int main()
{
     
    int a[5] = {
      1, 2, 3, 4, 5 };
    int *ptr = (int *)(&a + 1);
    printf( "%d,%d", *(a + 1), *(ptr - 1));
    return 0; 
}

这道题*(a+1)简单,就是数组首元素地址+1算出来的就是2。关键是第二个题,用来存放&a的是数组指针也就是int (*)[5],但前面有个整型指针的强转,所以&a+1由下图表示。
玩转指针重难点(3)_第1张图片
由于ptr-1,此时已经被转化为整型指针,减一就是往前移动一个整型。也就是5.

2.

#include
struct Test
{
     
	int Num;
	char *pcName;
	short sDate;
	char cha[2];
	short sBa[4];
}* p;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
int main()
{
     
	p = (struct Test*)0x100000;

	printf("%p\n", p + 0x1); // 0x100014
	printf("%p\n", (unsigned long)p + 0x1); // 0x100001
	printf("%p\n", (unsigned int*)p + 0x1); // 0x100004

	return 0;
}

①这里p被转化为了结构体指针,0x1是十六进制的1也是1,+1跳过一个结构体的指针的字节数也就是20,20转化为16进制加上0x100000也是就是答案了。
②这里的p被转化为整型+1就是+1。
③这里的p被转化为整型指针+1跳过4个字节。

3.

#include
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;
}

地址在内存中的存储都是以小端字节序来储存的,如果有人不懂小端字节序的话可以看看这篇博客整型在内存中的存储
玩转指针重难点(3)_第2张图片
ptr1[-1]的意思是*(ptr1+(-1)),-1移动一个整型,也就是内存中04000000,以十六进制打印就是4。
(int)a + 1是一个整数跳过一个字节
玩转指针重难点(3)_第3张图片

4.

#include 
int main()
{
     
	int a[3][2] = {
      1, 3, 5 };
	int *p;
	p = a[0];
	printf("%d", p[0]);
	return 0;
}
// 输出结果是什么?

a的排列在这里插入图片描述
a[0],a[1],a[2] 分别是每一行的数组名,即每一行首元素的地址p[0]相当于对a解引用答案就是1。

5.

#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]);

	return 0;
}

玩转指针重难点(3)_第4张图片
p[4][2]相当于*(*(p+4)+2),两个指针相减得到是元素之间的个数也就是-4,在内存中的存储为玩转指针重难点(3)_第5张图片
转化为16进制是ffffffc。

6.

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;
}

这道题和第三道题的思路一样,大家可以自己感受一下。
答案是10和5.

7.

#include 
int main()
{
     
    int a[3][2] = {
      (0, 1), (2, 3), (4, 5) };
    int *p;
    p = a[0];
    printf( "%d", p[0]);
    return 0;
}
// 输出结果为多少?

逗号表达式得出来的是后面那个数,所以该题答案为1。

8.

#include
int main()
{
     
 	char *c[] = {
     "work","at","alibaba"};
    char**pa=a;
    pa++;
    printf("%s ",*pa);
	 return 0;
}

玩转指针重难点(3)_第6张图片

你可能感兴趣的:(c语言,c++,指针,数据结构,算法,c语言)