通过反汇编简要描述char *str和char str[]的区别以及调用printf输出字符串

结论:

假设以下代码存在于函数内部,即为初始化局部变量

  • char *pStr = "aaaaa";

  此时是把pStr初始化一个指向字符的指针,这个指将针被初始化在栈上或者寄存器中。
  字符串"aaaaa"作为常量直接被放在程序的.rodata段内,即一个固定的地方,在代码编译后,就已经将字符串的地址确定下来了,所以会将这个地址直接编码在指令中(加载时可能需重定位)。当初始化这个指针,为其赋值"aaaaa"时,会直接将常量"aaaaa"的地址赋予指针pStr
  • char arrayStr[] = "aaaaa";

  此时是初始化一个字符数组,"aaaaa"并非作为常量存放在.rodata段内,而是在调用拥有这行代码的函数时,初始化在其栈中,arrayStr"aaaaa"的首地址。
  因为str(字符数组的首地址)在初始化时就已经固定了,是该函数运行时栈某个位置的一个固定的地址,即其是一个常量,故以下最后两行赋值就是错误的:
  char arrayStr[] = "aaaaa";
  char *s = "abcd"
  
  str = "bbbbbb"; //error!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!  将常量字符串的地址赋值给不可被修改的数组首地址
  str = s;         //error!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! 将指向字符的指针赋值给不可被修改的数组首地址
  • pStrarrayStr作为printf参数时,实际上都是将字符数组的地址作为参数,此时如果格式化字段为%d就是打印这个地址,若是%c就打印字符数组。

    int printf(const char * formal ,[optional],[optional],[optional]...);
    

  

分析:

  • 初始化一个字符指针指向一个字符数组
linux >>> gcc  -Og  -o  pTest  -fno-stack-protector  pTest.c //编译源文件
linux >>> objdump -d -pTest.c                                //查看源文件反汇编代码
int pTest(){                               
  char *a = "aaaaaa";
  printf("%s",p);
}

                  
0000000000400546 <main>:
  400526:   48 83 ec 08             sub    $0x8,%rsp
  40052a:   be d4 05 40 00          mov    $0x4005d4,%esi
  40052f:   bf db 05 40 00          mov    $0x4005db,%edi
  400534:   b8 00 00 00 00          mov    $0x0,%eax
  400539:   e8 c2 fe ff ff          callq  400400 <printf@plt>
  40053e:   b8 00 00 00 00          mov    $0x0,%eax
  400543:   48 83 c4 08             add    $0x8,%rsp
  400547:   c3                      retq 

我们看到本段c代码初始化了一个指向字符的指针,并将一个形如"aaaaa"的字符数组赋值给这个指针。
然后观察汇编代码,我们知道x86-64gcc会默认%rdi存放要调用的函数第一个参数,%rsi存放要调用函数的第二个参数。此时反汇编代码直接将0x4005d40赋值给寄存器%esi0x4005db赋值给寄存器%edi

所以我们去查看这两个地址上的数据:

 linux > objdump -s  pTest
Contents of section .rodata:
     4005d0 01000200 61616161 61610025 6400      ....aaaaaa.%d. 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,928评论 6 509
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,748评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,282评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,065评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,101评论 6 395
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,855评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,521评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,414评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,931评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,053评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,191评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,873评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,529评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,074评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,188评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,491评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,173评论 2 357

推荐阅读更多精彩内容