(C语言)指针运算 习题练习1.1

习题一:

cs 复制代码
#include <stdio.h>
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;
	}

提示(在计算前要搞懂是什么类型)

答案:

1.p 是一个指向 struct Test 类型的指针。 p + 0x1 表示指针 p 向后移动一个 struct Test 的大小。由于 struct Test 的大小是 20 字节,所以 p + 0x1 实际上是 0x100000 + 20 = 0x100014。

这里就运用到计算机十六进制的运算了。或许有人算成 0x100020

在这里在复习一下

在十六进制中:

  • 每一位的权重是16的幂(从右到左依次是 160,161,162,...160,161,162,...)。
  • 加法规则:当某一位的和超过15时,需要向高位进位。
步骤1:将20转换为十六进制

20的十进制值转换为十六进制是:

Go 复制代码
20 (十进制) = 0x14 (十六进制)
  1. 提一个问题: 这里是不是指针+1 ?

答案:不是 .这里其实相等于 整数+1,也就是 0x100000+1 --> 0x100001

  1. 首先是强制转化为整型指针,所以这里是指针运算 = 指针加1,

也就是,0x100004 (跳过一个unsigned int* 大小为4个字节)

注意:本题与环境有关系

在x86环境下:

地址为8位数,所以要补齐

在x64环境下:

习题二:

注意这里有坑奥,小心啊诸君

cs 复制代码
#include <stdio.h>
int main()
{
    int a[3][2] = { {0, 1}, (2, 3), (4, 5) };
    //int a[3][2] = { {0, 1}, {2, 3}, {4, 5} };
    int* p;
    p = a[0];
    printf("%d", p[0]);
    return 0;
}

欧克,不知道各位掉入坑没有?发现坑没有?

如果你的答案是0,那么恭喜你成功入坑。

答案揭晓:是 1

这里{0, 1}, (2, 3), (4, 5) 所用的是小括号(),而不是{ },那么其中所表达意思也截然不同,用(),也就是逗号表达式,那什么是逗号表达式呢?

逗号表达式会计算其所有操作数,但只返回最后一个操作数的结果。因此,(0,1)的结果是1,(2, 3) 的结果是 3(4, 5) 的结果是 5。所以,数组 a 实际上被初始化为:1,3,5,0,0,0.

习题三

假设环境是x86环境,程序输出的结果是啥?

注意:指针-指针的前提是两个指针指向同一个空间

得到的结果的绝对值是两个指针之间的元素个数 ,小地址-大地址会得到负数

提示:可以画出图更易理解

cs 复制代码
#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;
}

答案:FFFFFFFC, -4

不知道有小伙伴答对了嘛

在搞懂了位置和大小后要注意输出的格式 %p %d

  • 第一个参数%p):输出地址差值的指针表示,直接将内存的值,当作地址直接打印
  • −4(十进制)在 x86环境下表示为无符号整数时是 0xfffffffc0xfffffffc(32位系统)。(这里会运用的到原码,反码,补码的概念)
  • 第二个参数%d):输出地址差值的整数值。
    −4.

欧克,今日的习题就到此为止了。下章再见。

如果有什么疑问或错误,欢迎指出!

相关推荐
大白同学4214 分钟前
【C++】用哈希表封装unordered_XX
开发语言·c++·散列表
GIS小天3 小时前
AI+预测3D新模型百十个定位预测+胆码预测+去和尾2025年8月25日第170弹
人工智能·算法·机器学习·彩票
PAK向日葵4 小时前
【算法导论】XM 0823 笔试题解
算法·面试
岁月栖迟4 小时前
leetcode 49. 字母异位词分组
windows·算法·leetcode
Asmalin4 小时前
【代码随想录day 21】 力扣 77. 组合
算法·leetcode·职场和发展
XH华5 小时前
C语言第十一章内存在数据中的存储
c语言·开发语言
AndrewHZ6 小时前
【python与生活】如何用Python写一个简单的自动整理文件的脚本?
开发语言·python·生活·脚本·文件整理
拉法豆粉7 小时前
在压力测试中如何确定合适的并发用户数?
java·开发语言
枯萎穿心攻击7 小时前
Unity VS UE 性能工具与内存管理
开发语言·游戏·unity·ue5·游戏引擎·虚幻·虚幻引擎
老赵的博客7 小时前
c++ 常用接口设计
开发语言·c++