第三章 运算符和表达式

合集下载

Java编程基础及应用第3章运算符、表达式和语句

Java编程基础及应用第3章运算符、表达式和语句

(1)左移位运算符
左移位运算符的符号为“<<”,是二元运算符。左移位运算符左
面的操作元称为被移位数,右面的操作数称为移位量。

例如:a<<n运算的结果是通过将a的所有位都左移n位,每左移一 个位,左边的高阶位上的0或1被移除丢弃,并用0填充右面的低位 。
3.1.5 移位运算符

(2)右移位运算符
3.1.7 条件运算符

条件运算符是一个多元运算符,它的符号是“? : ”,需要连接三
个操作数,用法如下:a?b:c,要求a的值必须为boolean型数据 。运算法则是:当a的值为true时,a?b:c运算的结果是b的值;
当a的值是false时,a?b:c运算的结果是c的值。

例如: 8>2?10:20的结果是10;
// DevideTest2.java public class DevideTest2 { public static void main(String[] args) { int a = 13, b = 4, k; float f1, f2; k = a / b;//整数相除,结果仍为整数 f1 = a / b;//将整数结果强制转换为浮点型 f2 = (float) a / b;//将a强制转换为浮点 型,结果则为浮点型

(4)“按位异或”运算符
“^”是双目运算符。对两个整型数据a、b按位进行异或运算,运 算结果是一个整型数据c。运算法则是:如果a、b两个数据对应位
相同,则c的该位是0,否则是1。

例如:1001001和0101001进行“异或”运算,表达如下, 1001001 ^0101001 1100000

按照运算类型,可以将运算符分成以下几类:算术运算符,关系

C语言第3章数据类型、运算符与表达式ppt课件

C语言第3章数据类型、运算符与表达式ppt课件
第三章
数据类型、运算符与表达式
1
主要内容
一、C的数据类型 二、常量与变量 三、基本数据类型 四、运算符与表达式
2
一、C的数据类型
(一) 什么是数据类型? (二) C语言的数据类型有哪些?
3
(一) 什么是数据类型?
对数据的描述
对操作的描述
数据结构+算法=程序
C语言中以 “数据类型”形式存在
4
所谓数据类型是按被定义变量的性质,表示形 式,占据存储空间的多少,构造特点来划分的。
int NUM=20; sum=PRICE*NUM;
11
符号常量优点
1、含义清楚。 2、在需要改变一个常量时,能够做到“一
改全改”
12
(二)变量
概念
变量代表内存中具有特定属性的一 个存储单元,它用来存放数据,也 就是变量的值。
13
(1)变量名。每个变量都有一个名字 ──变量名,代表一个地址。 (2)变量值。在程序运行过程中,变 量值存储在内存中。在程序中,通过 变量名来引用变量的值。
#include <stdio.h>
void main() {
int student,age; int if=adrress=1; float score=90;
stadent=2; Age=20; printf("%d %d %d %f",if,student,age,score); }
本程序中有 几处错误?
(5)标识符的有效长度随系统而异,如果超 长,则超长部分被舍弃。VC++6.0中规 定最大长度为247个字符。
23
请选出下列正确的标识符 M.D.John , 12%gf ,1add ,_ce36 ,age& 5thclass, lotus-1-2-3 , cd*ef , float,

第3章 运算符和表达式

第3章  运算符和表达式

double long
unsigned
float

int
char,short
横向箭头表示必须的转换 ,纵向箭头表示当运 算符两侧的运算对象为不同类型时的转换, 这些转换都是由系统自动进行的 。
北京邮电大学出版社
3.4 不同数据类型数据间的混合运算
二.强制类型转换 强制类型转换是通过类型转换运算来实现的。 其一般形式为: (类型说明符)(表达式) (类型说明符)是类型转换运算符,单目运算, 优先级别为2级,具右结合性。在类型转换 运算符的右侧跟上表达式形成类型转换表达 式,其功能是把表达式的运算结果强制转换 成类型说明符所表示的类型。
北京邮电大学出版社
3.2 算术运算符
二.算术表达式
算术表达式是用算术运算符和括号将运算对象连接起来 的、符合C语言的语法规则的式子。 使用算术表达式时应注意: (1) 当双目算术运算符两侧运算对象的类型一致时,运算 结果的类型与运算对象的类型相同,如果类型不一 致,系统将自动按规律先将运算对象转换为同一类 型,然后再进行运算。 (2) 可以用括号改变表达式的运算顺序,左右括号必须配 对,多层括号都用小括号“()”表示。 (3) 注意算术表达式的书写形式,不要写成代数式的形式。
北京邮电大学出版社
3.4 不同数据类型数据间的混合运算
三.强制类型转换 赋值表达式的类型转换 当赋值运算符两侧的运算对象数据类型不同时, 系统也将进行自动类型转换,转换规则为: 将赋值运算符右侧表达式的类型转换为左侧变量 的类型。
北京邮电大学出版社
3.4 不同数据类型数据间的混合运算
1.浮点型与整型相互转换 将浮点数据(包括单、双精度)转换为整型时,将舍弃浮点数的小 数部分,只保留整数部分。 2.单、双精度浮点型相互转换 由于C语言中的浮点值总是用双精度表示的,所以float型数据只是 在尾部加0延长为double型数据参加运算,然后直接赋值。 double型数据转换为float型时,先截取双精度实数的前7位有效数 字,然后再赋给单精度类型的变量。 3.字符型与整型相互转换 将整型数据赋给字符型变量时,由于整型数据用两个字节存放,而 字符型数据用一个字节存放,所以只保留其低8位赋给字符型 变量,高位部分舍弃。 字符型数据赋给整型变量时,将字符数据的8位放入整型变量的低8 位中,有些编译系统在整型变量的高8位补0;而有些编译系 统(如Turbo C),根据字符的最高位为0或1将高8位全部补 0或补1。

第三章VB运算符和表达式

第三章VB运算符和表达式
规则1.VB代码中不区分字母的大小写
(1) 关键字 首字母自动改为大写, 其余字母改为小写 (2) 自定义的变量名、过程名 系统以第一次定义的为准
规则2. 语句书写自由
语句是构成VB程序的最基本成分,程序 是按行书写的。
(1)一行写多个语句时,语句间用冒号(:) 分隔。 例:n=100:m=1000
(三)变量声明
使用变量前,一般必须先声明变量名及其 数据类型(变量的两个特性),然后才能在程序 中使用
1.用Dim语句声明变量 语句格式:
Dim 变量名 [As 类型] [,变量名 [As 类型]] …
• 说明:Dim语句定义的变量其作用范围由 Dim语 句所在的位置决定。 Dim 语句出现在窗体代码 的声明部分时,则窗体以及窗体中各控件的事 件过程都可以使用这些变量。这种变量称为窗 体级变量; 在过程内部用 Dim 语句声明的
举例
(2)一个语句可写在几行上 (3)一行允许最多达255个字符
用续行符(空格加下划线“ _”)连接。
规则3. 代码中必要时添加注释
说明: (在VB程序中呈绿色)
1. 注释有利于程序的可读性。
2. 注释部分在程序运行时不执行
3. 续行符后不能加注释
4. 三种设置方式如下 1)以Rem开头 2)单引号“ ‘ ”引导注释见 3)使用注释块
它是内存单元位置的命名,一旦定 义了某个变量,该变量就表示某个内存 单元的位置,用户可以使用变量名访问 该内存单元中的数据。 举例如下
举例1说明:
对于新建的学生宿舍,要给其进行编号,学 生宿舍的编号是对一个宿舍的命名,宿舍号就 是用来描述宿舍位置的。可以通过宿舍号找到 宿舍内住的学生。若调换宿舍,则成员变化 宿舍 宿舍号 内存空间 变量

c语言程序设计第三章运算符与表达式

c语言程序设计第三章运算符与表达式

第三章运算符和表达式3.1 运算符和表达式概述使用运算符可以对运算对象(包括常量和变量)进行计算以得到计算结果。

用运算符将运算对象连接成一个符合C语言语法规则的式称为表达式。

另外,C语言中的表达式是可以嵌套的,即简单表达式经过运算符连接后还可以形成更为复杂的表达式。

根据运算符所连接的运算对象(操作数)的个数,可以将C语言中的运算符分为三类:(1) 单目(一元)运算符:只连接一个操作数的运算符。

(2) 双目(二元)运算符:带有两个操作数的运算符。

(3) 三目(三元)运算符:同时对三个操作数进行计算的运算符。

C语言中的表达式可以分为三类:(1) 单个常量或者单个变量是最简单的表达式。

(2) 带有运算符的表达式。

(3) 函数调用。

任何一种运算都是将一定的运算符作用于一定的运算对象上,得到预期的运算结果。

所以运算对象、运算符和运算结果是运算的三大要素。

3.2 算术运算符和算术表达式一、基本算术运算符和简单算术表达式1. 基本算术运算符C语言为用户提供的基本算术运算符包括:+(加)、-(减)、*(乘),/(除)、%(求余),这些运算符都是双目运算符,也即在生成算术表达式的时,基本算术运算符左右两侧都必须出现运算对象。

2. 简单算术表达式当用基本算术运算符去连接常量或者变量时,就形成简单算术表达式。

简单算术表达式的基本形式:data1 op data2。

data1和data2表示某个常量或者变量,op代表上述5个基本算术运算符之一。

假设有变量定义:int a=20,b=-5;则a+b、a-b、a*-2、20/-b、20%6、a%b等都是简单算术表达式。

3. 基本算术运算符使用说明(1) +、-、*,/既可以连接整型数据,也可以连接实型数据。

当参与这4个运算符的运算对象都是整型数据时,得到整型数据运算结果;否则表示浮点运算。

例如,int a=15,b=2;则a*b等于30,而a/b等于7;a*2.0等于30.0,而a/2.0等于7.5。

3 数据类型、运算符和表达式

3 数据类型、运算符和表达式

三、整型数据
3.1.整型常量 整型常量即整常数按不同的进制区分, 整型常量即整常数按不同的进制区分 , 整型常数 有三种表示方法: 有三种表示方法:
十进制数: 以非0 220, 560, 十进制数: 以非0开始的数 如:220, -560, 45900 八进制数: 06; 0106, 八进制数: 以0开始的数 如:06; 0106, 十六进制数: 十六进制数: 以0X或0x开始的数 如:0X0D, 0XFF, 0x4e
一般情况下,符号常量名用大写、变量用小写。 一般情况下,符号常量名用大写、变量用小写。
3、符号常量的声明和使用 一般放在程序的前端, <…>在一块: 一般放在程序的前端,与#include < >在一块: #define 符号常量名 值 如:#define Zero 0 好处: 好处: 含义清楚 (#define Second 60) (#define (#define 一改全改 (#define PI 3.14)
3. 整型变量的溢出
main(){ i,j; int i,j; unsigned k,l,m; k,l,m; i=32767 32767; i=32767; j=i+1 j=i+1; l=65535 65535u l=65535u; m=l+2 m=l+2; printf("j=%d\n",j); printf("j=% n",j); printf("l=% n",l); printf("l=%u\n",l); printf("m=% n",m); printf("m=%u\n",m); }
3.2、整型变量 整型变量的分类:加上不同的修饰符 1 . 整型变量的分类 : 加上不同的修饰 符 , 整型变 量有以下几种类型; 量有以下几种类型; C 语言标准没有规定整型变量在计算机内存中所 占的字节数,它与具体的机器和操作系统有关: 占的字节数,它与具体的机器和操作系统有关:

3、JavaScript运算符和表达式

3、JavaScript运算符和表达式

var box = Infinity + Infinity;
//Infinity
var box = -Infinity + -Infinity; //-Infinity
var box = Infinity + -Infinity; //NaN,正无穷和负无穷相加等NaN
var box = 100 + '100';
3.逻辑非运算符可以用于任何值。无论这个值是什么数据类型,这个运算符都会返回一个布尔值。它 的流程是:先将这个值转换成布尔值,然后取反
注: JavaScript虽说也有& 和 |,但是这里不是做逻辑运算符,而是位运算符
七、三目运算符
三目运算符,又叫三元条件运算符 三元条件运算符其实就是后面将要学到的if 语句的简写形式。 根据条件在两个语句中执行其中的一个,使用符号 ?: 语法如下: 条件表达式?语句1:语句2 参数说明: 条件表达式,结果会被作为布尔值处理 语句1:如果条件表达式返回true则执行 语句2:如果条件表达式返回false则执行
算术运算符即算术运算符号。是完成基本的算术运算 (arithmetic operators) 符号,就是 用来处理四则运算的符号。
算数运算符分为以下:
二、算术运算符
加法运算符(+)
var box = 1 + 2;
//等于3
var box = 1 + NaN;
//NaN,只要有一个NaN 就为NaN
值 true false false false true true false false false true false
五、比较运算符(关系运算符)
相等运算符 == :判断两个操作数是否相等。 不同的数据类型会自动转换为相等的数据类 型再做比较。

Java实用PPT课件第3章运算符、表达式与语句

Java实用PPT课件第3章运算符、表达式与语句
12
(4)“按位异或”运算符
"^"是双目运算符。对两个整型数据a、b按位进行运算, 运算结果是一个整型数据c。运算法则是:如果a、b两个数据 对应位相同,则c的该位是0,否则是1。如果b的精度高于a, 那么结果c的精度和b相同。
位运算符在操作逻辑型数据时,与逻辑运算符&&、||、! 不同的是位运算要计算完a和b之后再给出运算的结果。
(2)“按位或”运算符 "|"是双目运算符。对两个整型数据a、b按位进行运算,运 算结果是一个整型数据c。运算法则是:如果a、b两个数据对应 位都是0,则c的该位是0,否则是1。如果b的精度高于a,那么 结果c的精度和b相同。 (3)“按位非”运算符 "~"是单目运算符。对一个整型数据a按位进行运算,运算结 果是一个整型数据c。运算法则是:如果a对应位是0,则c的该 位是1,否则是0。
a>>n运算的结果是通过将a的所有位都右移n位,每右移一 个位,右边的低阶位被移出丢弃,并用0或1填充左边的高位, a是正数用0填充,负数时用1填充。
因此,a每右移一次,如果该数的每一计算有效位都没有 从低位移出时,就相当于将a除以2并舍弃了余数。整数不断右 移位的最后结果一定是0,而负数不断右移位的最后结果是-1。
符的级别是7级。 (3)关系表达式
结果为数值型的变量或表达式可以通过关系运算符形成关系表达式。 例如,24>18,(x+y+z)>30+x等。
5
3.3逻辑运算符与逻辑表达式
逻辑运算用来实现boolean型数据的逻辑“与”、“或”和“非”运算, 运算结果是boolean型数据。 (1)逻辑“与”和逻辑“或”
在下面的例子3-2中,利用“异或”运算的性质,对几个 字符进行加密并输出密文,然后再解密。运行结果见图3-2。

第三章 数据类型运算符与表达式

第三章 数据类型运算符与表达式

三、变量
3、变量值的存储 变量被定义以后,系统在运行时会为该变量分配一个相 应大小的存储空间,称为存储单元。 给变量赋值后,该变量对应的存储单元中会存放该值, 这个值称为变量的值。 那么变量的值在变量的存储单元中是如何表示的呢? (1)整数是以补码的形式存放的。 (正数的补码是其本身,负数的补码为原码按位取反加1) 如:int a=2, b; b= -2; a 00000000 00000010 b 11111111 11111110
(一)算术运算符和算术表达式
表达式的值: 表达式运算得到的最终结果为表达式的值。 也就是整个式子代表的值 如a=5,b=2; a+b 7
(二)赋值运算符和赋值表达式
赋值运算符:= 格式:变量=表达式 如:int a,b; 下面都是正确的赋值表达式 a=5; b=3; a=2+3; a=a+2; b=a*a; 赋值运算为“从右向左”结合的。 如x=y=z=3 它等价于:x=(y=(z=3))
第三章 数据类型运算符与表达式
信息管理系
3.0、C语言中标识符的概念
• 在程序中,由程序设计者使用的名字成为标 识符。标识符用以标志区分不同的东西。它 可以用作函数的名字、变量、常量的名字, 以及文件的名字等等。
一、C语言中的标识符分类
• 用户标识符 • 关键字(语句标识及类型标识)(P375附录II) 例如:real,main,char,int,float,double, long,if,for,switch,default,break等。 • 预定义标识符(函数名字等) 例如:define,include,printf,scanf,sin等。
2的原码表示:00000000 00000010 -2的补码表示:11111111 11111101+1=11111111 11111110

第三章 数据类型、运算符及表达式§31 字符及标识符

第三章 数据类型、运算符及表达式§31 字符及标识符

2关系运算符
比较两个操作数的大小的运算符,称为关系运算符。 关系运算的表达式,称为关系表达式。 例如, 3+5 > 7-4 关系表达式也有它的值。 如: 8 > 3, 该关系成立,因此关系表达式的值为真, 反之, 其值为假。 在C语言中,用数值1表示真,用数0表示假。 如,7 == 2,关系表达式为假,其值为0。 关系运算符的种类和表达式如下:

*C 语言提供的长整数的表示方法可以用来扩大整数的取值 范围. – 例如, 41l, 037l, 0x1fL 字母后面的l 或 L ,表示该数是长常数., 上面三个数,分别是十进制、八进制、十六进制长整数。 一个在整数中放不下的普通整数也被作为长整数,
因此, 把其后紧跟有 l 或 L 的整数叫显式长整数. • 在16位字长的机器上,长整数的位数是 32 位 ( 增长一倍 )。 故长十进制整数取值范围为 -2147483648 到 2147483647。 (2)整型变量: • 基本整型 int 如: int x; • 长整型 long 如: long int y; 或 long y ; • 无符号 unsugend 如: unsigend int z; 或 unsigend z。
• 关键字
具有固定意义的标识符,用户不能用作为自己的标识符, 它们共有32个,除符号常量外都用小写字母表示,就其用途 分五类。 (1) 数据类型 int char float double short ... (2) 存储类型 extern static register auto typedef (3) 控制语句 if else for while do .... (4) 运算符 sizeof (5) 符号常量 EOF BOF .... *它们的含义后面将会络续提到。 * 用户定义的标识符,不能和关键字同名。

第3章_运算符和表达式

第3章_运算符和表达式

运行结果如下: k=3 f1=3.0 f2=3.75
【例题】编写程序,接收命令行输入的浮点数,
将此浮点数的整数部分输出。
import java.util.*; public class FloatDemo { public static void main(String args[]){ double d; Scanner reader=new Scanner(System.in); d=reader.nextDouble(); System.out.println(d+"的整数部分为"+(long)d); reader.close(); } }
赋值运算符还可以与算术运算符、逻辑运算符和位运算 符组合成复合赋值运算符,使用方法见表。
运算符 += 用例 x += y 等价于 x=x+y 运算符 &= 用例 x &= y 等价于 x=x&y
-= *= /=
%= >>>=
x- = y x*= y x /= y
x %= y x >>>= y
x=x-y x=x*y x=x/y
运算符和表达式
常用的运算符有哪些?
算术运算符:+、-、*、/、% 关系运算符:>、<、>=、<=、==、!= 逻辑运算符:&&、||、! 条件运算符:?:
运算符和表达式
1 运算符 对数据进行加工和处理称为运算,表示各种 运算的符号称为运算符,参与运算的数据称为 操作数。 根据操作数的个数,可以将运算符分为单 目、双目和多目运算符。单目运算符只对1个操 作数运算,双目运算符对2个操作数运算。 根据操作数和运算结果,运算符分为:算 术运算符、关系运算符、逻辑运算符、位运算 符。

运算符和表达式

运算符和表达式

(2) (3)
(4)
-5%2 得 -1
• 说明:
– “-”为单目运算符时,右结合性
1%10 得 1 6%2 得 0
5.5%2 ()
– 两整数相除,结果为整数
– %要求两侧均为整型数据
1 ax a x
2
4x
写成C表达式:1.0/2*(a*x+(a+x)/4/x)
ab c de
f gh
写成C表达式:(a+b)/(c+d*e/(f+g*h))
例 3.6 根据下列条件,写出C的逻辑表达式。 (4)条件“x、y 落在圆心在(0,0)半径为1的圆外、
中心点在(0,0)边长为4的矩形内”。 逻辑表达式: x*x+y*y>1&&x>=–2&&x<=2&&y>=–2&&y<=2
2
1
-2
1 -1 -1
2
-2
注意
❖逻辑表达式的特性:
▪逻辑表达式求解时,并非所有的逻辑运算符都被执行,只
float z=4; x=(y=y+6,y/z); c*=(a=b=1,c=2,b+=a,b*5); printf("x=%d\n",x); printf(“a=%d,b=%d,c=%d”,a,b,c); }
运行结果: x=3 a=1,b=2,c=20
3.7 多种类型混合运算
3.7.1 运算符优先级
▪规定了在表达式求解过程中,当运算对象的左右都有运算符
时运算的先后次序,即运算对象先做优先级高的运算。
▪如:4–6*8,先做“*”运算,其结果再做“–”,因“*”优先

C语言教程第3章 数据类型、运算符与表达式

C语言教程第3章  数据类型、运算符与表达式
#include <stdio.h> void main( ) { int a,b,c,d; /*指定a、b、c、d为整型变量*/ unsigned u; /*指定u为无符号整型变量*/ a=12;b=-24;u=10; c=a+u;d=b+u; printf("a+u=%d,b+u=%d\n",c,d); } 运行结果为 a+u=22,b+u=-14
注意以下几点:
(4) 一个整常量后面加一个字母u,认为 是unsigned int型,如12345u,在内存 中按unsigned int规定的方式存放(存储 单元中最高位不作为符号位,而用来存 储数据,见图2.4(b)。如果写成-12345u, 则先将-12345转换成其补码53191,然 后按无符号数存储。
int a; unsigned int b;
一个整数(以13为例)在存储单元中 的存储情况
3. 整型变量的定义
int a,b; (指定变量a、b为整型) unsigned short c,d; (指定变量c、d为无符号短整型) long e,f; (指定变量e、f为长整型)
例3.2整型变量的定义与使用。
字符型变量用来存放字符常量,请注 意只能放一个字符,不要以为在一个字符 变量中可以放一个字符串(包括若干字符)。 字符变量的定义形式如下: char c1,c2;
c1='a';c2='b';
3.5.3 字符数据在内存中的存储 形式及其使用方法
字符的相应的ASCII代码放到存储单元中
例3.6向字符变量赋予整数。
单精度 ( float 型 占4B) 双精度 ( double 型 占8B )

C语言第3章数据类型、运算符、表达式

C语言第3章数据类型、运算符、表达式

例如
➢字符常量‘a’占一个字节 ➢字符串常量"a" 占2个字节
‘a’ → “a” →
0110 0001 ……
0110 0001 0000 0000
(97)10
(97)10 (0)10
7.变量赋初值
变量赋初值
C语言允许定义变量时赋予初值。
➢int i = 6;
也可对某个变量赋初值:
➢int a, b, c = 6;
如: 0x16, 0x28
4.整型数据
整型变量
分类:
➢基本型 用“ int ”定义; ➢短整型 用“ short int ”或 “ short ”定义; ➢长整型 用“ long ”或 “ long int ”定义; ➢无符号型 用“ unsigned ”定义,不存放符号;
整型变量定义方式
➢基本整型:int a, b, c; ➢短整型 : short int 或 short a, b, c; ➢长整型: long int 或 long a, b, c; ➢无符号型:unsigned a, b; unsigned short a, b
10+‘a’+1.5–8765.1234 ‘b’
8.各种数值型数据间的混合运算
转换方法(自动转换)
double float

long
unsigned
低 int char, short
图中“ ” 表示必定转换。如'a' +' b',先转换为int,结果为 int。
既使是同一种类型也按" "转换。
对于“++”和“--”的使用要避免二义性
10.赋值运算符和赋值表达式

第3章-基本数据类型、运算符和表达式

第3章-基本数据类型、运算符和表达式
整型常量
问题:
0123 = (
)10
0x123 = (
)10
0Xff = (
)10
形式
表示方式
举例
十进制整数 由数字0~9和正负号表示 123,-456,0
八进制整数
由数字0开头,后跟数字0~7 表示
十六进制整数 由0x开头,后跟
0~9,a~f,A~F表示
0123,011 0x123,0Xff
整型常量的类型

(signed) long

unsigned int
无 unsigned short
unsigned long
实 有 float 型 有 double
字有
符 型

char unsigned char
说明:数据类型 所占字节数随机 器硬件不同而不 同,上表以IBM 所占位P数C机为例 数的表示范围
16
#define PRICE 30
main()
{
int num,total; num=10;
运行结果:total=300
total=num*PRICE;
printf("total=%d",total);
}
变量
其值可以改变的量称为变量 变量也可以为任意数据类型 变量定义的一般格式
数据类型 变量1[,变量2,…,变量n];
组讨成论::判断下列标识符号合法性
su•m只能S由um字母M、.D数.J字oh、n 下划d线ay组成D,ate且第3一day个s 字母必 须是字母或下划线
stu•d大en小t_n写am敏e感#33 lotus_1_2_3 char a>b ab•ov不e 能使$1用23关_键toD字ay
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第三章运算符和表达式3.1 运算符和表达式概述使用运算符可以对运算对象(包括常量和变量)进行计算以得到计算结果。

用运算符将运算对象连接成一个符合C语言语法规则的式称为表达式。

另外,C语言中的表达式是可以嵌套的,即简单表达式经过运算符连接后还可以形成更为复杂的表达式。

根据运算符所连接的运算对象(操作数)的个数,可以将C语言中的运算符分为三类:(1) 单目(一元)运算符:只连接一个操作数的运算符。

(2) 双目(二元)运算符:带有两个操作数的运算符。

(3) 三目(三元)运算符:同时对三个操作数进行计算的运算符。

C语言中的表达式可以分为三类:(1) 单个常量或者单个变量是最简单的表达式。

(2) 带有运算符的表达式。

(3) 函数调用。

任何一种运算都是将一定的运算符作用于一定的运算对象上,得到预期的运算结果。

所以运算对象、运算符和运算结果是运算的三大要素。

3.2 算术运算符和算术表达式一、基本算术运算符和简单算术表达式1. 基本算术运算符C语言为用户提供的基本算术运算符包括:+(加)、-(减)、*(乘),/(除)、%(求余),这些运算符都是双目运算符,也即在生成算术表达式的时,基本算术运算符左右两侧都必须出现运算对象。

2. 简单算术表达式当用基本算术运算符去连接常量或者变量时,就形成简单算术表达式。

简单算术表达式的基本形式:data1 op data2。

data1和data2表示某个常量或者变量,op代表上述5个基本算术运算符之一。

假设有变量定义:int a=20,b=-5;则a+b、a-b、a*-2、20/-b、20%6、a%b等都是简单算术表达式。

3. 基本算术运算符使用说明(1) +、-、*,/既可以连接整型数据,也可以连接实型数据。

当参与这4个运算符的运算对象都是整型数据时,得到整型数据运算结果;否则表示浮点运算。

例如,int a=15,b=2;则a*b等于30,而a/b等于7;a*2.0等于30.0,而a/2.0等于7.5。

(2) 在使用除法运算符时要注意右操作数(除数)不能为零。

(3) 取余运算%只能对整型数据取余。

另外,由于取余实质上是先进行除法运算,然后得到相除后的余数,所以和除法运算符一样,右操作数不能为零。

例如,int a=15,b=0;double d=3.0;则a%b和a%d都是非法的表达式。

【例3.1】调用函数printf打印表达式的值。

#include <stdio.h>main(){int a=15,b=20;printf("%d--%d \n",a,15);printf("%d+%d=%d\n",a,b,a+b);printf("15+20=%d\n",15+20);printf("%d+5=%d\n",a,a + 5);}说明:(1)printf不仅能打印单个常量或者单个变量的值,还能将任意的有值表达式的值打印在控制台屏幕上。

(2) 操作数和运算符之间可以有空白符,见本例程序中的“a + 5”。

【例3.2】测试更多的算术运算符。

#include <stdio.h>main(){int i=7,j=2;double d=2.0;printf("%d%%%d=%d\n",i,j,i%j);printf("%d%%%d=%d\n",j,i,j%i);printf("%d/%d=%d\n",i,j,i/j);printf("%d/%f=%f\n",i,d,i/d);}说明:(1) %是格式说明符的起始字符,需要用%%来打印%,见本例程序第6行和第7行。

(2) 从程序第8行和第9行的运行结果中不难看出,当两个整型数据参与除法运算时结果为整数,否则为浮点数。

4. 字符的算术运算第二章中提到过,由于字符在内存中是用ASCII码存储的,而ASCII码就是一个整数,所以字符数据和整型数据是兼容的,即可以把字符赋给整型变量,也可以把整数赋给字符变量,还可以用转换字符c或d输出字符数据和整型数据。

兼容性还体现在能让字符数据参与算术运算。

【例3.3】对字符进行算术运算。

#include <stdio.h>main(){char ch1='A',ch2='a';int i=0x20;printf("%d,%d\n",ch1+0x20,ch2-i);printf("%c,%c\n",ch1+0x20,ch2-i);}说明:字符数据参与算术运算时,实际是用该字符的ASCII码值进行相应的计算。

二、自增(++)和自减运算(- -)++和--是两个单目的算术运算符,作用是使变量当前的值加1或减1。

当++或--放在变量名前面时,称为前自增或前自减运算;当++或—放在变量名后面时,称为后自增或后自减运算。

以++为例,前自增运算是先对变量值加1运算,再使用变量的值(自增以后的值);后自增运算是先使用变量原来的值,再对变量值加1。

【例3.4】比较前/后自增运算符的不同。

#include <stdio.h>main(){int a=2009,b=a;printf("a=%d,b=%d\n",a,b);printf("a++=%d\n",a++);printf("a=%d\n",a);printf("++b=%d\n",++b);printf("b=%d\n",b);}说明:(1) ++和—主要用来改变变量的值,所以它们的操作数不能是数值。

例如,4++;就是一条非法语句。

(2) 使用时只连接一个操作数的运算符为单目运算符(或叫一元运算符),所以sizeof和&都是单目运算符。

sizeof可以计算某一类型数据存储时占据的内存字节数,例如sizeof(变量名);&用于获得变量的地址,例如,&变量名。

【例3.5】分析以下程序的运行结果。

交换第5行与第6行后,程序的运行结果?#include <stdio.h>main(){int a=2010;printf("%d\n",--a);printf("%d\n",a--);printf("%d\n",a);}说明:通常,只在单一地对变量加1或减1的情况下才使用自增或自减运算符。

如果让自增/自减运算参与其他操作,有可能会出现意想不到的副作用。

【例3.6】自增/自减运算符的副作用。

#include <stdio.h>main(){int i=2009;printf("i=%d,i++=%d\n",i,i++);}说明:本例在VC6.0下运行的结果为:i=2009,i++=2009;而在TC2.0下运行的结果为:i=2010,i++=2009。

三、算术运算符的优先级和结合性本章开篇时提到过,可以将一个表达式嵌套在另一个表达式中,另一个等价的说法就是可以用运算符去连接表达式。

当用基本算术运算符连接常量或变量时可以形成最简单的算术表达式,而常量和变量本身就是最简单的有值表达式,所以事实上可以用基本算术运算符去连接两个有值表达式,即expression1 op expression2,这里的expression1和expression2表示有值表达式,而op则代表5个基本算术运算符。

例如,a*b+2009(其中a、b为int变量)、3.5-2.0+d (d 为double变量)。

1. 运算符的优先级当一个表达式中使用了多个运算符时,由运算符的优先级决定到底哪一运算先进行。

算术运算符的优先级如表3-1所示。

表3-1 算术运算符的优先级表所以在计算a*b+2009时,由于变量b左边的乘法运算符*的优先级高于右边的加法运算符+,所以该表达式应先执行乘法运算,后计算加法(将乘法运算的结果和常量2009相加)。

2. 运算符的结合性那么对于表达式“3.5-2.0+d”怎么计算?因为变量d左右两边的运算符+和-的优先级是相同的。

由此可见,当某个常量或者变量左右两边的运算符的优先级相同的时,无法通过优先级来决定运算符执行的先后顺序,这时需要由结合性来判定运算顺序。

算术运算符的优先级和结合性如表3-2所示。

根据结合性,在计算3.5+d-2.0时,由于加法运算符+和减法运算符是左结合,即变量d先和左边的加法运算相结合,所以该表达式应先执行加法运算,后计算减法(将加法运算的结果和常量2.0相减)。

若想不受优先级和结合性的制约,人为地改变运算的先后顺序,则可以使用括号。

例如,对于表达式“a*b+2009”,若想强制先执行加法运算,则需对加法子表达式使用括号——a*(b+2009),对于表达式“3.5+d-2.0”,若想强制先执行减法运算,则需对减法子表达式使用括号——3.5+(d-2.0)。

3. 复杂表达式的计算在计算复杂表达式时,常常可以应用算符优先算法的基本思想——先从左往右扫描整个表达式,一旦发现表达式中某个变量或者常量左边运算符的优先级高于右边运算符的优先级时,就执行左边运算。

然后对经过化简的表达式按照上述过程继续化简,直到所有运算执行完毕为止。

【例3.7】若有定义语句:int s=6;则表达式s%2+(s+1)%2的值为。

分析:根据算符优先算法的基本思想,本例表达式中运算符的计算顺序如下:s%2+(s+1)%2 → 0+(s+1)%2 → 0+7%2 → 0+1 → 1【例3.8】算术运算符的优先级和结合性#include <stdio.h>main(){int a=5,b=4;printf("a=%d,b=%d\n",a,b);printf("a+b%%3*a+b%%2/4=%d\n",a+b%3*a+b%2/4);printf("a++/--b=%d\n",a++/--b);printf("++a*a++=%d\n",++a*a++);printf("++a*10+15/b++=%d\n",++a*10+15/b++);printf("a=%d,b=%d\n",a,b);}3.3 赋值运算符和赋值表达式一、基本赋值运算符和赋值表达式的一般形式1. 基本赋值运算符在第2章中,我们已经接触过对变量的赋值运算,它的作用是将数据存储在某个变量中(赋值运算实质上就是将数据写入到某个变量中)。

相关文档
最新文档