判断Unix系统及库文件是32位还是64位的详解
一、查看系统32还是64位系统
bootinfo -y 查看硬件位数
bootinfo -K 查看内核位数
二、查看库文件是32位还是64位
1、使用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,动态链接,没有除去
2、通过二进制查看命令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条)