单片机双字节数乘法运算实验_c语言 基本运算

单片机双字节数乘法运算实验_c语言 基本运算_第1张图片

一:算术运算符

算术运算符非常地简单,就是小学数学里面的一些加减乘除操作。不过呢,还是有一些语法细节需要注意的。

1.加法运算符 +

1 

在第3行利用加法运算符 + 进行了加法运算,再将和赋值给了变量b,最终变量b的值是15

2.减法运算符 或 负值运算符 -

1 

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

3.乘法运算符 *

1 

注意:乘法运算符并不是x或者X,而是星号*。变量b最终的值是50。

4.除法运算符 /

1 

注意:除法运算符并不是÷,而是一个正斜杠 /

1> 第1行中的10.0是浮点型,4是整型,因此会将4自动类型提升为浮点型后再进行运算,最后变量b的值是2.5

2> 第2行中的10和4都是整型,计算机中的运算有个原则:相同数据类型的值才能进行运算,而且运算结果依然是同一种数据类型。因此,整数除于整数,求出来的结果依然是整数,会损失小数部分。最后变量b的值是2。查看输出结果:

2e765f34b40fb72ae097ba227c80bfd8.png

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

1 
  • 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。因此使用这个%有个原则:%两侧必须都为整数。下面的写法是错误的:

1 

编译器会直接报错,因为5.0并非整数。

1> 正数取余

1 

简单计算可得:变量a的值为1,变量b的值为2

2> 负数取余

1 

利用%求出来的余数是正数还是负数,由%左边的被除数决定,被除数是正数,余数就是正数,反之则反。因此变量a、b、c的值分别是-1、1、-1

6.运算顺序

1> 算术表达式

用算术运算符将数据连接起来的式子,称为“算术表达式”。比如a + b、10 * 5等。如果表达式比较复杂的话,那么就要注意一下它的运算顺序。表达式的运算顺序是按照运算符的结合方向和优先级进行的。

2> 结合方向

算术运算符的结合方向是从左到右。例如表达式2+3+4,先计算2+3。

3> 优先级

优先级越高,就越先进行运算,当优先级相同时,参照结合方向。下面是算术运算符的优先级排序:

负值运算符(-) > 乘(*)、除(/)、模(%)运算符 > 加(+)、减(-)运算符

例如表达式4+5*8/-2的计算顺序为:-、*、/、+,最后的结果是-16

4> 小括号

如果需要先计算优先级低的可以使用小括号()括住,小括号的优先级是最高的!

  • 例如4+5*8-2默认的计算顺序是:*、+、-
  • 如果想先执行加法运算,就可以这样写:(4+5)*8-2,最后的结果都是不一样的

二、赋值运算符

赋值运算符又分两种:简单赋值运算符 和 复合赋值运算符。

1.简单赋值运算符 =

1> 简单用法

其实这个等号 = 从讲变量开始就见过它了,它的作用是将右边的值赋值给左边。

1 

赋值运算符的结合方向是:从右到左,而且优先级比算术运算符低。因此先进行等号=右边的加

你可能感兴趣的:(单片机双字节数乘法运算实验)