C语言第二课 数字的运算

在赋值运算的时候,有括号先算括号,没有括号有乘除先算乘除,没有乘除先算加减。

 

当除法运算的时候,print("%d,%d\n", 123/10 , 123%10);         计算这个的时候, 第一个除法 得到的是整数的部分 也就是12,第二个是取余数 也就是3

注意:只有浮点数初一浮点数才会出现小数点。其他情况下不会出现。

除法运算的时候,print("%f\n",123.0/10.0); 这个计算是不会取整的,因为是浮点数运算,得到的值就是精确的值 也就是12.3

注意:当浮点数运算的时候,不可以使用取余数的运算符,也就是说 print("%f\n" ,123.0 % 10.0); 是不合法的,因为直接得到精确的值了,所以不合法会报错的。

 

计算机只能对同一种数据类型进行计算,不同类型的混合运算,系统需要先进行转换,才能计算,类型转换就可能造成内存截断,这个结果可能是错误的或者是我们不想要的

 

 

 

运算优先级表:

C语言第二课 数字的运算

C语言第二课 数字的运算

C语言第二课 数字的运算

 

 

自增自减问题:

int a = 12; int b = 12;

int c = a++; int d = ++b;

 

print("%d,%d\n", a , c ); 打印的结果是 13 ,12 因为先执行的是把a的值赋给c,然后a再进行自增运算

 

print("%d , %d\n", b , d ); 打印的结果是 13 , 13 因为先执行的是把b进行自增运算,然后b的值在赋给d

 

常量是无法自加的, 就是  例如 13++;会报错。 但是 a++;就可以  因为 a是变量,a++改变的是a这个变量自增

 

注意:

1.同一个变量的自加自减在同一个语句当中只能出现一次。

2. ++a的优先级 高于 a++的优先级。 就是 先执行++a,后执行a++

3.   int b = 13 ; print("%d\n" , b);            print("%d\n" , b++);   print("%d\n" , ++b);               

    先打印 13  然后 13  最后 15  因为 b++ 是先打印b 然后再执行++ 之后得到的b是14  ,第三个++b 是将b自增后的值进行打印,所以打印的值为15.

 

 在内存中  a++ 和 ++a 的存在形式 :

C语言第二课 数字的运算



其他的一些运算符:


int a = 10;

a = a + 3 ;  等价于    a += 3 ;

a = a - 3 ;  等价于 a -= 3 ;

a = a * 3 ; 等价于 a *= 3 ;

a = a /3 ;   等价于 a /= 3 ; 



相关文章:

  • 2021-08-25
  • 2021-11-18
  • 2021-06-13
  • 2022-01-09
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-11-30
猜你喜欢
  • 2021-04-15
  • 2022-12-23
  • 2021-09-21
  • 2021-07-30
  • 2022-12-23
  • 2021-08-10
  • 2021-10-31
相关资源
相似解决方案