linux下GCC编译器
来源:互联网 发布:java web用户登录注册 编辑:程序博客网 时间:2024/05/22 00:07
linux下编译源文件makefile文件的简单总结:
Linux系统下的gcc(GNU CCompiler)是GNU推出的功能强大、性能优越的多平台编译器,
是GNU的代表作之一。gcc可以在多种硬体平台上编译出可执行程序,其执行效率与一般的编
译器相比平均效率要高20%~30%。
GCC编译器能将C、C++语言源程序、汇编程序编译、链接成可执行文件。
在Linux系统中,可执行文件没有统一的后缀,系统从文件的属性来区分可执行
文件和不可执行文件。
使用GCC编译程序时,编译过程可以被细分为四个阶段:
v预处理(Pre-Processing) // 此阶段主要是在库中找到所需要的头文件,包含到文件中来;
v编译(Compiling), //检查文件中的语法,语句的错误;
v汇编(Assembling), //翻译成机器语言;
v链接(Linking),
Gcc通过后缀来区别输入文件的类别:
v .c为后缀的文件: C语言源代码文件
v .a为后缀的文件: 是由目标文件构成的库文件
v .C,.cc或.cxx 为后缀的文件:是C++源代码文件
v .h为后缀的文件: 头文件
v .i 为后缀的文件: 是已经预处理过的C源代码文件
v .ii为后缀的文件: 是已经预处理过的C++源代码文件
v .o为后缀的文件: 是编译后的目标文件
v .s为后缀的文件: 是汇编语言源代码文件
v .S为后缀的文件: 是经过预编译的汇编语言源代码文件。
gcc最基本的用法是∶
gcc [options] [filenames]
options:编译器所需要的编译选项
filenames: 要编译的文件名
-c多该程序制作编译,不做链接;
-I指定include file的查找目录;
-L指定library file的查找目录;
-Wall编译文件时发出所有的警告信息;
-c:只编译,不连接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件。
-Wall:生成所有警告信息
-w:不生成任何警告信息
-DMACRO: 定义 MACRO 宏,等效于在程序中使用#define MACRO
-g:产生调试工具(GNU的gdb)所必要的符号信息,要想对编译出的程序进行调试,就必须加入这个选项。
例如:
hello.c:
#include <stdio.h>
int main(void)
{
printf (Hello world!\n);
return 0;
}
编译和运行这段程序:
# gcc hello.c -o hello
# ./hello
输出:Hello world!
1.如果是简单的*.C文件,
(1)命令:gcc -o run file.c 或者 gcc file.c -o run
如果编译通过,此时运行./run就能执行该文件了;
(2)命令:gcc -o file.c
如果编译通过,运行a.out就能执行该文件了;
-o指定输出的文件名,如果没有指定文件名,默认的执行命令是a.out;
-O,对程序进行优化编译、链接,采用这个选
项,整个源代码会在编译、连接过程中进行优
化处理,这样产生的可执行文件的执行效率可
以提高,但是,编译、连接的速度就相应地要
慢一些。
-O2,比-O更好的优化编译、连接,当然整个
编译、连接过程会更慢。
编译命令:
以file.c为例:
1. gcc file.c -o runfile //优化代码;
./runfile
2. gcc –O file.c -o runfile //对文件更好的进行优化;编译的慢但是效率高;
./runfile
-Idirname: 将dirname所指出的目录加入到程序头文件目录列表
中。
C程序中的头文件包含两种情况∶
v #include <A.h>
v #include “B.h”
对于<>,预处理程序cpp在系统预设的头文件目录(如/usr/include)中搜寻相应的文件;
而对于””,cpp在当前目录中搜寻头文件。这个选项的作用是告诉cpp,如果在当前目录中没有找到需要的文件,就到指定的dirname目录中去寻找。
例:gcc foo.c -I /home/include -o foo //先在当前目录下查找,如果没有就到库里去查找;
-Ldirname:将dirname所指出的目录加入到库文件的目录列表中。在默认状态下,连接
程序ld在系统的预设路径中(如/usr/lib)寻找所需要的库文件,这个选项告诉连接程序,首
先到-L指定的目录中去寻找,然后再到系统预设路径中寻找。
-lname:在连接时,装载名字为
“libname.a”的函数库,该函数库位于
系统预设的目录或者由-L选项确定的目
录下。例如,-lm表示连接名为
“libm.a”的数学函数库。
例:gcc foo.c -L /home/lib -lfoo -o foo
-static:静态链接库文件
例:gcc –static hello.c -o hello
库有动态与静态两种,动态通常用.so为后缀,静态用.a为后缀。
例如:libhello.so libhello.a。当使用静态库时,连接器找出程序所需的函数,然后将它们拷贝到可执行文件,一旦连
接成功,静态程序库也就不再需要了。然 而,对动态库而言,就不是这样,动态库会在执行程序内留下一个标记‘指明当程序
执行时,首先必须载入这个库。由于动态库节省空间,linux下进行连接的 缺省操作是首先连接动态库。
演示:静态链接与动态链接可执行文件大小比较
各
Linux系统下的gcc(GNU CCompiler)是GNU推出的功能强大、性能优越的多平台编译器,
是GNU的代表作之一。gcc可以在多种硬体平台上编译出可执行程序,其执行效率与一般的编
译器相比平均效率要高20%~30%。
GCC编译器能将C、C++语言源程序、汇编程序编译、链接成可执行文件。
在Linux系统中,可执行文件没有统一的后缀,系统从文件的属性来区分可执行
文件和不可执行文件。
使用GCC编译程序时,编译过程可以被细分为四个阶段:
v预处理(Pre-Processing) // 此阶段主要是在库中找到所需要的头文件,包含到文件中来;
v编译(Compiling), //检查文件中的语法,语句的错误;
v汇编(Assembling), //翻译成机器语言;
v链接(Linking),
Gcc通过后缀来区别输入文件的类别:
v .c为后缀的文件: C语言源代码文件
v .a为后缀的文件: 是由目标文件构成的库文件
v .C,.cc或.cxx 为后缀的文件:是C++源代码文件
v .h为后缀的文件: 头文件
v .i 为后缀的文件: 是已经预处理过的C源代码文件
v .ii为后缀的文件: 是已经预处理过的C++源代码文件
v .o为后缀的文件: 是编译后的目标文件
v .s为后缀的文件: 是汇编语言源代码文件
v .S为后缀的文件: 是经过预编译的汇编语言源代码文件。
gcc最基本的用法是∶
gcc [options] [filenames]
options:编译器所需要的编译选项
filenames: 要编译的文件名
-c多该程序制作编译,不做链接;
-I指定include file的查找目录;
-L指定library file的查找目录;
-Wall编译文件时发出所有的警告信息;
-c:只编译,不连接成为可执行文件,编译器只是由输入的.c等源代码文件生成.o为后缀的目标文件。
-Wall:生成所有警告信息
-w:不生成任何警告信息
-DMACRO: 定义 MACRO 宏,等效于在程序中使用#define MACRO
-g:产生调试工具(GNU的gdb)所必要的符号信息,要想对编译出的程序进行调试,就必须加入这个选项。
例如:
hello.c:
#include <stdio.h>
int main(void)
{
printf (Hello world!\n);
return 0;
}
编译和运行这段程序:
# gcc hello.c -o hello
# ./hello
输出:Hello world!
1.如果是简单的*.C文件,
(1)命令:gcc -o run file.c 或者 gcc file.c -o run
如果编译通过,此时运行./run就能执行该文件了;
(2)命令:gcc -o file.c
如果编译通过,运行a.out就能执行该文件了;
-o指定输出的文件名,如果没有指定文件名,默认的执行命令是a.out;
-O,对程序进行优化编译、链接,采用这个选
项,整个源代码会在编译、连接过程中进行优
化处理,这样产生的可执行文件的执行效率可
以提高,但是,编译、连接的速度就相应地要
慢一些。
-O2,比-O更好的优化编译、连接,当然整个
编译、连接过程会更慢。
编译命令:
以file.c为例:
1. gcc file.c -o runfile //优化代码;
./runfile
2. gcc –O file.c -o runfile //对文件更好的进行优化;编译的慢但是效率高;
./runfile
-Idirname: 将dirname所指出的目录加入到程序头文件目录列表
中。
C程序中的头文件包含两种情况∶
v #include <A.h>
v #include “B.h”
对于<>,预处理程序cpp在系统预设的头文件目录(如/usr/include)中搜寻相应的文件;
而对于””,cpp在当前目录中搜寻头文件。这个选项的作用是告诉cpp,如果在当前目录中没有找到需要的文件,就到指定的dirname目录中去寻找。
例:gcc foo.c -I /home/include -o foo //先在当前目录下查找,如果没有就到库里去查找;
-Ldirname:将dirname所指出的目录加入到库文件的目录列表中。在默认状态下,连接
程序ld在系统的预设路径中(如/usr/lib)寻找所需要的库文件,这个选项告诉连接程序,首
先到-L指定的目录中去寻找,然后再到系统预设路径中寻找。
-lname:在连接时,装载名字为
“libname.a”的函数库,该函数库位于
系统预设的目录或者由-L选项确定的目
录下。例如,-lm表示连接名为
“libm.a”的数学函数库。
例:gcc foo.c -L /home/lib -lfoo -o foo
-static:静态链接库文件
例:gcc –static hello.c -o hello
库有动态与静态两种,动态通常用.so为后缀,静态用.a为后缀。
例如:libhello.so libhello.a。当使用静态库时,连接器找出程序所需的函数,然后将它们拷贝到可执行文件,一旦连
接成功,静态程序库也就不再需要了。然 而,对动态库而言,就不是这样,动态库会在执行程序内留下一个标记‘指明当程序
执行时,首先必须载入这个库。由于动态库节省空间,linux下进行连接的 缺省操作是首先连接动态库。
演示:静态链接与动态链接可执行文件大小比较
各
- linux下GCC编译器
- linux下安装gcc编译器
- LINUX下C++编译器GCC
- 【Linux】linux下gcc编译器的使用
- linux下gcc编译器的使用
- Linux 下的 gcc, g++ 编译器
- LINUX下的C++编译器GCC简介
- linux下gcc相用编译器选项
- LINUX下的C++编译器GCC简介
- LINUX下的C++编译器GCC简介
- LINUX下的C++编译器GCC简介
- LINUX下的C++编译器GCC简介
- Linux下gcc编译器常用选项一览表
- linux下编译器gcc/g++编译步骤
- LINUX下的C++编译器GCC简介
- Linux环境下GNU, GCC, G++编译器
- Linux下的GCC编译器工具集成
- linux下编译器gcc/g++编译步骤
- Spring动态代理实现
- iOS: CGContext的函数CGContextClipToMask
- c语言连接两个字符串
- 精简高效CSS系列之二——浮动float
- 2013 - ECJTU 暑期训练赛第六场-problem-I
- linux下GCC编译器
- uva 10305 Ordering Tasks(拓扑排序)
- hdu 3711
- 7月份的学习汇报
- 几个简单的排序算法(java版)
- 图的匹配问题与最大流问题(五)——计算二分图的最大匹配
- JS创建对象的几种方法
- Python中的*args和**kwargs
- SQL SERVER 插入大批量数据有无索引的效率对比