【C语言篇】☞ 4. 运算符

算术运算符:

  1. +  加法运算符
  2. –   减法运算符,或负值运算符
  3. *  乘法运算符
  4. /   除法运算符
  5. % 模运算符,或称取余运算符,要求%两侧均为整型数据

% 取模(取余)运算符的注意事项:

1)取模运算符的操作数只能是整数  

2)取模运算符的正负性取决于前面老操作数正负

3)如果取模运算的左侧小于右边, 那么结果就是左手

取余(模运算):5%3=2; -5%3=-2; 5%-3=2; -5%-3=-2 (余数的记和给除数一致!)

2%9=2;

图片 1

算术运算的注意点:

  1. 自动类型转换

    int a = 10.6;

    int b = 10.5 + 1.7;

    int b = 10.5 + 10; //将右边的10升格为double类型

    自动将大类型转换为多少类,会少精度

  1. 自动型提升

  (相同数据类型的价才能够展开演算(比如加法运算),而且运算结果仍然是平种多少类。系统会自行对占有内存较少的型做一个“自动型提升”的操作)

    float a = 10 + 3.45f;//int 提升为 float    

    int b = ‘A’ + 32; // char 提升为 int

    double c = 10.3f + 5.7; // float 提升为 double

  1. 化解除法的精度问题

    double b = 1.0 / 2;

  1. 强制类型转换

  (将死范围的多寡赋值给小范围变量时,系统会自动开一个要挟类型转换的操作,这样便于丢精度)

    double a = (double)1 / 2;

    double b = (double)(1 / 2);

    int i = 10.7;  //系统转

    int i = (int) 10.7;  //自己强转

    int a = 198l; // long 转换为 int    

    char b = 65; // int 转换为 char

    int c = 19.5f; // float 转换为 int

 

赋值运算符的结方向是:从右到左,而且事先级比算术运算符低

赋值运算符是所有运算符中除了逗号运算符以外优先级最低的

 

 

从增自减写于头里和后的分别:

  • 设++写于变量的前头,
    那么会先行拿变量自增再就此自增之后的结果与运算
  • 一经++写于变量的后面,
    那么会先行以变量的价值与运算再用变量自增
  • 总结一句话:
    ++在前方, 先自增再运算, ++在晚, 先运算再自增

++a和a++的区别:

  1. 先操作,再使用

    int b = ++a;  //等价于 a=a+1;  b=a;

  1. 先使用,后操作。

    int b = a++; //等价于 b=a;  a=a+1;

  运算规则:先左++,再赋值,最后右++。

 

sizeof()运算符:

sizeof可以为此来算一个变量或者一个常量、一种植多少类所占有的外存字节数。

只顾:sizeof是一个运算符, 不是一个函数

          利用sizeof计算的格式: sizeof(变量/常量/数据类型);

 

sizeof一共有3种形式:

  1. sizeof(变量\常量)
  2. sizeof  变量\常量
  3. sizeof(数据类型)

 

举例:

#include <stdio.h>

int main() {

    char c=’a’;

    printf(“%lu, %lu\n”, sizeof(10), sizeof(c));//4,
1

    printf(“%lu, %lu\n”, sizeof 10, sizeof c);//4,
1

    printf(“%lu\n”, sizeof(int));//4

    return 0;

}

 

逗号运算符和逗号表达式

  1. 逗号运算符主要用来连接表达式

    例如:a=a+1,b=3*4

  1. 之所以逗号运算符连接起来的表达式称为逗号表达式

        它的一般式也:表达式1,表达式2,… …,表达式n

    逗号表达式的运算过程是:先算表达式1,再算表达式2,依次算到发挥式n

    整个逗号表达式的值是终极一个表达式的价值

//逗号运算符

#include <stdio.h>

//逗号运算符类似于加减乘除运算符,逗号运算符取最后一个表达式的价。

int main(){

    int num,num1;

    num=4,7; //逗号运算符的先级低于赋值运算符

    num1=(4,7); //提高逗号运算符的优先级,先逗号运算,再赋值运算

    printf(“num=%d num1=%d\n”,num,num1);
// num=4 num1=7

    return 0;

}

 

干运算符

<    小于运算符

<=  小于等于运算符

>    大于运算符

>=  大于等于运算符

==   等于运算符

!=   不顶运算符

  关系运算符的返值就发生星星点点种植, 要么真, 要么假. 1(真)和0(假)

 

动用注意(优先级):

  1. (算术运算符)的预级大于(关系运算符)

如:3+4>8-2;//结果为1; 等价于:(3+4)>(8-2);

  1. 关系运算符的做方向也“从左往右”

如:4>3>2;//结果为0

  1. (<,>,<=,>=)的预先级大于(==,!=)

如:2==3>1;//结果为0; 等价于:2==(3>1);

int a=3>4+7;//结果为0

int b=(3>4)+7;//结果为7

int c=5!=4+2*7>3==10;//结果为0

逻辑运算符

  && 逻辑与 、|| 逻辑或 、! 逻辑非

  利用注意:

  • 若果想判断a的值是否在(3, 5)范围外,千万不克写成3<a<5,因为涉及运算符的整合方向为“从左往右”。比如a也2,它会先算3<a,也尽管是3<2,条件不起,结果为0。再跟5于,即0<5,条件建立,结果吗1。因此 3<a<5的结果为1,条件建立,也就是说当a的值也2不时,a的价值是于(3, 5)范围外的。这明摆着是非正常的。正确的判定方式是:(a>3) && (a<5)
  • 好屡屡连连用逻辑非运算符:!(4>2)结果为0,是”假”,!!(4>2)结果为1,是”真”,!!!(4>2)结果为0,是“假”
  • C语言规定:任何非0值都也“真”,只有0才为“假”。因此逻辑与为适用于数值。  
  • 比如:
    • 5 && 4的结果是1,为“真”;-6
      && 0的结果是0,为“假”。
    • 5 || 4的结果是1,为“真”;-6
      || 0的结果是1,为“真”;0 || 0的结果是0,为“假”。
    • !5、!6.7、!-9底结果都也0,!0的结果吧1。

  && 和 ||
都备短路特征:

  如果前方一个表达式能控制最终结果虽然免见面精打细算后一个表达式!

#include <stdio.h>

int main() {

    //逻辑运算符&&和||的短路特征

    int a=3,b=4,c=5,r;

    r=(a>b)&&(++b>c);

    printf("%d,%d,%d,%d\n", a, b, c, r);//3, 4, 5, 0

    r=(a<b++)||(b<c++);

    printf("%d,%d,%d,%d\n", a, b, c, r);//3, 5, 5, 1

    

    //非短路的逻辑运算符&和|

    a=3;b=4;c=5;

    r=(a>b)&(b>++c);

    printf("%d,%d,%d,%d\n", a, b, c, r);//3, 4, 6, 0

    r=(a<b)|(b<c++);

    printf("%d,%d,%d,%d\n", a, b, c, r);//3, 4, 7, 1

    return 0;

}

优先级: 

  逻辑运算符的事先级依次为:
小括声泪俱下()
> 负号 – > ! > 算术运算符 >
关系运算符 > && >
||

 条件运算符(三目运算符 ” ? :
“):表达式1?表达式2:表达式3

要是表达式1吧实在,三观运算符的演算结果吧达式2的价,否则也发挥式3的值

单目运算符:操作数只出一个(-1;)

目运算符:操作数有点儿个(1 – 2;)

其三收看运算符:操作数有三独(5 > 4 ? 1 : 0)

 

当我们不确定某些运算符的先级的早晚,可以采取() 来明确预级

图片 2