前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >8-运算符(上)

8-运算符(上)

作者头像
Python知识大全
发布2020-02-13 18:10:56
6330
发布2020-02-13 18:10:56
举报
文章被收录于专栏:Python 知识大全

本文目录

一、算术运算符 二、赋值运算符 三、自增运算符和自减运算符

计算机的基本能力就是计算,所以一门程序设计语言的计算能力是非常重要的。C语言之所以无所不能,是因为它不仅有丰富的数据类型,还有强大的计算能力。C语言一共有34种运算符,包括了常见的加减乘除运算。这讲就对C语言中的运算符做一个详细介绍。 一、算术运算符 算术运算符非常地简单,就是小学数学里面的一些加减乘除操作。不过呢,还是有一些语法细节需要注意的。 1.加法运算符 +

在第7行利用加法运算符 + 进行了加法运算,再将和赋值给了变量c,最终变量c的值是11 2.减法运算符 或 负值运算符 -

1> 在第7行利用减法运算符 - 进行了减法运算,再将差赋值给了变量c,最终变量c的值是-1 2> 在第7行中,这个 - 并不是什么减法运算符,而算是一个负值运算符,-10代表的是负十 3.乘法运算符 *

注意:乘法运算符并不是x或者X,而是星号*。变量b最终的值是30。 4.除法运算符 / 注意:除法运算符并不是÷,而是一个正斜杠 /

查看输出结果:

3> 如果想让 整数除于整数 不损失精度的话,可以将某个整数强制转换为浮点型数据

10和4之间只要有1个强转为浮点型数据即可,另外1个整数会自动类型提升为浮点型数据。因此,变量a、b、c的值都是2.5。 变量d的情况就不一样了,第7行代码的意思是先计算(10/4)的值,再将(10/4)的值强转为浮点型数据。(10/4)的值是2,将2强转为浮点型数据,那不也就是2么?所以,变量d的值是2 5.模运算符 或称 取余运算符 % 注意:这个%并不是除号÷,它是一个取余运算符,或者叫做模运算符。取余的意思是,取得两个整数相除之后的余数。比如,5除于2的余数是1,5除于3的余数是2。因此使用这个%有个原则:%两侧必须都为整数。下面的写法是错误的:

编译器会直接报错,因为5.0并非整数。 1> 正数取余

简单计算可得:变量a的值为1,变量b的值为2 2> 负数取余

利用%求出来的余数是正数还是负数,由%左边的被除数决定,被除数是正数,余数就是正数,反之则反。因此变量a、b、c的值分别是-1、1、-1 6.运算顺序 1> 算术表达式 用算术运算符将数据连接起来的式子,称为“算术表达式”。比如a + b、10 * 5等。如果表达式比较复杂的话,那么就要注意一下它的运算顺序。表达式的运算顺序是按照运算符的结合方向和优先级进行的。 2> 结合方向 算术运算符的结合方向是从左到右。例如表达式2+3+4,先计算2+3。 3> 优先级 优先级越高,就越先进行运算,当优先级相同时,参照结合方向。下面是算术运算符的优先级排序: 负值运算符(-) > 乘(*)、除(/)、模(%)运算符 > 加(+)、减(-)运算符 例如表达式4+58/-2的计算顺序为:-、、/、+,最后的结果是-16 4> 小括号 如果需要先计算优先级低的可以使用小括号()括住,小括号的优先级是最高的! 例如4+58-2默认的计算顺序是:、+、- 如果想先执行加法运算,就可以这样写:(4+5)*8-2,最后的结果都是不一样的 二、赋值运算符 赋值运算符又分两种:简单赋值运算符 和 复合赋值运算符。 1.简单赋值运算符 = 1> 简单用法 其实这个等号 = 从讲变量开始就见过它了,它的作用是将右边的值赋值给左边。 赋值运算符的结合方向是:从右到左,而且优先级比算术运算符低。因此先进行等号=右边的加法运算,运算完毕后再将结果赋值给等号右边的变量。最后变量a的值是15。 2> 连续赋值

在第1行分别定义了int类型的变量a、b 第3行代码的意思:将10赋值给变量b,再把变量b的值赋值给a。所以最后变量a、b的值都是10 3> 使用注意 等号=左边只能是变量,不能是常量!常量都是不可变的,怎么可以再次赋值呢?下面的写法是错误的: 1 10 = 10 + 5; 2.复合赋值运算符 += 加赋值运算符。如a += 3+2,等价于 a = a +(3+2) -= 减赋值运算符。如a -= 3+2,等价于 a = a -(3+2) *= 乘赋值运算符。如a *= 3+2,等价于 a = a *(3+2) /= 除赋值运算符。如a /= 3+2,等价于 a = a /(3+2) %= 取余赋值运算符。如a %= 3+2,等价于 a = a %(3+2) 三、自增运算符和自减运算符 1.简介 ++ 自增运算符。如a++,++a,都等价于a = a+1 -- 自减运算符。如a--,--a,都等价于a = a-1 注意:你写个5++是错误的,因为5是常量。 2.++a和a++的区别 1> 单独使用++a和a++时,它们是没区别的

上面两段代码的效果都是让a的值+1,最后a的值都为11 2> 下面这种情况,++a和a++就有区别了

上面两段代码的执行结果是有区别的。 第1段代码:++a的意思是先对a执行+1操作,再将a的值赋值给b。因此最后a、b的值都是11 第2段代码:a++的意思是先将a的值拷贝出来一份,然后对a执行+1操作,于是a变成了11,但是拷贝出来的值还是10,a++运算完毕后,再将拷贝出来的值10赋值给了b,所以最后变量b的值是10,变量a的值是11 --a和a--的区别也是一样的。 3> 再来看一个比较刁钻的例子

很多人一眼看上去,觉得最后a的值应该是11,其实最后a的值是10。前面已经说过a++的作用了,这里也是一样的。先将a的值拷贝出来一份,然后对a执行+1操作,于是a变成了11,但是拷贝出来的值还是10,a++运算完毕后,再将拷贝出来的值10赋值给了a,所以最后变量a的值是10。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2018-09-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 Python 知识大全 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档