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库。