%暖兴 计算,改变您的现在 DAWNING 一个简单的例子一hello.c ·用vi编写源文件: #include void main() printf("hello world.\n"); } ·用gcc编译 gcc hello.c ·运行 a.out 3/17
3/17 一个简单的例子—hello.c • 用vi编写源文件: #include void main() { printf(“hello world.\n”); } • 用gcc编译 gcc hello.c • 运行 a.out
%曙光 计算,改变您的现在 GCC简介(1/2) ● gcc(GNW,Compliler Collection)是GNU推出的功能 强大、性能优越的多平台编译器,是GU的代表作品之 0 gcc编译器能将C、,Fortran,C+语言源程序、汇程式化 序和自标程序编译、连接成可执行文件,如果没有给 可执行文件的名字,gcc将生成一个名为a.out的文 件 gcc最基本的用法是: gcc [options][filenames] 其中options.就是编译器所需要的参数,filenames给出相关的文 件名称 4/17
4/17 GCC简介(1/2) • gcc(GNU Compliler Collection)是GNU推出的功能 强大、性能优越的多平台编译器,是GNU的代表作品之 一。 • gcc编译器能将C、Fortran,C++语言源程序、汇程式化 序和目标程序编译、连接成可执行文件,如果没有给 出可执行文件的名字,gcc将生成一个名为a.out的文 件。 • gcc最基本的用法是∶ gcc [options] [filenames] 其中options就是编译器所需要的参数,filenames给出相关的文 件名称
曙光 计算,改变您的现在 DAWNING GCC简介(2/2) ·在Linux.系统中,可执行文件没有统一的后缀,系统从 文件的属性来区分可执行文件和不可执行文件。 ·而gcc则通过后缀来区别输入文件的类别 -·c为后缀的文件,C语言源代码文件 -.f为后缀的文件,Fortran77语言源代码文件 -.f90为后缀的文件,Fortran90语言源代码文件 -.C,·cc或.cxx为后缀的文件,是C++源代码文件 -·h为后缀的文件,是程序所包含的头文件 一·o为后缀的文件,是编译后的目标文件,也是静态库文件 ··so为后缀的文件,动态库文件 -.a为后缀的文件,是由目标文件构成的档案库文件 5/17
5/17 GCC简介(2/2) • 在Linux系统中,可执行文件没有统一的后缀,系统从 文件的属性来区分可执行文件和不可执行文件。 • 而gcc则通过后缀来区别输入文件的类别 –.c为后缀的文件,C语言源代码文件 –.f为后缀的文件,Fortran77语言源代码文件 –.f90为后缀的文件,Fortran90语言源代码文件 –.C,.cc或.cxx 为后缀的文件,是C++源代码文件 –.h为后缀的文件,是程序所包含的头文件 –.o为后缀的文件,是编译后的目标文件,也是静态库文件 –.so为后缀的文件,动态库文件 –.a为后缀的文件,是由目标文件构成的档案库文件
%曙光 计算,改变您的现在 GCC常用编译参数(1/3) -℃:只编译,不连接成为可执行文件, 编译器只是由输入的.c等 源代码文件生成.0为后缀的目标文件,通常用于编译不包含主程 序的子程序文件。 ● -o output filename:确定输出文件的名称为output filename, 同时这个名称不能和源文件同名。如果不给出这个选项,gcC就给 出预设的可执行文件a.out。 -g:产生符号调试工具(GNU的gdb)所必要的符号资讯,要使用gdb 对源代码进行调试,我们就必须加入这个选项。 ·-0:对程序进行优化编译、连接,采用这个选项,整个源代码会 在编译、连接过程中进行优化处理,这样产生的可执行文件的执 行效率可以提高,但是,编译、连接的速度就相应地要慢一些。 -02:比-0更好的优化编译、连接,当然整个编译、连接过程会更 慢。 6/17
6/17 GCC常用编译参数(1/3) • -c:只编译,不连接成为可执行文件,编译器只是由输入的.c等 源代码文件生成.o为后缀的目标文件,通常用于编译不包含主程 序的子程序文件。 • -o output_filename:确定输出文件的名称为output_filename, 同时这个名称不能和源文件同名。如果不给出这个选项,gcc就给 出预设的可执行文件a.out。 • -g:产生符号调试工具(GNU的gdb)所必要的符号资讯,要使用gdb 对源代码进行调试,我们就必须加入这个选项。 • -O:对程序进行优化编译、连接,采用这个选项,整个源代码会 在编译、连接过程中进行优化处理,这样产生的可执行文件的执 行效率可以提高,但是,编译、连接的速度就相应地要慢一些。 • -O2:比-O更好的优化编译、连接,当然整个编译、连接过程会更 慢
多暖光 计算,改变您的现在 GCC常用编译参数(23) -Idirname:将dirname所指出的目录加入到程序头文件目录列表 中,是在预编译过程中使用的参数。C程序中的头文件包含两种情 况: A)#include B)#include "myinc.h” 其中,A类使用尖括号(<>),B类使用双引号()。对于A类, 预处理程序cpp在系统预设包含文件目录(如/usr/include)中搜寻 相应的文件,而对于B类,cpp在当前目录中搜寻头文件,这个选 项的作用是告诉Cpp,如果在当前目录中没有找到需要的文件,就 到指定的dirname目录中去寻找。在程序设计中,如果我们需要的 这种包含文件分别分布在不同的目录中,就需要逐个使用-I选项 给出搜索路径。 717
7/17 GCC常用编译参数(2/3) • -Idirname:将dirname所指出的目录加入到程序头文件目录列表 中,是在预编译过程中使用的参数。C程序中的头文件包含两种情 况: A)#include B)#include “myinc.h” 其中,A类使用尖括号(),B类使用双引号(“ ”)。对于A类, 预处理程序cpp在系统预设包含文件目录(如/usr/include)中搜寻 相应的文件,而对于B类,cpp在当前目录中搜寻头文件,这个选 项的作用是告诉cpp,如果在当前目录中没有找到需要的文件,就 到指定的dirname目录中去寻找。在程序设计中,如果我们需要的 这种包含文件分别分布在不同的目录中,就需要逐个使用-I选项 给出搜索路径
暖光 计算,改变您的现在 GCC常用编译参数(33) ·-Ldirname:将dirname所指出的目录加入到程序函数档案库文件 的目录列表中,是在连接过程中使用的参数。在预设状态下,连 接程序1d在系统的预设路径中(如/usr/1ib)寻找所需要的档案库 文件,这个选项告诉连接程序,首先到一L指定的目录中去寻找, 然后到系统预设路径中寻找,如果函数库存放在多个目录下,就 需要依次使用这个选项,给出相应的存放目录。 ·-lname:在连接时,装载名字为“1 ibname..a”的函数库,该函数 库位于系统预设的目录或者由-L选项确定的目录下。例如,-1m表 示连接名为“1ibm.a”的数学函数库。 上面我们简要介绍了gCc编译器最常用的功能和主要参数选项,更 为详尽的资料可以参看Linux.系统的联机帮助。 8/17
8/17 GCC常用编译参数(3/3) • -Ldirname:将dirname所指出的目录加入到程序函数档案库文件 的目录列表中,是在连接过程中使用的参数。在预设状态下,连 接程序ld在系统的预设路径中(如/usr/lib)寻找所需要的档案库 文件,这个选项告诉连接程序,首先到-L指定的目录中去寻找, 然后到系统预设路径中寻找,如果函数库存放在多个目录下,就 需要依次使用这个选项,给出相应的存放目录。 • -lname:在连接时,装载名字为“libname.a”的函数库,该函数 库位于系统预设的目录或者由-L选项确定的目录下。例如,-lm表 示连接名为“libm.a”的数学函数库。 上面我们简要介绍了gcc编译器最常用的功能和主要参数选项,更 为详尽的资料可以参看Linux系统的联机帮助
暖光 计算,改变您的现在 DAWNING GCC应用举例 1.gcc hello.c 生成a.out 2.gcc -o hello hello.c 生成hello 3.gcc -0-o hello hello.c 生成hello 4.gcc-02 -o hello hello.c 生成hello 5.gcc -c hello.c 生成he1lo.o gcc -o hellohello.o 生成hello 6.gcc -c hello1.c 生成he1lo1.o gcc -c hello2.c 生成he11o2.o gcc-ohel1 o hello1.ohel1o2.o生成hello 7.gcc-o test test.o-1m-I/home/czn/include 9117
9/17 GCC应用举例 1. gcc hello.c 生成a.out 2. gcc –o hello hello.c 生成hello 3. gcc –O –o hello hello.c 生成hello 4. gcc –O2 –o hello hello.c 生成hello 5. gcc –c hello.c 生成hello.o gcc –o hello hello.o 生成hello 6. gcc –c hello1.c 生成hello1.o gcc –c hello2.c 生成hello2.o gcc –o hello hello1.o hello2.o 生成hello 7. gcc –o test test.o –lm –I/home/czn/include
曙光 计算,改变您的现在 Make简介 在开发大系统时,经常要将程序划分为许多模块。各 个模块之间存在着各种各样的依赖关系,在Linux中通 常使用Makefile来管理。 - 由于各个模块间不可避鞔存在关联,所以当一个模块改动后, 其他模块也许会有所更新,当然对小系统来说,手工编译连 接是没问题,但是如果是一个大系统,存在很多个模块,那 么手工编译的方法就不适用了。 为此,在Linux系统中,专门提供了一个make命令来自动维护 目标文件。 与手工编译和连接相比,make命令的优点在于他只更新修改 过的文件,而对没修改的文件则置之不理,并且make命令不 会漏掉一个需要更新的文件。 10/17
10/17 Make简介 • 在开发大系统时,经常要将程序划分为许多模块。各 个模块之间存在着各种各样的依赖关系,在Linux中通 常使用 Makefile来管理。 –由于各个模块间不可避免存在关联,所以当一个模块改动后, 其他模块也许会有所更新,当然对小系统来说,手工编译连 接是没问题,但是如果是一个大系统,存在很多个模块,那 么手工编译的方法就不适用了。 –为此,在Linux系统中,专门提供了一个make命令来自动维护 目标文件。 –与手工编译和连接相比,make命令的优点在于他只更新修改 过的文件,而对没修改的文件则置之不理,并且make命令不 会漏掉一个需要更新的文件
曙光 计算,改变您的现在 DAWNING 一个简单的例子 ·先举一个例子:a.cb.c两个程序 a.c b.c extern void p(char *) main O void p(char *str) p("hello world"); printf("%sn",str); ·Makefile hello:a.c b.c gcca.cb.c-o hello←注意这里是一个Tab ·执行make gcc a.c b.c -o hello 产生一个叫nello的可执行程序 11/17
11/17 一个简单的例子 • 先举一个例子: a.c b.c两个程序 a.c extern void p(char *); main() { p("hello world"); } b.c void p(char *str) { printf("%sn",str); } • Makefile hello: a.c b.c gcc a.c b.c -o hello 注意这里是一个Tab • 执行make gcc a.c b.c -o hello 产生一个叫hello的可执行程序