指针笔试题

指针和数组笔试题解析 

二维数组

sizeof内部的表达式不参与运算,那么为什么呢?

原因:当我们写代码的时候是在test.c文件,但是在运行的时候是test.exe文件中运行

源代码要经过编译然后再加上链接,成为可执行程序才能运行,运算是在运行的过程中才完成的,但是sizeof在编译期间就完成了,所以sizeof内部的表达式不参与运算

总结:

数组名的意义:

1.sizeof(数组名),这里的数组名表示整个数组,计算的是整个数组的大小

2.&数组名,这里的数组名表示整个数组,取出的是整个数组的地址

3.除此之外所有的数组名都表示首元素的地址

指针笔试题

1.笔试题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  5

 2.笔试题2:

考察的是指针+-整数的问题

//由于还没学习结构体,这里告知结构体的大小是20个字节
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);
	printf("%p\n", (unsigned long)p + 0x1);
	printf("%p\n", (unsigned int*)p + 0x1);
	return 0;
}

0x100014        0x100001        0x100004

这里的p是结构体指针变量

 3.笔试题3:

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

%p--是打印地址

%x--是16进制格式打印

注意:打印的时候低位放在低地址,高位放高地址,需要将小端存储还原回来

4  2000000

 4.笔试题4:

int main()
{
	int a[3][2] = { (0,1),(2,3),(4,5) };
	int* p;
	p = a[0];
	printf("%d", p[0]);
	return 0;
}

1

逗号表达式的结果是最后一个表达式的结果

数组的初始化内容由逗号表达式,实际上数组初始化的是1,3,5

p[0]-->&a[0][0]

a[ 0 ]是二维数组第一行的数组名,对a[ 0 ] 这个数组名没有&,没有单独sizeof,所以a[ 0 ] 这个数组名表示数组首元素的地址,即a[ 0 ][ 0 ] 地址

a[ 0 ] -->&a[ 0 ][ 0 ]

5.笔试题5:

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

指针和指针相减得到的是指针之间的元素个数

FF FF FF FC  -4

 6.笔试题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.笔试题7:

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

 at

8.笔试题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;
}

POINT         ER         ST        EW

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值