gcc编译和linux下proc编译的总结

来源:互联网 发布:南箫制作数据 编辑:程序博客网 时间:2024/05/04 06:44

在linux下编译.pc文件(即应用了oracle的嵌入式数据库开发语言)过程有两步:
首先经过proc预处理把.pc文件编译 成.c文件:
proc test.pc
这期间如果报错那么就是一些库文件和头文件没有包含进去。proc 常用参数选项说明:
(1)code:指出预编译处理所生成的c函数 的格式当code= ANSI_C时,生成符合ANSI_C标准的函数原型参数:
extern sqlca(log*,void *);
当 code=KR_C时生成如下格式的函数原型参数:
extern sqlca(/*_log*,void *_*/);
语 法:code=ANSI_C|KR_C缺省值为KR_C。注:能在命令行里或程序上输入。
(2)DBMS:指定所用oracle数据库管理系统的 版本。
语法:DBMS=NATIVE|v6|v7
缺省值:NATIVE。注:只能在命令行上输入。
(3)ERRORS:
指出编译程序时产生的错误信息是否发送到终端和清单文件。
语法:ERRORS=YES|NO,为YES时 发送到终端和清单文件,为NO 时只发送到清单文件。
默认:YES。
注:能在程序和命令行上输入。
(4)INCLUDE:指定 EXEC SQL INCLUDE 文件的目录路径,只适用于使用目录的操作系统。
语法:INCLUDE =PATH
(5)MODE:指 定程序遵循的标准
语法:
MODE=ORACLE|ISO|ANSI.....还有其他标准。
(6)ONAME:指定输出文件:
语 法:
ONAME=PATH+FILENAME
(7)LINES:指出预编译处理程序是否对输出文件加#line命令。
(8)INAME: 指定输 入文件:
语法:
ONAME=PATH+FILENAME
预编译完后会产生相应的.c文件,接下来对.c文件进行编译:
这 里使用gcc编译。
gcc编译的选项参数说明:
-c  
只激活预处理,编译,和汇编,也就是他只把程序做成obj文件
例 子用法:
gcc -c hello.c
他将生成.o的obj文件  
-S
只激活预处理和编译,就是指把文件编译 成为汇编代码。
例子用法
gcc -S hello.c
他将生成.s的汇编代码,你可以用文本编辑器察看
-E
只 激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里
面.
例子用法:
gcc -E hello.c > pianoapan.txt
gcc -E hello.c | more
慢慢看吧,一个hello word 也要与处理成800行的代码
-o
制定目标名称,缺省的时候,gcc 编译出来的文件是a.out,很难听,如果
你和我有同 感,改掉它,哈哈
例子用法
gcc -o hello.exe hello.c (哦,windows用习惯了)
gcc -o hello.asm -S hello.c
-ansi
关闭gnu c中与ansi c不兼容的特性,激活ansi c的专有特性(包括禁止一
些asm inline typeof关键字,以及UNIX,vax等预处理宏,
-wall
      显示警告信息
-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(后两个参数)
-include file
包含某个代码,简单来说,就是便以某个文件,需要另一个文件的时候,就可以
用它设定,功能就相 当于在代码中使用#include
例子用法:
gcc hello.c -include /root/pianopan.h
-imacros file
将file文件的宏,扩展到gcc/g++的输入文件,宏定义本身并不出现在输入文件

-Dmacro
相当于C语言中的#define macro
-Dmacro=defn
相当于C语言中的#define macro=defn
-Umacro
相当于C语言中的#undef macro
-undef
取消对任何非标准宏的定义
-Idir
在你是用#include"file"的时候,gcc/g++会先在当前目录查找你所制定的头
文件,如果没有找 到,他回到缺省的头文件目录找,如果使用-I制定了目录,他
回先在你所制定的目录查找,然后再按常规的顺序去找.
对 于#include,gcc/g++会到-I制定的目录查找,查找不到,然后将到系
统的缺省的头文件目录查找
-I-
就是取消前一个参数的功能,所以一般在-Idir之后使用
-idirafter dir
在-I的目录里面查找失败,讲到这个目录里面查找.
-iprefix prefix
-iwithprefix dir
一般一起使用,当-I的目录查找失败,会到 prefix+dir下查找
-nostdinc
使编译器不再系统缺省的头文件目录里面找头文件,一般和-I联合使用,明确
限定头文件的位置
-nostdin C++
规定不在g++指定的标准路经中搜索,但仍在其他路径中搜索,.此选项在创建
libg++库使用
-C
在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很
方便的
-M
生成文件关联的信息。包含目标文件所依赖的所有源代码
你可以用gcc -M hello.c来测试一下,很简单。
-MM
和上面的那个一样,但是它将忽略由#include造成的依赖关系。
-MD
和-M相同,但是输出将导入到.d的文件里面
-MMD
和-MM相同,但是输出将导入到.d的文件里面
-Wa,option
此选项传递option给汇编程序;如果option中间有逗号,就将option分成多个选
项,然 后传递给会汇编程序
-Wl.option
此选项传递option给连接程序;如果option中间有逗号,就将option分成多个选
项,然 后传递给会连接程序.

-llibrary  
制定编译的时候使用的库
例子用法
gcc -lcurses hello.c
使 用ncurses库编译程序
-Ldir
制定编译的时候,搜索库的路径。比如你自己的库,可以用它制定目录,不然
编译器将只在标准库的目录找。这个 dir就是目录的名称。
-O0
-O1
-O2
-O3
编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3 优化级别最
高  
-g
只是编译器,在编译的时候,产生条是信息。
-gstabs
此选项以stabs格式声称调试信息,但是不包括gdb调试信息.
-gstabs+
此选项以stabs格式声称调试信息,并且包含仅供gdb使用的额外调试信息.
-ggdb
此选项将尽可能的生成gdb的可以使用的调试信息.
这期间报错,是一些必要库文件和头文件没有链接上,只要把所需的东西链接上就OK了,下面一个MAKEIFLE文件显示整个编译过程:
#---------------------------------------------
# rules of making *.pc, DON'T change anytime !
.c.o:
    $(CC) $*.c;
    echo    "        $(CC) $*.c/n";
.pc.o:
    $(PROC) iname=$*.pc
    $(CC) $*.c
    @rm     $*.c
    @rm *.lis
    @echo   " "
.SUFFIXES:      .pc .c .o
#---------------------------------------------
OS=Linux
MACRO=TUXEDO
MACRO1=FUN
#PROCFLAGS = unsafe_null= yes dynamic=ansi mode=oracle dbms=v8 parse=full
PROCFLAGS = mode=oracle dbms=v8 unsafe_null=yes dynamic=ansi PARSE=none code=ansi_c lines=yes

CC      =       gcc $(INCL) -D$(OS) -D$(MACRO) -c *.c
PROC    =       proc $(INCL_PC) $(PROCFLAGS)
INCL    =       -I$(ORACLE_HOME)/precomp/public -I$(ORACLE_HOME)/rdbms/public
INCL_PC =       include=$(ORACLE_HOME)/precomp/public /
                include=$(ORACLE_HOME)/rdbms/public /
        include=$(HOME)/incl
BIN    =    myprog
$(BIN):$(OBJS)
    $(PROC) *.pc
    $(CC) -o $(BIN)
    @rm tp??????
    @rm *.c
    @rm *.lis
    @echo   " "
    @echo    "       ==================MAKE [$(BIN)] SUCCESS!!=============="

原创粉丝点击