C语言课件(运算符和表达式)
- 格式:ppt
- 大小:297.00 KB
- 文档页数:29
C语言运算符和表达式C语言把除了控制语句和输入输出以外几乎所有的基本操作都作为运算符处理。
1自增(++)、自减(-一)运算符:自增(++)、自减(一)运算符的作用是使变量的值加1或减1,例如,++ii(在使用之前,先使的值加(减)1)i++,i-(在使用i之后,使i的值加(减)1)y++i和i++的不同之处在于:++i是先执行i=i+1,再使用i的值;而i++是先使用i的值,再执行i=i+lβ自增(减)运算符常用于循环语句中,使循环变量自动加1;也用于指针变量,使指针指向下一个地址。
2算术表达式和运算符的优先级与结合性用算术运算符和括号将运算对象连接起来的、符合C语法规则的式子称C 算术表达式。
运算对象包括常量、变量、函数等。
c语言规定了运算符的优先级(如先乘除后加减),还规定了运算符的结合性。
在表达式求值时,先按运算符的优先级别顺序执行,如果在一个运算对象两侧的运算符的优先级别相同,C语言规定了各种运算符的结合方向(结合性),算术运算符的结合方向都是〃自左至右〃,即运算对象先与左面的运算符结合。
算术运算符是自左至右(左结合性),赋值运算符是自右至左(右结合性)。
赋值运算符和赋值表达式赋值运算符就是二,表示〃存储〃,即把赋值号右边表达式的值存给左边的变量。
可以出现在赋值号左边的式子,称为左值(Ieftvalue)o左值必须有内存空间且允许赋值。
常用的左值是变量,但常变量不能作为左值。
赋值运算符的结合性,从右至左。
若有两个赋值号,要先执行右边的。
如:a=b=2相当于是a=(b=2).3不同类型数据间的混合运算在程序中经常会遇到不同类型的数据进行运算,如果一个运算符两侧的看据类型不同,则先自动进行类型转换,使二者成为同一种类型,然后进行运算。
整型、实型,字符型数据间可以进行混合运算。
规律为1)十、-\/运算的两个数中有一个数为float或double型,结果是double 型,因为系统将所有float型数据都先转换为double型,然后进行运算。
c语言运算符及其表达式(总14页)--本页仅作为文档封面,使用时请直接删除即可----内页可以根据需求调整合适字体及大小--C语言的数据类型运算符表达式1.基本数据类型基本数据类型最主要的特点是,其值不可以再分解为其它类型。
也就是说,基本数据类型是自我说明的。
2.构造数据类型构造数据类型是根据已定义的一个或多个数据类型用构造的方法来定义的。
也就是说,一个构造类型的值可以分解成若干个“成员”或“元素”。
每个“成员”都是一个基本数据类型或又是一个构造类型。
在C语言中,构造类型有以下几种:·数组类型·结构类型·联合类型3.指针类型指针是一种特殊的,同时又是具有重要作用的数据类型。
其值用来表示某个量在内存储器中的地址。
虽然指针变量的取值类似于整型量,但这是两个类型完全不同的量,因此不能混为一谈。
4.空类型在调用函数值时,通常应向调用者返回一个函数值。
这个返回的函数值是具有一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max函数定义中,函数头为: int max(int a,int b);其中“int ”类型说明符即表示该函数的返回值为整型量。
又如在例题中,使用了库函数 sin,由于系统规定其函数返回值为双精度浮点型,因此在赋值语句s=sin (x);中,s 也必须是双精度浮点型,以便与sin函数的返回值一致。
所以在说明部分,把s说明为双精度浮点型。
但是,也有一类函数,调用后并不需要向调用者返回函数值,这种函数可以定义为“空类型”。
其类型说明符为void。
在第五章函数中还要详细介绍。
在本章中,我们先介绍基本数据类型中的整型、浮点型和字符型。
其余类型在以后各章中陆续介绍。
对于基本数据类型量,按其取值是否可改变又分为常量和变量两种。
在程序执行过程中,其值不发生改变的量称为常量,取值可变的量称为变量。
它们可与数据类型结合起来分类。
例如,可分为整型常量、整型变量、浮点常量、浮点变量、字符常量、字符变量、枚举常量、枚举变量。
C语⾔运算符与表达式1 概论计算机内存中的数据可以通过变量,常量来表⽰和存储,那么这些数据如何运算?C语⾔中提供了⼤量(34种)的运算符可以⽤来完成数据的算术,赋值,逻辑,关系,条件判断以及⾃增⾃减运算和基于⼆进制的位运算,同时提供了跨平台的⽤于数据格式化输⼊输出的函数printf()和scanf(),⽽实际上计算机需要去完成的任务正是读取输⼊的数据,根据业务逻辑进⾏计算之后将结果输出。
在学习为了完成数据的复杂计算⽽⽣的那些运算符之前,需要先明⽩⼏个概念:操作数:参与计算的数据,可以是之前学过的整数,浮点数和字符以及以后学的。
运算符:也就是执⾏某项计算的符号,例如+ - * / % >等等表达式:操作数和运算符的组合,例如 x+y;⽽运算符通常是有优先级和结合性的特性:优先级:以算术运算符为例⼦,通常是先乘除后加减,可以使⽤()提⾼优先级结合性:继续以算术运算符为例⼦,当优先级相同时(表达式中只有同级别的运算符),通常是从左到右开始执⾏的。
但是实际⽣产和⽣活中通常都是各种运算和后⾯学习的流程控制语句联合嵌套使⽤的,是现实⽣活中的业务复杂度决定的。
2 算术运算符算术运算符主要是⽤来完成数学运算的,C语⾔⽀持数学上的加减乘除四则混合运算,同时还有取模运算(%),也就是求被除数/除数=商数…余数,需要指出的是只有整数才能求模。
下⾯程序案例演⽰了算术运算符使⽤过程中需要注意的事项:1 整数和整数运算,结果是整数,尤其是在使⽤除法时需要注意会舍去⼩数部分2 当有多种数据类型(int double char)参与运算时,运算结果的数据类型是参与运算的最⼤的数据类型,这样保持数据运算的准确性。
#include <stdio.h>/*算术运算符 + - * -@author Tony 186********@@since 20160526 10:13*/void alg_operator() {printf("%d\n", 1 + 3);printf("%d\n", -3); //加减运算符有时候会被当做正负数printf("%d\n", 5 / 2.0);//运算的结果是2.5 但是printf在打印输出时不会做强制类型转换,因此这⾥解析错误,结果为0printf("%d\n", (int)(3.5 * 2));// 当参与运算的类型不⼀致时,如果想要指定类型的结果,可以通过强制类型转换来实现printf("3/2=%d", 3 / 2); //两个整数相除⼩数部分被舍去}求模运算的结果与被除数相同,如果被除数是正数,那么取余的结果也是正数,反之也成⽴。