Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2315226
  • 博文数量: 527
  • 博客积分: 10343
  • 博客等级: 上将
  • 技术积分: 5565
  • 用 户 组: 普通用户
  • 注册时间: 2005-07-26 23:05
文章分类

全部博文(527)

文章存档

2014年(4)

2012年(13)

2011年(19)

2010年(91)

2009年(136)

2008年(142)

2007年(80)

2006年(29)

2005年(13)

我的朋友

分类: LINUX

2010-02-24 15:54:03

#include
#include

int main()
{
        puts("hello,world");
        puts("world");
        return 0;
}

给定上述程序, gcc -o mytest test.c
默认不打开优化选项时, 不执行优化, hello,world 与 world是两个独立的字符串. 如果用工具把可执行文件中的hello,world强制改成 hello,!orld, 则会产生输出
hello,!orld
world

但如果打开了-O1 以上的选项, 用strings查看, world被合并到了hello,world中, 因为world碰巧是hello,world的最后一部分.

此时再把hello,world中的w改为!, 就会在输出中出现
hello,!orld
!orld
的结果.

在已将二进制文件发布给客户又无法得到源代码修改后rebuild的情况下, 曾这样尝试修改 ifconfig为
ifxxxfig, 但碰巧程序中另有一处理XML的代码中, 以strcmp与"config"作比较, 以此判断XML的root元素是否正确, 结果就出现了上面描述的奇怪bug.

ELF二进制文件没有做checksum, 实验说明直接修改其二进制文件是可行的.
阅读(1523) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~