如何判断Unix系统的一个库文件是32位还是64位的

某些时候,我们需要知道操作系统的位数,或者配置插件的时候需要知道主程序的位数(例如配置apache插件的时候需要知道apache的位数以便配置相应的插件),最简单的办法就是执行file命令,如:

Linux:

# file libnss1_files-2.2.4.so
libnss1_files-2.2.4.so: ELF 32-bit LSB shared object, Intel 80386, version 1, not stripped

# file libtrsbean.so
libtrsbean.so: ELF 64-bit LSB shared object, version 1, not stripped

AIX:32位的没有说明

#file /usr/ccs/lib/mcrt0.o
/usr/ccs/lib/mcrt0.o:   executable (RISC System/6000) or object module not stripped

#file /usr/ccs/lib/mcrt0_64.o
/usr/ccs/lib/mcrt0_64.o:        64-bit XCOFF executable or object module not stripped

Solaris:

# file libmp.so
libmp.so:       ELF 32-位 MSB 动态库 SPARC 版本 1,动态链接,没有除去

 

 

另外通过二进制查看命令od查看相关的库文件也可以解决此问题,但难度大,也不保险。下面给出在不同系统中的结果,以供参考(由于只在某一版本的操作系统下面做的测试,下面的结果不可能适应所有的所有版本的系统)

Linux

32位第4段是0101;64位第4段是0102
     -h 表示按16进制2字节整数查看,整数高低位也调整了(如7f45变成457f); -N 10 表示查看10个字节

#od -h -N 10 32.so
      0000000 457f 464c 0101 0001 0000

#od -h  -N 10  64.so
      0000000 457f 464c 0102 0001  0000

Solaris

和Linux差不多,只是Linux的 -h 参数变成 -x。另外显示结果也不太一样,Solaris是按照字节顺序显示的,Linux是按照16进制2字节整数查看,会把高低位调整了。

#od -x -N 10  32.so           
     0000000 7f45 4c46 0101 0100 0000

#od -x -N 10  64.so           
     0000000 7f45 4c46 0102 0100 0000

AIX

32位是01df ;64位是01f7

#od -N 10 -h crt0_r.o
     0000000  01df 0003 3d65 462a 0000

#od -N 10 -h mcrt0_64.o
      0000000  01f7 0003 3fe2 7fd5 0000

 

HP Unix

没有实际操作,只是通过UltraEdit打开两个文件xxx32.sl和xxx64.sl并比较前面几个字节(惠普库文件是.sl结尾不是.so结尾的)。发现64位的文件和Linux/Solaris的类似。

02 10 01 0e 05 12 40

7f 45 4c 46 02 02 01

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值