C语言中“语句”和“指令”有什么区别?

Python010

C语言中“语句”和“指令”有什么区别?,第1张

区别一:构成不一样

1、C程序的执行部分是由语句组成的。 程序的功能也是由执行语句实现的。

2、指令可以使编译器按不同的条件编译不同的程序部分,因而产生不同的目标代码文件。这对于程序的移植和调试是很有用的,尤其是针对于跨平台程序移植的时候。

区别二:实现功能不一样

1、C程序语言可以实现多种程序结构, 即顺序结构、分支(选择)结构、循环结构。

2、指令可以实现源代码的部分编译功能,可以根据表达式的值或者某个特定的宏来确定编译条件,以决定编译哪些代码,不编译哪些。

扩展资料

C语言表达式语句

表达式语句由表达式加上分号“”组成。

其一般形式为:表达式执行表达式语句就是计算表达式的值和执行副作用。

例如: x=y+z;a=520;赋值语句;

y+z;加法运算语句,但计算结果不能保留,无实际意义;

i++; 自增1语句,i值增1。

i++; 是先运算i后再加1。

++i; 是先把i值增1后运算。

包括空语句,函数调用语句在内都属于表达式语句。

C语言条件编译指令

1、#if指令

该指令检测表达式值是否为真。如果表达式的值为真,则编译后面的代码直到出现 #else、#elif 或 #endif 为止,否则不编译。

2、#endif指令

该指令用于终止 #if 指令。

3、#else指令

该指令用于 #if 指令之后,当前面的 #if 指令的条件不为真时,就编译 #else 后面的代码。

4、#elif指令

该指令综合了 #else 和 #if 指令的作用。下面的示例代码演示了 #if、#else、#elif 与 #endif 的组合使用情况。

参考资料来源:百度百科—C语言基础语句

你是说关键字吧!

由ANSI标准定义的C语言关键字共32个 :

auto double int struct break else long switch

case enum register typedef char extern return union

const float short unsigned continue for signed void

default goto sizeof volatile do if while static

根据关键字的作用,可以将关键字分为数据类型关键字和流程控制关键字两大类。

1 数据类型关键字

A基本数据类型(5个)

void :声明函数无返回值或无参数,声明无类型指针,显式丢弃运算结果

char :字符型类型数据,属于整型数据的一种

int :整型数据,通常为编译器指定的机器字长

float :单精度浮点型数据,属于浮点数据的一种

double :双精度浮点型数据,属于浮点数据的一种

B 类型修饰关键字(4个)

short :修饰int,短整型数据,可省略被修饰的int。

long :修饰int,长整形数据,可省略被修饰的int。

signed :修饰整型数据,有符号数据类型

unsigned :修饰整型数据,无符号数据类型

C 复杂类型关键字(5个)

struct :结构体声明

union :共用体声明

enum :枚举声明

typedef :声明类型别名

sizeof :得到特定类型或特定类型变量的大小

D 存储级别关键字(6个)

auto :指定为自动变量,由编译器自动分配及释放。通常在栈上分配

static :指定为静态变量,分配在静态变量区,修饰函数时,指定函数作用域为文件内部

register :指定为寄存器变量,建议编译器将变量存储到寄存器中使用,也可以修饰函数形参,建议编译器通过寄存器而不是堆栈传递参数

extern :指定对应变量为外部变量,即在另外的目标文件中定义,可以认为是约定由另外文件声明的韵蟮囊桓觥耙�谩?

const :与volatile合称“cv特性”,指定变量不可被当前线程/进程改变(但有可能被系统或其他线程/进程改变)

volatile :与const合称“cv特性”,指定变量的值有可能会被系统或其他进程/线程改变,强制编译器每次从内存中取得该变量的值

2 流程控制关键字

A 跳转结构(4个)

return :用在函数体中,返回特定值(或者是void值,即不返回值)

continue :结束当前循环,开始下一轮循环

break :跳出当前循环或switch结构

goto :无条件跳转语句

B 分支结构(5个)

if :条件语句

else :条件语句否定分支(与if连用)

switch :开关语句(多重分支语句)

case :开关语句中的分支标记

default :开关语句中的“其他”分治,可选。

C 循环结构(3个)

for :for循环结构,for(123)4的执行顺序为1->2->4->3->2...循环,其中2为循环条件

do :do循环结构,do 1 while(2)的执行顺序是 1->2->1...循环,2为循环条件

while :while循环结构,while(1) 2的执行顺序是1->2->1...循环,1为循环条件

以上循环语句,当循环条件表达式为真则继续循环,为假则跳出循环。

我们可以在C源程序中插入传给编译程序的各中指令,这些指令被称为预处理器指令,它们扩充了程序设计的环境。现把常用的预处理命令总结如下: \x0d\x0a1. 预处理程序\x0d\x0a按照ANSI标准的定义,预处理程序应该处理以下指令:\x0d\x0a#if #ifdef #ifndef #else #elif\x0d\x0a#endif\x0d\x0a#define\x0d\x0a#undef\x0d\x0a#line\x0d\x0a#error\x0d\x0a#pragma\x0d\x0a#include\x0d\x0a显然,上述所有的12个预处理指令都以符号#开始,,每条预处理指令必须独占一行。\x0d\x0a2. #define\x0d\x0a#define指令定义一个标识符和一个串(也就是字符集),在源程序中发现该标识符时,都用该串替换之。这种标识符称为宏名字,相应的替换称为宏代换。一般形式如下:\x0d\x0a#define macro-name char-sequence\x0d\x0a这种语句不用分号结尾。宏名字和串之间可以有多个空白符,但串开始后只能以新行终止。\x0d\x0a例如:我们使用LEFT代表1,用RIGHT代表0,我们使用两个#define指令:\x0d\x0a#define LEFT 1\x0d\x0a#define RIGHT 0\x0d\x0a每当在源程序中遇到LEFT或RIGHT时,编译程序都用1或0替换。\x0d\x0a定义一个宏名字之后,可以在其他宏定义中使用,例如:\x0d\x0a#define ONE 1\x0d\x0a#define TWO ONE+ONE\x0d\x0a#define THREE ONE+TWO\x0d\x0a宏代换就是用相关的串替代标识符。因此,如果希望定义一条标准错误信息时,可以如下定义:\x0d\x0a#define ERROR_MS “Standard error on input \n”\x0d\x0a如果一个串长于一行,可在行尾用反斜线”\”续行,如下:\x0d\x0a#define LONG_STRING “This is a very very long \\x0d\x0aString that is used as an example”\x0d\x0a3. #error\x0d\x0a#error指令强制编译程序停止编译,它主要用于程序调试。#error指令的一般形式是:\x0d\x0a#error error-message\x0d\x0a注意,宏串error-message不用双引号包围。遇到#error指令时,错误信息被显示,可能同时还显示编译程序作者预先定义的其他内容。\x0d\x0a4. #include\x0d\x0a程序中的#include指令要求编译程序读入另一个源文件。被读入文件的名字必须用双引号(“”)或一对尖括号()包围,例如:\x0d\x0a#include “stdio.h”\x0d\x0a#include \x0d\x0a都使C编译程序读入并编译头文件以用于I/O系统库函数。\x0d\x0a包含文件中可以包含其他#include指令,称为嵌套包含。允许的最大嵌套深度随编译器而变。\x0d\x0a文件名被双括号或尖括号包围决定了对指定文件的搜索方式。文件名被尖括号包围时,搜索按编译程序作者的定义进行,一般用于搜索某些专门放置包含文件的特殊目录。当文件名被双括号包围时,搜索按编译程序实时的规定进行,一般搜索当前目录。如未发现,再按尖括号包围时的办法重新搜索一次。\x0d\x0a通常,绝大多数程序员使用尖括号包围标准的头文件,双引号用于包围与当前程序相关的文件名。\x0d\x0a\x0d\x0a5. 条件编译指令\x0d\x0a若干编译指令允许程序员有选择的编译程序源代码的不同部分,这种过程称为条件编译。\x0d\x0a5.1#if、#else、#elif #endif\x0d\x0a条件编译指令中最常用的或许是#if,#else,#elif和#endif。这些指令允许程序员根据常数表达式的结果有条件的包围部分代码。\x0d\x0a#if的一般形式是:\x0d\x0a#if constant-expression\x0d\x0aStatement sequence\x0d\x0a#endif\x0d\x0a如#if后的常数表达式为真,则#if和#endif中间的代码被编译,否则忽略该代码段。#endif标记#if块的结束。\x0d\x0a#else指令的作用与C语言的else相似,#if指令失败时它可以作为备选指令。例如:\x0d\x0a#include \x0d\x0a#define MAX 100\x0d\x0aInt main(void)\x0d\x0a{\x0d\x0a#if MAX>99\x0d\x0aprintf(“Compiled for array greater than 99.\n”)\x0d\x0a#else\x0d\x0aprintf(“Complied for small array.\n”)\x0d\x0a#endif\x0d\x0areturn 0\x0d\x0a}\x0d\x0a注意,#else既是标记#if块的结束,也标记#else块的开始。因为每个#if只能写一个#endif匹配。\x0d\x0a#elif指令的意思是“否则,如果”,为多重编译选择建立一条if-else-if(如果-否则-如果链)。如果#if表达式为真,该代码块被编译,不测试其他#elif表达式。否则,序列中的下一块被测试,如果成功则编译之。一般形式如下:\x0d\x0a#if expression\x0d\x0aStatement sequence\x0d\x0a#elif expression1\x0d\x0aStatement sequence\x0d\x0a#elif expression2\x0d\x0aStatement sequence\x0d\x0a.\x0d\x0a.\x0d\x0a.\x0d\x0a#elif expression\x0d\x0aStatement sequence\x0d\x0a#endif\x0d\x0a5.2#ifdef和#ifndef\x0d\x0a条件编译的另一个方法是使用编译指令#ifdef和#ifndef,分别表示“如果已定义”和“如果未定义”。#ifdef的一般形式如下:\x0d\x0a#ifdef macro-name\x0d\x0aStatement sequence\x0d\x0a#endif\x0d\x0a如果macro-name原先已经被一个#define语句定义,则编译其中的代码块。\x0d\x0a#ifndef的一般形式是:\x0d\x0a#ifndef macro-name\x0d\x0aStatement sequence\x0d\x0a#endif\x0d\x0a如果macro-name当前未被#define语句定义,则编译其中的代码块。\x0d\x0a\x0d\x0a我认为,用这种,可以很方便的开启/关闭整个程序的某项特定功能。\x0d\x0a#ifdef和#ifndef都可以使用#else或#elif语句。\x0d\x0a#inlucde \x0d\x0a#define T 10\x0d\x0aInt main(void)\x0d\x0a{\x0d\x0a#ifdef t\x0d\x0aPrintf(“Hi T\n”)\x0d\x0a#else\x0d\x0aPrintf(“Hi anyone\n”)\x0d\x0a#endif\x0d\x0a#ifndef M\x0d\x0aPrintf(“M Not Defined\n”)\x0d\x0a#endif\x0d\x0aReturn 0\x0d\x0a}\x0d\x0a6. #undef\x0d\x0a#undef指令删除前面定义的宏名字。也就是说,它“不定义”宏。一般形式为:\x0d\x0a#undef macro-name\x0d\x0a7. 使用defined\x0d\x0a除#ifdef之外,还有另外一种确定是否定义宏名字的方法,即可以将#if指令与defined编译时操作符一起使用。defined操作符的一般形式如下:\x0d\x0adefined macro-name\x0d\x0a如果macro-name是当前定义的,则表达式为真,否则为假。\x0d\x0a例如,确定宏MY是否定义,可以使用下列两种预处理命令之一:\x0d\x0a#if defined MY\x0d\x0a或\x0d\x0a#ifdef MY\x0d\x0a也可以在defined之前加上感叹号”!”来反转相应的条件。例如,只有在DEBUG未定义的情况下才编译。\x0d\x0a#if !defined DEBUG\x0d\x0aPrintf(“Final Version!\n”)\x0d\x0a#endif\x0d\x0a使用defined的一个原因是,它允许由#elif语句确定的宏名字存在。\x0d\x0a8. #line\x0d\x0a#line指令改变__LINE__和__FILE__的内容。__LINE__和__FILE__都是编译程序中预定义的标识符。标识符__LINE__的内容是当前被编译代码行的行号,__FILE__的内容是当前被编译源文件的文件名。#line的一般形式是:\x0d\x0a#line number “filename”\x0d\x0a其中,number是正整数并变成__LINE__的新值;可选的“filename”是合法文件标识符并变成__FILE__的新值。#line主要用于调试和特殊应用。\x0d\x0a\x0d\x0a9. #pragma\x0d\x0a#pragma是编译程序实现时定义的指令,它允许由此向编译程序传入各种指令。例如,一个编译程序可能具有支持跟踪程序执行的选项,此时可以用#pragma语句选择该功能。编译程序忽略其不支持的#pragma选项。#pragma提高C源程序对编译程序的可移植性。\x0d\x0a10. 预处理操作符#和##\x0d\x0a有两个预处理操作符:#和##,它们可以在#define中使用。\x0d\x0a操作符#通常称为字符串化的操作符,它把其后的串变成用双引号包围的串。例如:\x0d\x0a#include \x0d\x0a#define mkstr(s) #s\x0d\x0aint main(void)\x0d\x0a{\x0d\x0aPrintf(mkstr(I like C))\x0d\x0aReturn 0\x0d\x0a}\x0d\x0a预处理程序把以下的语句:\x0d\x0aPrintf(mkstr(I like C))\x0d\x0a变成\x0d\x0aPrintf(“I like C”)\x0d\x0a操作符##把两个标记拼在一起,形成一个新标记。例如:\x0d\x0a#include \x0d\x0a#define concat(a,a) a##b\x0d\x0aint main(void)\x0d\x0a{\x0d\x0aInt xy = 10\x0d\x0aPrintf(“%d”,concat(x,y))\x0d\x0aReturn 0\x0d\x0a}\x0d\x0a预处理程序把以下语句:\x0d\x0aPrintf(“%d”,concat(x,y))\x0d\x0a变成\x0d\x0aPrintf(“%d”,xy)\x0d\x0a操作符#和##主要作用是允许预处理程序对付某些特殊情况,多数程序中并不需要。\x0d\x0a11. 预定义宏\x0d\x0aC规范了5个固有的预定义宏,它们是:\x0d\x0a__LINE__\x0d\x0a__FILE__\x0d\x0a__DATE__\x0d\x0a__TIME__\x0d\x0a__STDC__\x0d\x0a__LINE__和__FILE__包含正在编译的程序的行号和文件名。\x0d\x0a__DATE__和内容形如month/day/year(月/日/年)的串,代表源文件翻译成目标码的日期。\x0d\x0a__TIME__中的串代表源代码编译成目标码的时间,形如hour:minute:second(时:分:秒)\x0d\x0a如果__STDC__的内容是十进制常数1,则表示编译程序的实现符合标准C。