① 能将c语言的语句用在shell脚本吗他的执行需要经过编译链接吗为什么
不可以,C的源代码必须要经过编译连接后才能执行,shell是解释型的脚本语言,不需要编译。
② 我们所写的每条C语句经过编译最终将转换成二进制的机器指令 这句话为什么对
不是每条语句都会被编译为指令的
最简单的例子,空语句就不会被编译
③ 以下语句是否可以通过编译: if ( 1<=n<=10 );
编译可以通过,但是C语言没有这样的写法;
程序运逗返改行结果很可能不是正确结果,比如:山判
#include<stdio.h>世锋
intmain()
{
inta=3,b=2,c,s;
c=(a>b>1)&&(a++==1+b++);
s=a+b+c;
printf("%d ",s);//输出结果为5
//c=(a>b&&b>1)&&(a++==1+b++);
//printf("%d ",s);输出结果为8
}
④ C语言源程序文件经过编译连接之后生成一个后缀为_____的文件。
如果只生成一个文件,那么这个题目答案是B。编译(compile)后生成目标文件,后缀:.obj。也就是机器码。
然后链接器(Linker) 连接生成可执行文件,后缀:.exe。最后运行命令(go),直接运行.exe文件。
(4)语句经过编译扩展阅读:
简单讲,编译器就是将“一种语言(通常为高级语言)”翻译为“另一种语言(通常为低级语言)”的程序。
一个现代编译器的主要工作流程:源代码(source code) →预处理器(preprocessor) →编译器(compiler) →目标代码(object code) →链接器(Linker) → 可执行程序(executables)
高级计算机语言便于人编写,阅读交流,维护。机器语言是计算机能直接解读、运行的。
编译器将汇编或高级计算机语言源程序(Source program)作为输入,翻译成目标语言(Target language)机器代码的等价程序。
源代码一般为高级语言 (High-level language), 如Pascal、C、C++、Java、汉语编程等或汇编语言。
而目标则是机器语言的目标代码(Object code),有时也称作机器代码(Machine code)。
对于C#、VB等高级语言而言,此时编译器完成的功能是把源码(SourceCode)编译成通用中间语言(MSIL/CIL)的字节码(ByteCode)。
最后运行的时候通过通用语言运行库的转换,编程最终可以被CPU直接计算的机器码(NativeCode)。
⑤ C语言文件的编译与执行的四个阶段并分别描述
开发C程序有四个步骤:编辑、编译、连接和运行。
任何一个体系结构处理器上都可以使用C语言程序,只要该体系结构处理器有相应的C语言编译器和库,那么C源代码就可以编译并连接到目标二进制文件上运行。
1、预处理:导入源程序并保存(C文件)。
2、编译:将源程序转换为目标文件(Obj文件)。
3、链接:将目标文件生成为可执行文件(EXE文件)。
4、运行:执行,获取运行结果的EXE文件。
(5)语句经过编译扩展阅读:
将C语言代码分为程序的几个阶段:
1、首先,源代码文件测试。以及相关的头文件,比如stdio。H、由预处理器CPP预处理为.I文件。预编译的。文件不包含任何宏定义,因为所有宏都已展开,并且包含的文件已插入。我归档。
2、编译过程是对预处理文件进行词法分析、语法分析、语义分析和优化,生成相应的汇编代码文件。这个过程往往是整个程序的核心部分,也是最复杂的部分之一。
3、汇编程序不直接输出可执行文件,而是输出目标文件。汇编程序可以调用LD来生成可以运行的可执行程序。也就是说,您需要链接大量的文件才能获得“a.out”,即最终的可执行文件。
4、在链接过程中,需要重新调整其他目标文件中定义的函数调用指令,而其他目标文件中定义的变量也存在同样的问题。
⑥ 程序是由语句组成的吗声明部分算语句吗到底什么是语句啊
声明不是指令,那是给编译器看的....
就是告诉编译器,往下查找,可以找到该声明的定义部分,如果不懂函数原型的意义,你可以这么理解
⑦ 我们所写的每条c语句,经过编译最终都转化成二进制的机器指令为什么对
C语言中的注释是不会转化为二进制的。
第一句话,注意“每条c语句”,c语句是不包含注释,所以正确。
第二句话,“每条可执行语句和非执行语句”,显然注释语句也被包含在其中,所以错误。
这种题就是玩了个文字游戏
⑧ C++中如何定义动态的字符串数组
new 动态定义数组。因并谈为new 就是用来动态开辟空间的,所以当然可以用来开辟一个数组空间。
这样,下面的语句:
int size=50;
int *p=new int[size]; 是正确的。
首先 new int[size][Column] 就是动态生成时确定的,所以它没有错。那么就是 int(*p)[Column],这句有问题了,这句为什么不对呢, 那是因为,这是一个定义语句,而定义语句先经过编译器进行编译,当编译器运行到此处时,发现Column 不是常数,因此不能通过编译。
而之所以编译器认为Column 不是常数,是因为编译阶段,编译器起的作用是查语法错误,和预分配空间,它并不执行程序,因此,没有执行那亮毕个赋值语句(只是对这个语句检查错误,和分配空间),因此编译阶段,它将认为column 是个变量。
(8)语句经过编译扩展阅读
动态数组的特点
数组到底应该有多大才合适,有时可能不得而知。所以希望能够在运行时具有改变数组大小的能力。
动态数组就可以在任何时候改变大小。在Visual Basic中,动态数组最灵活、最方便,有助于有效管理内存。例如,可短时间使用一个大数组,然后,在不使用这敬蔽芹个数组时,将内存空间释放给系统。
如果不用动态数组,就要声明一个数组,它的大小尽可能达到最大,然后再抹去那些不必要的元素。但是,如果过度使用这种方法,会导致内存的操作环境变慢。
每次执行 ReDim 语句时,当前存储在数组中的值都会全部丢失。Visual Basi 重新将数组元素的值置为 Empty(对 Variant 数组)、置为 0(对 Numeric 数组)、置为 零长度字符串(对 String 数组)或者置为 Nothing(对于对象的数组)。
在为新数据准备数组,或者要缩减数组大小以节省内存时,这样做是非常有用的。有时希望改变数组大小又不丢失数组中的数据。使用具有 Preserve 关键字的 ReDim 语句就可做到这点。
⑨ C语言中的条件编译有什么作用
条件编译就是为了实现在满足一定条件时编译某一组语句,而再不满足条件时编译另一组语句!
事实上,它确实与条件语句相似,但是它们是不一样的。条件语句中的各个语句都是要经过编译的,而条件编译中的部分语句不需要进行编译(请注意这儿是编译不是执行)。条件编译的作用在编写大型程序的时候就会相当的明显,因为它可以减少被编译的语句,从而减少目标程序的长度,减少运行时间。
具体怎样使用的话,这个你最好看一些教程,要想在这个地方给你讲清还是比较麻烦的。不过总体来讲它还是比较简单的,你看教程的话应该比较容易看懂!
⑩ 我们所写的每条C语句经过编译最终将转换成二进制的机器指令 这句话为什么对不是只有可执行语句才会吗
C语言里,以分号结尾的叫做语句,没有可执行语句这个凯猜概念,因为单独的一个分号(空语句)也可以(不是一定)被编译为汇编指令nop所对应的二进制指令。上面的正孙备描述只在未进行编译器优化时成举毁立。