No.63582 作者:红8511 邮件: ID:136082 登陆:1次 文章数:8篇 最后登陆IP: 最后登陆:2009/9/2 13:41:08 注册:2009/9/2 13:41:08 财富:100 发帖时间:2009/9/4 16:58:18 发贴者IP:221.219.118.207 标题:红8511:一本超越谭浩强、K&R的C语言编程著作《 Linux C编程一站式学习》连载六 摘要:No.63582一本超越谭浩强、K&R的C语言编程著作《 Linux C编程一站式学习》连载六 5. 表达式 常量和变量都可以参与加减乘除运算,例如1+1、hour-1、hour * 60 + minute、minute/60等。这里的+ - * /称为运算符(Operator),而参与运算的常量和变量称为操作数(Operand),上面四个由运算符和操作数所组成的算式称为表达式(Expression)。 和数学上规定的一样,hour * 60 + minute这个表达式应该先算乘再算加,也就是说运算符是有优先级(Precedence)的,*和/是同一优先级,+和-是同一优先级,*和/的优先级高于+和-。对于同一优先级的运算从左到右计算,如果不希望按默认的优先级计算则要加()括号(Parenthesis)。例如(3+4)*5/6应先算3+4,再算*5,再算/6。 前面讲过打印语句和赋值语句,现在我们定义:在任意表达式后面加个;号也是一种语句,称为表达式语句。例如: hour * 60 + minute; 这是个合法的语句,但这个语句在程序中起不到任何作用,把hour的值和minute的值取出来加乘,得到的计算结果却没有保存,白算了一通。再比如: int total_minute; total_minute = hour * 60 + minute; 这个语句就很有意义,把计算结果保存在另一个变量total_minute里。事实上等号也是一种运算符,称为赋值运算符,赋值语句就是一种表达式语句,等号的优先级比+和*都低,所以先算出等号右边的结果然后才做赋值操作,整个表达式total_minute = hour * 60 + minute加个;号构成一个语句。 任何表达式都有值和类型两个基本属性。hour * 60 + minute的值是由三个int型的操作数计算出来的,所以这个表达式的类型也是int型。同理,表达式total_minute = hour * 60 + minute的类型也是int,它的值是多少呢?C语言规定等号运算符的计算结果就是等号左边被赋予的那个值,所以这个表达式的值和hour * 60 + minute的值相同,也和total_minute的值相同。 等号运算符还有一个和+ - * /不同的特性,如果一个表达式中出现多个等号,不是从左到右计算而是从右到左计算,例如: int total_minute, total; total = total_minute = hour * 60 + minute; 计算顺序是先算hour * 60 + minute得到一个结果,然后算右边的等号,就是把hour * 60 + minute的结果赋给变量total_minute,这个结果同时也是整个表达式total_minute = hour * 60 + minute的值,再算左边的等号,即把这个值再赋给变量total。同样优先级的运算符是从左到右计算还是从右到左计算称为运算符的结合性(Associativity)。+ - * /是左结合的,等号是右结合的。 现在我们总结一下到目前为止学过的语法规则: 表达式 → 标识符 表达式 → 常量 表达式 → 字符串字面值 表达式 → (表达式) 表达式 → 表达式 + 表达式 表达式 → 表达式 - 表达式 表达式 → 表达式 * 表达式 表达式 → 表达式 / 表达式 表达式 → 表达式 = 表达式 语句 → 表达式; 语句 → printf(表达式, 表达式, 表达式, ...); 变量声明 → 类型 标识符 = Initializer, 标识符 = Initializer, ...; (= Initializer的部分可以不写) 注意,本书所列的语法规则都是简化过的,是不准确的,目的是为了便于初学者理解,比如上面所列的语法规则并没有描述运算符的优先级和结合性。完整的C语法规则请参考[C99]的Annex A。 表达式可以是单个的常量或变量,也可以是根据以上规则组合而成的更复杂的表达式。以前我们用printf打印常量或变量的值,现在可以用printf打印更复杂的表达式的值,例如: printf("%d:%d is %d minutes after 00:00\n", hour, minute, hour * 60 + minute); 编译器在翻译这条语句时,首先根据上述语法规则把这个语句解析成下图所示的语法树,然后再根据语法树生成相应的指令。语法树的末端的是一个个Token,每一步展开利用一条语法规则。 图 2.2. 语法树 ......
>>返回讨论的主题
|