64位linux下编译32位程序命令: gcc -m32 test.c -o test32
64位linux下编译64位程序命令: gcc -m64 test.c -o test64
64位linux下编译32位 .o 命令:gcc -m32 -c test.c
64位linux下编译64位 .o 命令:gcc -m64 -c test.c
64位linux下编译32位静态库命令:ar cr libt32.a sotest.o
64位linux下编译64位静态库命令:ar cr libt64.a sotest.o
64位linux下编译32位动态库命令:gcc -m32 -g -Wall -shared -fPIC sotest.c -o libt32.so
64位linux下编译64位动态库命令:gcc -m64 -g -Wall -shared -fPIC sotest.c -o libt64.so
64位linux下编译32位调用动态库程序命令: gcc -m32 test.c -L./ -lt32 -o t32 或者 gcc -m32 test.c libt32.so -o t32 两者效果一样
64位linux下编译64位调用动态库程序命令: gcc -m64 test.c -L./ -lt64 -o t64 或者 gcc -m64 test.c libt64.so -o t64 两者效果一样
查看静态库导出函数: nm -s *.a
查看.a库文件位数:objdump -a *.a
查看.so库文件位数:objdump -a *.so或者file *.so
-----------------------------------------------------------------------------------------------------------------------
64位Aix下编译32位程序命令: gcc -maix32 test.c -o test32
64位Aix下编译64位程序命令: gcc -maix64 test.c -o test64
64位linux下编译32位 .o 命令:gcc -m32 -c test.c
64位linux下编译64位 .o 命令:gcc -m64 -c test.c
64位Aix下编译32位静态库命令ar cr libt32.a *.o
64位Aix下编译64位静态库命令ar -X64 cr libt64.a *.o
64位Aix下编译32位动态库命令:gcc -maix32 -g -Wall -shared -fPIC sotest.c -o libt32.so
64位Aix下编译64位动态库命令:gcc -maix64 -g -Wall -shared -fPIC sotest.c -o libt64.so
64位Aix下编译32位调用动态库程序命令: gcc -maix32 test.c libt32.so -o t32
64位Aix下编译64位调用动态库程序命令: gcc -maix64 test.c libt64.so -o t64
查看32位静态库导出函数: nm *.a
查看64位静态库导出函数: nm -X64 *.a
查看.so库文件位数: file *.so
-----------------------------------------------------------------------------------------------------------------------
64位linux编译32程序时错误提示:/usr/include/gnu/stubs.h:7:27: error: gnu/stubs-32.h:No such file or directory
# yum -y install glibc-devel.i386
1、64为linux编译如果不带m64参数编译出来的程序依然为64位
2、编译目录下执行export LD_LIBRARY_PATH=./:$LD_LIBRARY_PATH,可解决找不到当前目录so库的问题
3、64位程序在头文件定义加上 #pragma pack(4) 表示结构体以四个字节对齐 ,否则可能会出现一个包含Int类型的结构体 int类型和紧挨的一个类型 间隔8个字节的情况
显式调用时不要在MakeFile中加"-l库名称",直接dlopen 然后获取函数地址调用即可。
隐式链接时需要包含头文件加上"-l库名称",直接可以调用了。
静态链接时需要包含头文件加上"-l库名称",这时的库应该为.a库。
本文出自 “清澈” 博客,转载请与作者联系!