指针笔试题

文章主要包含一系列C语言的笔试题目,涉及指针指向数组、结构体以及内存地址计算的题目。例如,分析指针加减操作在不同数据类型指针下的表现,以及对数组、多维数组和字符串的指针操作。这些题目考察了对C语言内存管理和指针操作的理解。
摘要由CSDN通过智能技术生成
题目的问题都是 程序的结果是什么?
笔试题 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;
}

解析:

 笔试题2

#include<stdio.h>
struct Test
{
	int Num;
	char* pcName;
	short sDate;
	char cha[2];
	short sBa[4];
}*p;
//假设p 的值为0x100000。 如下表表达式的值分别为多少?
//已知,结构体Test类型的变量大小是20个字节
int main()
{
	printf("%p\n", p + 0x1);
	printf("%p\n", (unsigned long)p + 0x1);
	printf("%p\n", (unsigned int*)p + 0x1);
	return 0;
}

解析:

(1)p为结构体指针,+1要跳过1个结构体(20字节)=> 0x100000+1==0x100014

(2)(unsigned long)p =>0x100000为无符号长整型,0x100000+1==0x100001

(3)(unsigned int*)p 为无符号整型指针,+1要跳过1个整型,0x100000+1==0x100004

笔试题 3
#include <stdio.h>
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;
}

解析:

 

 笔试题4

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

解析:

 逗号表达式,就是用逗号隔开的多个表达式。

逗号表达式,从左向右依次执行。整个表达式的结果是最后一个表达式的结果。

 笔试题5

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

解析:

-4的补码的16进制以小端存储是 FFFFFFFC

如果有问题请看http://t.csdn.cn/Vpz8G

 笔试题6

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

该问题为 笔试题1的变式,解题思路相同

 笔试题7

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

解析:

 

  笔试题8

#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-1

 ++cpp图(紫色标记为路径  图8-2)

                                                               图8-2

*-- * ++cpp + 3图(红色圈圈为路径  图8-3)

                                                                   图8-3

 *cpp[-2] + 3图(粉色圈圈为路径     图8-4)

                                                                     图8-4

 cpp[-1][-1] + 1图(橙色圈圈为路径     图8-5)

                 

                                                                       图8-5

以上为我个人的小分享,如有问题,欢迎讨论!!!

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值