gcc 链接选项-static -static-libstdc++ -static-libgcc使用分析

本文讨论了在使用g++编译C++程序时,如何选择不同的链接选项(-static,-static-libstdc++,-static-libgcc)以实现静态链接,以及这些选项对程序移植性和依赖关系的影响。特别强调了-static选项的全静态编译特性。
摘要由CSDN通过智能技术生成

https://www.jianshu.com/p/c2adeb4f672c

当我们使用g++编译c++程序时,一般都会动态链接libstdc++.so共享库,有时候受限于不同机器和不同使用场景,我们希望静态链接libstdc++.so库,这样可能便于移植到相似的机器上,这时候就可以使用-static-xxx选项,将所有的库打包成一个可执行文件。他们之间的主要不同点在于:

-static 会将所以有用到的外部库全部以静态的方式链接
-static-libstdc++ 只将libstdc++.so静态链接
-static-gcc 同-static-libstdc++
 

-static-libstdc++

未使用-static-libstdc++编译,ldd:

使用-static-libstdc++编译,ldd:

-static-libgcc

-static-libgcc必须和-static-libstdc++搭配使用,单独使用-static-libgcc不能完全生效
使用-static-libstdc++,但未使用-static-libgcc编译,ldd:

使用-static-libstdc++ -static-libgcc编译,ldd:

-static

编译纯静态程序,不依赖任何so文件,当然也不能用来编译出so文件

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
费了九牛二虎之力整理的在linux下安装oracle需要的包集合,详细信息如下:i386: compat-libstdc++-33-3.2.3-61.i386 elfutils-libelf-devel-0.137-3.el5.i386 elfutils-libelf-devel-static-0.137-3.el5.i386 gcc-4.1.2-46.el5.i386 gcc-c++-4.1.2-46.el5.i386 glibc-devel-2.5-42.i386 glibc-headers-2.5-42.i386 kernel-headers-2.6.18-164.el5.i386 libaio-0.3.105-2.i386 libaio-devel-0.3.106-3.2.i386 libgcc-3.4.6-3.i386 libgomp-4.4.0-6.el5.i386 libstdc++-3.4.6-11.i386 libstdc++-devel-4.1.2-46.el5.i386 pdksh-5.2.14-1.i386 sysstat-7.0.2-3.el5.i386 unixODBC-2.2.11-7.1.i386 unixODBC-devel-2.2.11-7.1.i386 i686: binutils-devel-2.20.51.0.2-5.36.el6.i686 compat-libstdc++-33-3.2.3-69.el6.i686 elfutils-libelf-devel-0.152-1.el6.i686 glibc-2.12-1.25.el6.i686 glibc-devel-2.12-1.25.el6.i686 libaio-0.3.107-10.el6.i686 libaio-devel-0.3.107-10.el6.i686 libgcc-4.4.5-6.el6.i686 libstdc++-4.4.5-6.el6.i686 libstdc++-4.4.4-13.el6.i686 libstdc++-devel-4.4.4-13.el6.i686 libstdc++-docs-4.4.7-3.el6.i686 unixODBC-2.2.14-12.el6_3.i686 unixODBC-devel-2.2.14-12.el6_3.i686 zlib-1.2.3-29.el6.i686 zlib-devel-1.2.3-29.el6.i686 x86_64: binutils-2.20.51.0.2-5.20.el6.x86_64 binutils-2.20.51.0.2-5.36.el6.x86_64 binutils-devel-2.20.51.0.2-5.36.el6.x86_64 compat-libcap1-1.10-1.x86_64 compat-libstdc++-33-3.2.3-69.el6.x86_64 elfutils-libelf-devel-0.152-1.el6.x86_64 elfutils-libelf-devel-0.163-3.el7.x86_64 gcc-c++-4.4.5-6.el6.x86_64 glibc-2.12-1.25.el6.x86_64 glibc-2.17-105.el7.x86_64 glibc-devel-2.12-1.25.el6.x86_64 ksh-20100621-6.el6.x86_64 libaio-0.3.105-2.x86_64 libaio-0.3.107-10.el6.x86_64 libaio-0.3.109-13.el7.x86_64 libaio-devel-0.3.105-2.x86_64 libaio-devel-0.3.106-5.x86_64 libaio-devel-0.3.107-10.el6.x86_64 libaio-devel-0.3.109-13.el7.x86_64 libgcc-4.4.5-6.el6.x86_64 libgcc-4.8.5-4.el7.x86_64 libstdc++-4.4.5-6.el6.x86_64 libstdc++-4.8.5-4.el7.x86_64 libstdc++-devel-4.4.5-6.el6.x86_64 make-3.81-19.el6.x86_64 pdksh-5.2.14-30.x86_64 pdksh-5.2.14-36.el5.x86_64 sysstat-9.0.4-18.el6.x86_64 unixODBC-2.2.11-7.1.x86_64 unixODBC-2.2.14-12.el6_3.x86_64 unixODBC-2.3.1-11.el7.x86_64 unixODBC-devel-2.2.11-7.1.x86_64 unixODBC-devel-2.2.14-12.el6_3.x86_64 unixODBC-devel-2.3.1-11.el7.x86_64
这是一个针对 Windows 平台的 Makefile 文件,用于编译 Project2 项目。 以下是逐行解释: ```makefile # Project: Project2 ``` 注释,表示这个 Makefile 是为编译 Project2 项目而创建的。 ```makefile CPP = g++.exe CC = gcc.exe WINDRES = windres.exe ``` 定义了三个变量,分别用于指定 C++ 编译器、C 编译器和 Windows 资源编译器。 ```makefile OBJ = main.o visual.o menu.o map.o end.o LINKOBJ = main.o visual.o menu.o map.o end.o ``` 定义了两个变量,分别用于指定编译后生成的目标文件和链接需要的目标文件。 ```makefile LIBS = -L"C:/Program Files (x86)/Dev-Cpp/MinGW32/lib" -L"C:/Program Files (x86)/Dev-Cpp/MinGW32/mingw32/lib" -static-libstdc++ -static-libgcc INCS = -I"C:/Program Files (x86)/Dev-Cpp/MinGW32/include" CXXINCS = -I"C:/Program Files (x86)/Dev-Cpp/MinGW32/include" -I"C:/Program Files (x86)/Dev-Cpp/MinGW32/lib/gcc/mingw32/4.7.2/include/c++" ``` 定义了三个变量,分别用于指定需要链接的库文件、需要包含的头文件路径和 C++ 编译器需要包含的头文件路径。 ```makefile BIN = mimigong.exe ``` 定义了一个变量,用于指定生成的可执行文件名。 ```makefile CXXFLAGS = $(CXXINCS) CFLAGS = $(INCS) ``` 定义了两个变量,分别用于指定 C++ 编译器和 C 编译器的编译选项。 ```makefile RM = rm -f ``` 定义了一个变量,用于指定删除文件的命令。 ```makefile .PHONY: all all-before all-after clean clean-custom ``` 指定了一些伪目标,分别是 all、all-before、all-after、clean 和 clean-custom。 ```makefile all: all-before $(BIN) all-after ``` 定义了 all 目标,表示执行 all-before、$(BIN) 和 all-after 三个目标。 ```makefile clean: clean-custom ${RM} $(OBJ) $(BIN) ``` 定义了 clean 目标,表示执行 clean-custom 目标,然后删除生成的目标文件和可执行文件。 ```makefile $(BIN): $(OBJ) $(CPP) $(LINKOBJ) -o $(BIN) $(LIBS) ``` 定义了 $(BIN) 目标,表示需要通过链接 $(OBJ) 目标生成 $(BIN) 可执行文件。 ```makefile main.o: main.c $(CPP) -c main.c -o main.o $(CXXFLAGS) visual.o: visual.c $(CPP) -c visual.c -o visual.o $(CXXFLAGS) menu.o: menu.c $(CPP) -c menu.c -o menu.o $(CXXFLAGS) map.o: map.c $(CPP) -c map.c -o map.o $(CXXFLAGS) end.o: end.c $(CPP) -c end.c -o end.o $(CXXFLAGS) ``` 分别定义了 main.o、visual.o、menu.o、map.o、end.o 五个目标,用于编译对应的源代码文件,并将编译后生成的目标文件保存在当前目录下。其中,-c 选项表示只编译,不链接
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值