您的位置:首页 > 运维架构 > Linux

linux中的strip命令简介

2017-11-15 15:24 816 查看
转自:http://blog.csdn.net/stpeace/article/details/47090255

作为一名linux开发人员, 如果没有听说过strip命令, 那是很不应该的。 strip这个单词, 大家应该早就学过了, 你就记住是脱衣服就行了, 别的不要多想。 在linux中, strip也有脱衣服的含义, 具体就是从特定文件中剥掉一些符号信息调试信息

我们来看main.c文件:

[cpp] view
plain copy

#include <stdio.h>  

  

int add(int x, int y)  

{  

    return x + y;  

}  

  

int aaa;  

int bbb = 1;  

char szTest[] = "good";  

  

int main()  

{  

    int ccc = 2;  

    return 0;  

}  

然后我们看看结果:

[plain] view
plain copy

[taoge@localhost learn_strip]$ ls  

main.c  

[taoge@localhost learn_strip]$ gcc main.c   

[taoge@localhost learn_strip]$ ls -l a.out   

-rwxrwxr-x 1 taoge taoge 4673 Jul 27 05:30 a.out  

[taoge@localhost learn_strip]$ file a.out   

a.out: ELF 32-bit LSB executable, Intel 80386, version 1 (GNU/Linux), dynamically linked (uses shared libs), for GNU/Linux 2.6.18, not stripped  

[taoge@localhost learn_strip]$ nm a.out   

08049538 d _DYNAMIC  

08049604 d _GLOBAL_OFFSET_TABLE_  

0804847c R _IO_stdin_used  

         w _Jv_RegisterClasses  

08049528 d __CTOR_END__  

08049524 d __CTOR_LIST__  

08049530 D __DTOR_END__  

0804952c d __DTOR_LIST__  

08048520 r __FRAME_END__  

08049534 d __JCR_END__  

08049534 d __JCR_LIST__  

08049628 A __bss_start  

08049618 D __data_start  

08048430 t __do_global_ctors_aux  

08048310 t __do_global_dtors_aux  

08048480 R __dso_handle  

         w __gmon_start__  

0804842a T __i686.get_pc_thunk.bx  

08049524 d __init_array_end  

08049524 d __init_array_start  

080483c0 T __libc_csu_fini  

080483d0 T __libc_csu_init  

         U __libc_start_main@@GLIBC_2.0  

08049628 A _edata  

08049634 A _end  

0804845c T _fini  

08048478 R _fp_hw  

08048274 T _init  

080482e0 T _start  

08049630 B aaa  

08048394 T add  

0804961c D bbb  

08049628 b completed.5963  

08049618 W data_start  

0804962c b dtor_idx.5965  

08048370 t frame_dummy  

080483a2 T main  

08049620 D szTest  

[taoge@localhost learn_strip]$   

       通过ls -l 命令可知, a.out的大小是4673个字节;

       通过file命令可知, a.out是可执行文件, 且是not stripped, 也就是说没有脱衣服。

       通过nm命令, 可以读出a.out中的符号信息。

       现在, 我把a.out的衣服strip掉, 得到的结果为:

[plain] view
plain copy

[taoge@localhost learn_strip]$ ls  

a.out  main.c  

[taoge@localhost learn_strip]$ strip a.out   

[taoge@localhost learn_strip]$ ls -l a.out   

-rwxrwxr-x 1 taoge taoge 2980 Jul 27 05:34 a.out  

[taoge@localhost learn_strip]$ file a.out   

a.out: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), dynamically linked (uses shared libs), for GNU/Linux 2.6.18, stripped  

[taoge@localhost learn_strip]$ nm a.out   

nm: a.out: no symbols  

[taoge@localhost learn_strip]$   

       通过ls -l 命令可知, a.out的大小是2980个字节, 大大减小;

       通过file命令可知, a.out是可执行文件, 且是stripped, 也就是说衣服被脱了;

       通过nm命令, 发现a.out中的符号没有了。

        由此可见, strip用于脱掉文件的衣服, 文件会变小, 其中的符号信息会失去。 那这个strip有什么用呢? 很有用的! 原来的a.out比较大, 可以执行。 在strip之后, 文件变小了, 仍然可以执行, 这就就节省了很多空间。

        其实, strip不仅仅可以针对可执行文件, 还能针对目标文件和动态库等。

     

        在实际的开发中, 经常需要对动态库.so进行strip操作, 减少占地空间。 而在调试的时候(比如用addr2line), 就需要符号了。 因此, 通常的做法是: strip前的库用来调试, strip后的库用来实际发布, 他们两者有对应关系。 一旦发布的strip后的库出了问题, 就可以找对应的未strip的库来定位。

        最后啰嗦一句, 某某动态库strip前是18M左右, strip后是3M左右, 可见, 脱脱衣服还是有明显好处的。

        补充: 后来发现, 在调试过程中, 经常涉及到传库, 库太大时, 很耗费传输时间, 所以还是用strip来搞一下吧。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: