1、加减乘除运算符
加减法运算符
我们先看一段代码演示加减法的使用。
输出结果是:
右边相加减的结果赋值给左边变量。
除法运算符
看一段演示除法运算符代码
输出结果是:
从输出我们看到num3 = 0明显和我想要的结果不一样,而num4的结果完全符合我们的意料。
下面我们再看一段代码
输出结果是:
在代码里num3定义成一个整型(int),肯定不能存储小数,那么是因为num3是整型才会导致num3值只保留整数部分还是因为除法运算符"/"?我们再看一段代码,把num3定义成单精度浮点型(float),看看输出结果。
输出结果:
输出结果依旧是0,说明不是因为num3的数据类型造成输出结果变化,是因为除法运算符"/",两个整型相除,结果则是商向下取整。我们知道除法运算不仅仅是2个整型的运算,还可以是浮点型和整型,浮点型和浮点型之间的运算。我们先看一段代码整型和浮点型之间的除法运算。
输出结果:
现在输出结果达到我们的想要了。那么现在我们看看除数和被除数两者都是浮点型呢?将会输出什么?先看这段代码
输出结果:
结果完全符合我们的预期。说明两个数相除,只要任意一方是浮点型,得到的结果就是浮点型,保留小数部分。
现在我们总结一下除法运算符的结果的不同之处。
两个整数相除
结果是商向下取整
两个数相除,任意一方是浮点型
结果是商保留整数部分和小数部分
乘法运算符
乘法运算和除法运算结果有一个不同之处就是,乘法运算的结果不会发生截断,两个数都是整数,结果则是整数。两个数任意一方是浮点数,结果则是浮点数,但是我们通常情况下会遇到类似下面的代码。
输出结果是:
我们不是说两个数相乘任意一方是浮点型,结果则是浮点型吗?为什么小数点后面的数没了?其实这是发生了截断,在C语言里浮点型强制转换成整型会发生数据截断,小数部分被丢弃了。那么我们怎么知道数据发生了截断呢?看看下面这段代码我们就知道了。
输出结果是:
说明整型和浮点型相乘得到的结果是浮点型!这里要注意一下10.2f后面带有f表明将10.2转换成单精度浮点型,如果不带f则不会输出"good!"字符串。
2、求余运算符
在C语言里求余运算符是%,下面我们看一段代码。
输出结果:
在C语言里%只能对整型进行求余,任意一方是浮点型时,语法错误。
3、自增自减运算符
自增运算符
在C语言里自增运算符使用++,而自减运算符使用--,下面我们用实际代码分别看看自增自减和常规的加减法有什么不一样。
输出结果是:
从输出结果我们可以知道,num1和num2第一次自增输出结果一样,说明前自增和后自增都可以对变量进行加1。那么第二次输出就有点不同了,虽然都进行了自增,但是num1输出3而num2输出2,最后一次输出num2则是3。这是因为前自增先对变量进行加1后再使用,而后自增则先使用变量再进行加1操作。
自减法运算符
自增和自减法运算符运算过程一样,区别则是一个做加1操作另外一个做减1操作。
4、逗号运算符
首先我们看一段代码
这段代码的输出结果是:
从输出结果我们可以知道,逗号运算符是从左往右结合,先计算num2 = num1 + 1,此时num2 = 2,再计算num2 = num1 + 2,此时num2 = 3,最后取num2的最终值加1的结果赋值给s。
责任编辑:lq6
全部0条评论
快来发表一下你的评论吧 !