廖雪峰Java1-2Java程序基础-3整数运算

1.四则运算规则

        int i =(100 + 200) * (99 -88);//3300
        int n = i + 9;//3309
        //除法结果为整数
        int q = n / 100;//33
        //除数为0时运行将报错
        int x = n / 0;//抛出异常:Exception in thread "main" java.lang.ArithmeticException: / by zero

1.2.++运算和--运算

i++是先访问i然后再自增,而i++则是先自增然后再访问i的值

        int i = 0;
        int a = i++;
        int b = ++i;
        System.out.println(a);//0
        System.out.println(b);//2

1.3.简写的+=和-=

       //取示例1中的n的值
        n += 100;//3409
        n -= 100;//3309
        //取余运算符%
        int m = n % 100;//9

1.4整数运算运算规则

  • 计算结果溢出不报错
  • 计算结果是不正确的
    解决方法:用范围更大的整型。
        int i = Integer.MAX_VALUE;
        System.out.println(i);
        int x = i + 1;
        System.out.println(x);
        long y = (long)i + 1;
        System.out.println(y);

2.移位运算

  • 左移 <<
  • 右移 >>
  • 不带符号右移 >>>
  • byte和short会先转换为int再进行移位
	int n1 = 5;
        String s1 =  Integer.toBinaryString(5);
        System.out.println("5的二进制:"+s1);
        System.out.println();

        int n2 = n1 << 10;//左移10位,在后面加10个0
        String s2 = s1 + "0000000000";//字符串加10个0,得到二进制字符串
        System.out.println(s1+"~对字符串左移10位~"+s2+"\t转化为10进制数:"+Integer.parseInt(s2,2));
        System.out.println("直接左移10位:n2="+n2);
        System.out.println();

        int n3 = n2 >> 11;//右移11位,去掉11个0
        String s3 = "10";//s2=1010000000000去掉后面的11位数
        System.out.println(s2+"~右移10位~"+s3+"\t"+Integer.parseInt(s3,2));
        System.out.println("直接右移11位:n3="+n3);
        System.out.println();

        int n4 = n1 << 29;//最高位是符号,1表示符号,0表示整数
        System.out.println(n1+"直接左移29位:"+n4);
        System.out.println();

        int n5 = n4 >> 29;//保留符号位右移
        String s5 = "10";//s2=1010000000000去掉后面的11位数
        System.out.println(n4+"直接右移29位:"+n5);
        System.out.println();

        int n6 = n4 >>> 29;//无条件右移
        System.out.println(n4+"无条件右移11位:"+n6);

3.位运算

通常2个整数进行位运算,首先按位对齐,依次对每一位进行进行位运算。

3.1位运算 与运算& 2个都为1,结果为1

  • 1 & 1 = 1, 1 & 0 = 0, 0 & 1 = 0,0 & 0 = 0

3.2或运算| 有1个为1,结果为1

  • 1 | 1 = 1, 1 | 0 = 0, 0 | 1 = 0,0 | 0 = 0

3.3亦或运算^不相同结果为1

  • 1 ^ 1 = 0, 1 ^ 0 = 1, 0 ^ 1 = 1,0 | 0 = 0

3.4非运算\~

  • ~ 1 = 0, ~ 0 = 1
        int n1 = 0x03_83_d0_25;
        int n2 = 0x00_00_ff_ff;
        int n3 = n1 & n2;
        int n4 = n1 | n2;
        System.out.println(n3);
        System.out.println(n4);
        System.out.println(Integer.toBinaryString(n1));
        System.out.println(Integer.toBinaryString(n2));
        System.out.println("n1&n2:"+Integer.toBinaryString(n3));
        System.out.println("n1|n2:"+Integer.toBinaryString(n4));
具体过程参看下图

4.运算优先级


记不住没关系,直接加括号就是

5.类型自动提升与强制转型

  • 在运算过程中,计算结果为较大类型的整型
  • 可以将结果强制转型:(类型)变量或数值。
  • 强制转型可能丢失精度。long类型是64位,强制转为int类型,会将高位抛弃。
        short s = 12;
        int i = 100 +s;
        long n = 999 * i;
        //int x = n - 199;//编译错误
        int y1 = (int)(n - 199);
        int y2 = (int)n - 199;
        int z = (int)(n * 100000000);
        System.out.println(y1);//111689
        System.out.println(y2);//111689
        System.out.println(z);//410193920

6.总结:

  • 整数运算结果永远精确
  • 运算结果会自动提升
  • 可以强制转型,但可能丢失精度
  • 选择合适范围的整型(int, long)
posted on 2019-01-08 23:28  singleSpace  阅读(387)  评论(0编辑  收藏  举报