超详细csapp-linklab之第一阶段“输出学号”实验报告

该实验的主题是"链接"。

准备工具

虚拟机,Ubuntu32位,hexedit,main.o,phase1.o,该实验的C代码框架如下

cpp 复制代码
// main.c
void (*phase)();   /*初始化为0*/

int main( int argc, const char* argv[] ) {
        if ( phase )
               (*phase)();
        else
               printf("To run lab, please link the relevant object module with the main module.\n");
        return 0;
}

// phase[n].c

void do_phase() {

        ... // 该阶段具体工作
}

void (*phase)() = do_phase;  

步骤1

命令行

gcc main.o phase1.o

./a.out

输出

实验目标:通过改phase1的.data节,使得输出是学号(假定学号是10个0)

步骤2

命令行

objdump -s -d a.out

把a.out反汇编的同时,显示源文件(这样就能看到每个节中的数据)

找到main函数,看0x8048437这一行,调用了地址为M[0x804a0d4]的函数。

找到0x804a0d4存的地址,发现是804845d(下图,高亮的地方,注意用小端序的方法来读)

再去找0804845d这个位置(从汇编代码找更清晰),如下图,发现就是do phase函数

这个函数里调用了puts来输出字符串,字符串的首地址就是第一个参数,调用前放在寄存器ax以实现传参。ax中的值为0x804a061,这就是字符串的首地址。

找到了位置 ,进入hexedit,在对应位置修改,即可

步骤3

重新链接,命令行

gcc main.o phase1.o -o test

./test

phase1完成

相关推荐
Tingjct9 小时前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
C雨后彩虹9 小时前
计算疫情扩散时间
java·数据结构·算法·华为·面试
飞机和胖和黄9 小时前
考研之王道C语言第三周
c语言·数据结构·考研
达文汐10 小时前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗10 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
Gorgous—l10 小时前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法
一条大祥脚11 小时前
26.1.26 扫描线+数论|因子反演+子序列计数|树套树优化最短路
数据结构·算法
李老师讲编程12 小时前
C++信息学奥赛练习题-杨辉三角
数据结构·c++·算法·青少年编程·信息学奥赛
期末考复习中,蓝桥杯都没时间学了12 小时前
力扣刷题13
数据结构·算法·leetcode
多米Domi01112 小时前
0x3f 第48天 面向实习的八股背诵第五天 + 堆一题 背了JUC的题,java.util.Concurrency
开发语言·数据结构·python·算法·leetcode·面试