狗都不学计算机——大端与小端(2)

简介

之前有说到大小端的问题,今天就来举个栗子吧!!!
如果你忘记了,或者想看之前的理论部分,不要99,不要9.9,免费白嫖见下方~~~
狗都不学计算机——大端与小端

案例代码

代码功能非常简单,就是将abcdefgh赋值给buffer字符数组中,然后将字符数组的内容输出出来。

# 文件名:main.c
#include <stdio.h>

int main()
{
    char buffer[10] = "abcdefgh";
    printf("buffer = %s\n",buffer);

    return 0;
}

实验环境

  • WSL子系统ubuntu22.04
  • gcc版本11.04
  • gdb版本12.1(使用gef插件)
    在这里插入图片描述

实验测试

1)使用gcc将案例代码进行编译:gcc main.c -o main,编译完成后可以运行查看结果。
在这里插入图片描述

2)在Linux下可以使用file命令查看可执行文件的信息:file main
在这里插入图片描述

3)使用gdb进行动态调试

  • 运行程序:gdb-gef main(因为使用了gef插件,因此gdb被我修改为gdb-gef)
    在这里插入图片描述

  • 设置main处断点:b main
    在这里插入图片描述

  • 运行程序:r(第二张图为程序的相关信息)
    在这里插入图片描述-------------------------美丽的图片分割线---------------------------------
    在这里插入图片描述

  • 向下单步执行程序:ni,当看到程序执行到下图红框处时停止使用ni命令
    在这里插入图片描述

  • 查看rax寄存器,可以看到存储的是buffer的值
    在这里插入图片描述

  • 再执行一次ni,然后查看栈中的内容
    在这里插入图片描述

接下来,详细看一下栈中的内容。

  • 使用x/s命令,以字符串的形式输出内存中的内容
    在这里插入图片描述

  • 使用x/xg,以十六进制的形式输出8字节的内容
    在这里插入图片描述

  • 再使用x/xb,以十六进制的形式输出8字节的内容
    在这里插入图片描述

x/xg命令得到的结果为0x6867666564636261(注意结果为十六进制),我们将其进行转换。
在这里插入图片描述

通过转换可以发现,字符串是以hgfedcba的形式进行存储的,a被存储在低位(注:x/s会对输出结果进行处理,便于调试,真正存储是按二进制存储的,但一般便于观察,像gdb这类的软件都是以十六进制进行显示的

无情的广告时间

哈哈哈哈,又到了大家喜欢的广告时间了,喜欢的话给个关注呗,公众号:编码魔坊,谢谢您的关注!!!

  • 23
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

道人禅(armey)

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值