C语言指针笔试真题整理(8道)(下)

简介: C语言指针笔试真题整理(8道)(下)

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

解析

&aa + 1

取出二维数组的地址,再+1,跳过了这个二维数组,

&aa + 1是数组指针,要进行强制类型转换,转换成int*类型

*(aa + 1)

aa是数组名,表示的是二维数组的首元素,即第一行元素

(aa + 1)跳过了一行,指向的是第二行元素

解引用之后, *(aa + 1) == aa[1],也就是第二行元素的数组名,表示的是第二行首元素6的地址

*(ptr1 - 1)

ptr1是整型指针,减一之后,指向10,

解引用之后输出的结果是10

*(ptr2 - 1)

ptr2是整型指针,减一,指向5这个元素

多说一句:

ptr2在转换类型之前,就是int*类型,之后再进行类型转换可能只是为了形式美观

7

题干

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

答案

at

解析

温习旧识

字符指针

char *p = “abcdef”

该指针存储的是,该常量字符串的首元素a

a[]

a[],是字符指针数组,每个元素存储的都是字符串的首元素的地址,

如图:

a是数组名,存储的是首元素的地址,

即‘w’

pa

pa是二级指针变量,存储的是a数组首元素的地址

pa++,跳过的是pa指向元素的类型的大小,而它指向的元素类型是char*,指向的就是a数组中的第二个元素

,也就是at中a的地址

那么以字符串的形式打印*(pa),结果就是at

8

题干

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

解析

很多朋友看到这道题可能想放弃,不要放弃,我们一步一步来分析

c[]

字符指针数组,四个元素,存储的分别是E、N、P、F的地址,

如图:

cp[]

二级字符指针数组,c是数组的数组名,即首元素的地址,

自己进行一一对应

cpp

三级指针,存储的是cp的地址,也就是cp首元素的地址

如图:

**++cpp

cpp先自增,如图

再解引用两次,第一次解引用获得c+2,第二次解引用获得字符P的地址

再以字符串的形式打印出point

*-- * ++cpp + 3

先计算++cpp

注意:此时cpp的生命周期没有结束,还在代码块之内

解引用获得c+1

再自减,变成c

此时再进行解引用,得到字符‘E’的地址,

最后+3(向后移动三位),此时指向的就是ENTER中的第二个E

最终输出结果就是ER

*cpp[-2] + 3

cpp[-2] == *(cpp+(-2))

*cpp[-2]  ==  **(cpp+(-2))
*cpp[-2] + 3 == **(cpp - 2) + 3

(cpp - 2)指向的是c+3

两次解引用之后,字符F的地址

+3,向后移动三位,是字符S的地址

打印结果是:

ST

cpp[-1][-1] + 1

cpp[-1][-1] == *(*(cpp-1)-1)

cpp-1,指向的是c+2

如图

c+2,再减一,变成c+1

之后解引用获得字符N的地址,

加1,指向的是字符E,

最终打印的结果就是EW

结语

这8道题到这里就讲解结束了,怎么样,希望你有所收获

这类题作为笔试题,很强调自己对于画图能力的要求,这也是很重要的

我们下篇文章再见~



相关文章
|
22天前
|
C语言
【c语言】指针就该这么学(1)
本文详细介绍了C语言中的指针概念及其基本操作。首先通过生活中的例子解释了指针的概念,即内存地址。接着,文章逐步讲解了指针变量的定义、取地址操作符`&`、解引用操作符`*`、指针变量的大小以及不同类型的指针变量的意义。此外,还介绍了`const`修饰符在指针中的应用,指针的运算(包括指针加减整数、指针相减和指针的大小比较),以及野指针的概念和如何规避野指针。最后,通过具体的代码示例帮助读者更好地理解和掌握指针的使用方法。
44 0
|
21天前
|
C语言
【c语言】指针就该这么学(3)
本文介绍了C语言中的函数指针、typedef关键字及函数指针数组的概念与应用。首先讲解了函数指针的创建与使用,接着通过typedef简化复杂类型定义,最后探讨了函数指针数组及其在转移表中的应用,通过实例展示了如何利用这些特性实现更简洁高效的代码。
15 2
|
22天前
|
C语言
如何避免 C 语言中的野指针问题?
在C语言中,野指针是指向未知内存地址的指针,可能引发程序崩溃或数据损坏。避免野指针的方法包括:初始化指针为NULL、使用完毕后将指针置为NULL、检查指针是否为空以及合理管理动态分配的内存。
|
22天前
|
C语言
C语言:哪些情况下会出现野指针
C语言中,野指针是指指向未知地址的指针,通常由以下情况产生:1) 指针被声明但未初始化;2) 指针指向的内存已被释放或重新分配;3) 指针指向局部变量,而该变量已超出作用域。使用野指针可能导致程序崩溃或不可预测的行为。
|
28天前
|
存储 C语言
C语言32位或64位平台下指针的大小
在32位平台上,C语言中指针的大小通常为4字节;而在64位平台上,指针的大小通常为8字节。这反映了不同平台对内存地址空间的不同处理方式。
|
28天前
|
存储 算法 C语言
C语言:什么是指针数组,它有什么用
指针数组是C语言中一种特殊的数据结构,每个元素都是一个指针。它用于存储多个内存地址,方便对多个变量或数组进行操作,常用于字符串处理、动态内存分配等场景。
|
28天前
|
存储 C语言
C语言指针与指针变量的区别指针
指针是C语言中的重要概念,用于存储内存地址。指针变量是一种特殊的变量,用于存放其他变量的内存地址,通过指针可以间接访问和修改该变量的值。指针与指针变量的主要区别在于:指针是一个泛指的概念,而指针变量是具体的实现形式。
|
29天前
|
C语言
C语言指针(3)
C语言指针(3)
11 1
|
29天前
|
C语言
C语言指针(2)
C语言指针(2)
13 1
|
21天前
|
编译器 C语言
【c语言】指针就该这么学(2)
本文详细介绍了指针与数组的关系,包括指针访问数组、一维数组传参、二级指针、指针数组和数组指针等内容。通过具体代码示例,解释了数组名作为首元素地址的用法,以及如何使用指针数组模拟二维数组和传递二维数组。文章还强调了数组指针与指针数组的区别,并通过调试窗口展示了不同类型指针的差异。最后,总结了指针在数组操作中的重要性和应用场景。
16 0