‘壹’ c语言,编译、预编译区别
任何一种编程语言的编译都是把代码转换成机器代码认识的格式的过程,而C语言里的预编译则是进行类似转换宏,头文件的代码拷贝,条件语句转换等等基础的转换工作。详细可以看看网络里的内容。
‘贰’ 预编译语句中#与##的作用
# 和 ## 操作符是和#define宏使用的. 使用# 使在#后的首个参数返回为一个带引号的字符串. 例如, 命令
#define to_string( s ) # s
将会使编译器把以下命令
cout << to_string( Hello World! ) << endl;
理解为
cout << "Hello World!" << endl;
使用##连结##前后的内容. 例如, 命令
#define concatenate( x, y ) x ## y
...
int xy = 10;
...
将会使编译器把
cout << concatenate( x, y ) << endl;
解释为
cout << xy << endl;
理所当然,将会在标准输出处显示'10'.
‘叁’ C语言:预编译是什么
预编译,顾名思义,从字面上看,就是提前编译,它做的是工作就是为正式编译做准备
它说处理的是有#标识的代码,如讲include的文件进行拷贝、#define的条件编译等等!关于预编译的介绍你可以到网络里进行查看,里面有详细的介绍!http://ke..com/view/176610.htm
‘肆’ 什么是预编译和实时编译
预编译就是在你代码编译之前做的一些动作,比如你代码里写了
#define size 10
int a[size];
预编译就会把这个size替换掉
int a[10];
实时编译,一般是指那些动态语言,在执行到该代码的时候进行编译,例如
scipy.weave 里面可以嵌入C代码,并在程序的执行过程中,调用gcc编译器把这段C代码编译成二进制,并调用其中的函数执行。
‘伍’ 存储过程和预编译有什么区别
绝对不一样 但细节没有十分的把握说准,看看其他高手
补充:嗯,你的说法是对的,但预编译的代码一般后面会很快用到,但数据库的存储过程不一定会经常用到
‘陆’ 什么叫预编译语句。
预编译就是在所有的程序启动编译前,对某些特殊的程序进行编译,这些特殊的程序一般是类库的文件,全局变量或其他可能要被非预编译代码使用的程序。
‘柒’ 什么是预编译,何时需要预编译
预编译又称为预处理,是做些代码文本的替换工作
预编译又称为预处理,是做些代码文本的替换工作
处理#开头的指令,比如拷贝#include包含的文件代码,#define宏定义的替换,条件编译等
就是为编译做的预备工作的阶段
主要处理#开始的预编译指令
预编译指令指示了在程序正式编译前就由编译器进行的操作,可以放在程序中的任何位置。常见的预编译指令有:
(1)#include 指令
该指令指示编译器将xxx.xxx文件的全部内容插入此处。若用<>括起文件则在系统的INCLUDE目录中寻找文件,若用" "括起文件则在当前目录中寻找文件。一般来说,该文件是后缀名为"h"或"cpp"的头文件。
注意:<>不会在当前目录下搜索头文件,如果我们不用<>而用""把头文件名扩起,其意义为在先在当前目录下搜索头文件,再在系统默认目录下搜索。
(2)#define指令
该指令有三种用法:
第一种是定义标识,标识有效范围为整个程序,形如#define XXX,常与#if配合使用;
第二种是定义常数,如#define max 100,则max代表100(这种情况下使用const定义常数更好,原因见注1);
第三种是定义"函数",如#define get_max(a, b) ((a)>(b)?(a):(b)) 则以后使用get_max(x,y)就可以得到x和y中较大的数(这种方法存在一些弊病,见注2)。
第四种是定义"宏函数",如#define GEN_FUN(type) type max_##type(type a,type b){return a>b?a:b;} ,使用时,用GEN_FUN(int),则此处预编译后就变成了 max_int(int a,int b){return a>b?a:b;},以后就可以使用max_int(x,y)就可以得到x和y中较大的数.比第三种,增加了类型的说明。
(3)#if、#else和#endif指令
这些指令一般这样配合使用:
#if defined(标识) //如果定义了标识
要执行的指令
#else
要执行的指令
#endif
在头文件中为了避免重复调用(比如说两个头文件互相包含对方),常采用这样的结构:
#if !(defined XXX) //XXX为一个在你的程序中唯一的标识符,
//每个头文件的标识符都不应相同。
//起标识符的常见方法是若头文件名为"abc.h"
//则标识为"abc_h"
#define XXX
真正的内容,如函数声明之类
#endif
‘捌’ java里的(关于PreparedStatement接口)预编译
当你向数据库提交SQL语句后,数据库要对这条语句进行编译,例如语法分析、优化路径选择、分配资源等一系列操作,这是需要时间的。
当你向数据库插入10条记录时,如果使用常规做法,数据库需要编译10次。
而使用PreparedStatement接口,数据库只需要编译一次,其他只是更改参数就可以了。
所以,当你向数据库中进行批量操作的时候,预编译效率比较高。
‘玖’ 编译和预编译有什么区别。
预编译又称为预处理,是做些代码文本的替换工作。
处理#开头的指令,比如拷贝#include包含的文件代码,#define宏定义的替换,条件编译等
就是为编译做的预备工作的阶段
主要处理#开始的预编译指令
编译(compilation , compile) 1、利用编译程序从源语言编写的源程序产生目标程序的过程。 2、用编译程序产生目标程序的动作。 编译就是把高级语言变成计算机可以识别的2进制语言,计算机只认识1和0,编译程序把人们熟悉的语言换成2进制的。
‘拾’ 什么是预编译,请举例说明使用方法
主要是对代码做编译前的处理
主要处理#开始的预编译指令
比如 #include #define指令 这种的 就是把包引入或者定义引入
也就是在编译的时候,代码已经没有二义性、包含关系等这种麻烦了。