指针笔试题

题目1

#include <stdio.h>
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等价于中的这个a代表整个数组,所以&a的类型就是int(*)[5],容易得a+1指向如下图所示

 *(ptr-1)则先让ptr往后走一个int大小的位置(因为ptr是int指针),再对其进行解引用

*(ptr-1)就是5

*(a+1)中的a代表的数组首元素,所以这个式子等价于a[1]

 结果是

 

题目2

#include<stdio.h>
//在X86环境下
//假设结构体的⼤⼩是20个字节
//程序输出的结构是啥?
struct Test
{
 int Num;
 char *pcName;
 short sDate;
 char cha[2];
 short sBa[4];
}*p = (struct Test*)0x100000;

int main()
{
 printf("%p\n", p + 0x1);
 printf("%p\n", (unsigned long)p + 0x1);
 printf("%p\n", (unsigned int*)p + 0x1);
 return 0;
}

首先我们要明白0x1是16进制数,对应十进制数1

也就是说上面的0x1就是1 

  1. p+0x1等价于p+1,即p跳到一个struct Text大小后去,即当前地址加20
  2. p被强制转换为十六进制无符号整数,加1
  3. p被强制转换为无符号整型指针,这改变了p+0x1跳动的距离,变成了4(一个unsigned int的大小)

 

题目3

#include<stdio.h>
//小端存储,x86环境
int main()
{
int a[4]={1,2,3,4};
int*ptr1=(int*)(&a+1)
int*ptr2=(int*)((int)a+1);
printf("%x\n%x",ptr1[-1],*ptr2);
}

ptr1和上面那个有点相同啊 

 

解引用ptr1[-1]就是4 

小端存储转变后就是

 

 

题目3

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

 首先它这个数组初始化就等价于下面这个

int a[3][2]={1,3,5};

a[0]相当于第一行的数组名,也会被转换为第一个元素的地址 

p指向了二维数组第一个元素,p[0]等价于*p,就是1 

 

题目4

//假设环境是x86环境,程序输出的结果是啥?
#include <stdio.h>
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;
}

我们把a的地址强行赋值给p,但是p是个int(*)[4]指针,a是int(*)[5]指针,两个指针加减一个整数时跨过的区域不同,p[4][2]和a[4][2]的位置如下图蓝色区域所示 

 

本来都应该是打印成-4的,但是第一个打印出-4的补码的十六进制表现形式 

 

题目5

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

 

 

题目6

#include <stdio.h>
int main()
{
 char *a[] = {"work","at","alibaba"};
 char**pa = a;
 pa++;
 printf("%s\n", *pa);
 return 0;
}

 

pa++后变成

 

 

题目7

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

 第一句

第二句 

 

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值