10.04 g++ linux
2015-01-07 21:57:07 Red_River 阅读数 325
http://www.cppblog.com/singohgod/archive/2011/05/08/145950.html
2018-12-15 19:16:53 arthas_zy 阅读数 45

上文(g++基本用法)介绍简单的g++编译器的用法,只是针对没有依赖关系的单个文件的操作,当我们有多个文件需要编译的时候,是如何工作的呢?下面以简单的实例进行介绍,然后把实例以MakeFile文件实现,并对MakeFile文件进行简单介绍。

准备工作,下面是需要的简单实例文件及代码:

main.cxx

Administrator@72cec870236147e /home/liujl/mytest
$ cat main.cxx
#include
#include “printf1.hxx”
#include “printf2.hxx”
Administrator@72cec870236147e /home/liujl/mytest
$ g++ -c main.cxx

Administrator@72cec870236147e /home/liujl/mytest
$ g++ -c printf1.cxx

Administrator@72cec870236147e /home/liujl/mytest
$ g++ -c printf2.cxx

int main(){ printf1(); printf2();}
printf1.hxx
Administrator@72cec870236147e /home/liujl/mytest
$ cat printf1.hxx
#ifndef PRINTF_1_H
#define PRINTF_1_H

void printf1();

#endif
printf1.cxx
Administrator@72cec870236147e /home/liujl/mytest
$ cat printf1.cxx
#include “printf1.hxx”
#include

using namespace std;

void printf1()
{
cout<<“printf1”<<endl;
}
printf2.hxx
Administrator@72cec870236147e /home/liujl/mytest
$ cat printf2.hxx
#ifndef PRINTF_2_H
#define PRINTF_2_H

void printf2();

#endif
printf2.cxx
Administrator@72cec870236147e /home/liujl/mytest
$ cat printf2.cxx
#include “printf2.hxx”
#include

using namespace std;

void printf2()
{
cout<<“printf2”<<endl;
}
共计5个文件,3个cxx文件,2个hxx头文件
1、手动多文件编译

①先分别直接汇编(编译)为.o文件

Administrator@72cec870236147e /home/liujl/mytest
$ g++ -c main.cxx

Administrator@72cec870236147e /home/liujl/mytest
$ g++ -c printf1.cxx

Administrator@72cec870236147e /home/liujl/mytest
$ g++ -c printf2.cxx
②链接阶段

如果直接执行

Administrator@72cec870236147e /home/liujl/mytest
$ g++ main.cxx -o main
/tmp/cc9LFDvP.o:main.cxx:(.text+0xc): undefined reference to printf1()' /tmp/cc9LFDvP.o:main.cxx:(.text+0x11): undefined reference toprintf2()’
collect2: ld 返回 1
出现上边错误,原因是编译器找不到printf1()和printf2()的定义。
所以需要将3个obj文件链接到一个文件上:

Administrator@72cec870236147e /home/liujl/mytest
$ g++ main.cxx printf1.cxx printf2.cxx -o main

Administrator@72cec870236147e /home/liujl/mytest
$ ./main
printf1
printf2
并输出结果。
这样就能解决多文件编译问题,但是一般情况下,一个项目下的文件比较多,如果这样输入,比较费劲,所以就需要把编译过程写进一个MakeFile文件中

Administrator@72cec870236147e /home/liujl/mytest
$ cat makefile
cc=g++
exe=main
obj=main.o printf1.o printf2.o

(exe):(exe):(obj)
$(cc) -o $(exe) $(obj)
main.o:main.cxx
$(cc) -c main.cxx
printf1.o:printf1.cxx
$(cc) -c printf1.cxx
printf2.o:printf2.cxx
(cc)cprintf2.cxxclean:rmrf.omaincc=g++exe=mainobj=main.oprintf1.oprintf2.o(cc) -c printf2.cxx clean: rm -rf *.o main 其中 cc=g++ exe=main obj=main.o printf1.o printf2.o 为变量的定义,(…)作为引用,可以分析一下,是不是和上文中单个操作效果一样?
执行过程:

Administrator@72cec870236147e /home/liujl/mytest
$ make
g++ -c main.cxx
g++ -c printf1.cxx
g++ -c printf2.cxx
g++ -o main main.o printf1.o printf2.o

作者:richerg85
来源:CSDN
原文:https://blog.csdn.net/richerg85/article/details/17074193
版权声明:本文为博主原创文章,转载请附上博文链接!

2018-10-18 21:24:26 qq_35608277 阅读数 51
c++ 后缀 类型
.a 静态库 (archive)
.c .cc .cp .cpp .cxx C++源代码(需要编译预处理
.h C或者C++源代码头文件
.ii C++源代码(不需编译预处理)
.o 对象文件
.s 汇编代码
.so 动态库
< none> 标准C++系统头文件

g++是GNU开发的C++编译器,是GCC(GNU Compiler Collection)GNU编译器套件的组成部分(gcc是GNU的C编译器)。

即gcc 默认语言设为 C++ 的一个特殊的版本。

在执行编译的时候一般有下面4步:
⒈预处理,生成.i的文件[预处理器cpp]。
⒉将预处理后的文件转换成汇编语言,生成文件.s[编译器egcs]。
⒊由汇编变为目标代码(机器代码)文件.o[汇编器as]。
⒋连接目标代码,生成可执行程序[链接器ld]。

单个源文件生成可执行程序
命令行中未指定可执行程序的文件名,编译器采用默认的 a.out。

g++ helloworld.cpp

指定可执行程序的文件名

g++ helloworld.cpp -o helloworld

多个源文件生成可执行程序

g++ main.cpp speak.cpp -o main 

不用写头文件.h 因为在speak.cpp中有#include .h

格式

gcc [-c|-S|-E] [-std=standard]
           [-g] [-pg] [-Olevel]
           [-Wwarn...] [-Wpedantic]
           [-Idir...] [-Ldir...]
           [-Dmacro[=defn]...] [-Umacro]
           [-foption...] [-mmachine-option...]
           [-o outfile] [@file] infile...

1 总体选项

-E 只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里面。
例子用法: gcc -E hello.c > pianoapan.txt gcc -E hello.c | more 
慢慢看吧,一句`hello world`也要预处理成800行的代码。 

-S 只激活预处理和编译,就是指把文件编译成为汇编代码。
例子用法: gcc -S hello.c 将生成.s的汇编代码,可以用文本编辑器查看。 

-c 只激活预处理,编译,和汇编,也就是他只把程序做成obj文件。
例子用法: gcc -c hello.c 将生成.o的目标文件(object file)。 

-o 指定目标名称,缺省的时候,gcc/g++编译出来的文件是a.out。例子如下: g++ -o hello.out hello.cpp g++ -o hello.asm -S hello.cpp 

2 目录选项

-I[dir]
在你是用#include "file"的时候,gcc/g++会先在当前目录查找你所指定的头文件,
如果没有找到,会到系统默认的头文件目录找。如果使用-I指定了目录,编译器会先在指定的目录查找,
然后再去系统默认头文件目录查找。
对于#include <file>,gcc/g++会到-I指定的目录查找,查找不到,然后再到系统默认的头文件目录查找。 
-include [file]
相当于“#include”,用于包含某个代码,简单来说,就是编译某个文件,需要另一个文件的时候,就可以 用它设定,功能就相当于在代码中使用#include。
例子用法: gcc hello.c -include /root/pianopan.h -I-
就是取消前一个参数的功能,所以一般在-Idir之后使用 
-idirafter [dir]   
在-I的目录里面查找失败,将到目录dir里面查找。 
-iprefix [prefix],-iwithprefix [dir]
一般一起使用,当-I的目录查找失败,会到prefix+dir下查找。 
-L[dir]   
编译的时候,指定搜索库的路径。比如你自己的库,可以用它指定目录,不然编译器将只在标准库的 目录找。这个dir就是目录的名称。 
-l[library]    
指定编译的时使用的库,例子用法 gcc -lcurses hello.c 使用curses库编译连接,生成程序。 

3. 预处理选项

-Dmacro
相当于C语言中的#define macro。
 -Dmacro=defn   
相当于C语言中的#define macro=defn。 
-Umacro
相当于C语言中的#undef macro。
 -undef
取消对任何非标准宏的定义。

4.连接方式选项

-static
此选项将禁止使用动态库。优点:程序运行不依赖于其他库。缺点:可执行文件比较大。
 -shared
此选项将尽量使用动态库,为默认选项。优点:生成文件比较小。缺点:运行时需要系统提供动态库。 -symbolic
建立共享目标文件的时候,把引用绑定到全局符号上。对所有无法解析的引用作出警告(除非用连接选项, '-Xlinker -z -Xlinker defs'取代)。注:只有部分系统支持该选项。 
-Wl,-Bstatic
告诉链接器ld只链接静态库,如果只存在动态链接库,则链接器报错。 
-Wl,-Bdynamic
告诉链接器ld优先使用动态链接库,如果只存在静态链接库,则使用静态链接库。

5.其他选项

-fpic 编译器就生成位置无关目标码.适用于共享库(shared library). -fPIC 编译器就输出位置无关目标码.适用于动态连接(dynamic linking),即使分支需要大范围转移。 -v 显示详细的编译、汇编、连接命令 -pipe 使用管道代替编译过程中的临时文件,在使用非gnu汇编工具的时候,可能有些问题 g++ -pipe -o hello.out hello.cpp -ansi 关闭gnu c中与ansi c不兼容的特性,激活ansi c的专有特性(包括禁止一些asm inline typeof关键字,以及 UNIX,vax等预处理宏。 -fno-asm 此选项实现ansi选项功能的一部分,它禁止将asm,inline和typeof用作关键字。 -fno-strict-prototype 只对g++起作用,使用这个选项,g++将对不带参数的函数,都认为是没有显式的对参数的个数和类型说明,而不是没有 参数.而gcc无论是否使用这个参数,都将对没有带参数的函数,认为没有显式说明的类型。 -fthis-is-varialble 就是向传统c++看齐,可以使用this当一般变量使用。 -fcond-mismatch 允许条件表达式的第二和第三参数类型不匹配,表达式的值将为void类型。 -funsigned-char -fno-signed-char -fsigned-char -fno-unsigned-char 这四个参数是对char类型进行设置,决定将char类型设置成unsigned char(前两个参数)或者signed char(后 两个参数)。 -imacros file 将file文件的宏,扩展到gcc/g++的输入文件,宏定义本身并不出现在输入文件中 -nostdinc 使编译器不在系统缺省的头文件目录里面找头文件,一般和-I联合使用,明确限定头文件的位置。 -nostdin C++ 规定不在g++指定的标准路经中搜索,但仍在其他路径中搜索,此选项在创建libg++库使用。 -C 在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很方便的。 -m 生成与具体CPU相关的程序。 -mtune=cpu-type 为指定类型的CPU生成代码。cpu-type 可以是:i386,i486,i586,pentium,i686,pentium4 等等。 -m32 -m64 生成32bits程序或64bits程序 -mmmx -msse -msse2 -mno-mmx -mno-sse -mno-sse2 使用或者不使用MMX,SSE,SSE2指令。 -M 生成文件依赖的信息,包含目标文件所依赖的所有源文件。你可以用gcc -M hello.c来测试一下,很简单。 -MM 和上面的那个一样,但是它将忽略由#include造成的依赖关系。 -MD 和-M相同,但是输出将导入到.d的文件里面。 -MMD 和-MM相同,但是输出将导入到.d的文件里面。 -Wa,option 此选项传递option给汇编程序;如果option中间有逗号,就将option分成多个选项,然后传递给会汇编程序。 -Wl.option 此选项传递option给连接程序;如果option中间有逗号,就将option分成多个选项,然后传递给会连接程序。 -x language filename 设定文件所使用的语言,使后缀名无效,对以后的多个有效.也就是根据约定C语言的后缀名称是.c的,而C++的后缀 名是.C或者.cpp。如果你很个性,决定你的C代码文件的后缀名是.pig,那你就要用这个参数,这个参数对他后面 的文件名都起作用,除非到了下一个参数的使用。可以使用的参数有下面的这些: c,objective-c,c-header,c++,cpp-output,assembler,assembler-with-cpp。 看到英文,应该可以理解的。例子用法: gcc -x c hello.pig -x none filename 关掉上一个选项,也就是让gcc根据文件名后缀,自动识别文件类型,例子用法: gcc -x c hello.pig -x none hello2.c

2016-05-16 19:46:00 weixin_34413103 阅读数 0

yum install gcc-c++  

转载于:https://www.cnblogs.com/oh-mine/p/5499257.html

2015-02-10 19:36:00 weixin_33962621 阅读数 1

g++ 它的全名不叫g++而是叫gcc-c++;

所以要安装它就可以用 yum install gcc-c++;

转载于:https://www.cnblogs.com/JiangLe/p/4284746.html

Linux g++的安装

阅读数 220

Linux 安装g++

阅读数 17

linux g++ 动态库

阅读数 866

linux gcc 和 g++ 编译

阅读数 219

没有更多推荐了,返回首页