美文网首页
java基础知识

java基础知识

作者: thdqn | 来源:发表于2019-07-25 16:05 被阅读0次

title: java基础知识
tags: [java基础知识]


位运算符

java种的运算符有 “&”,“|”,“~”,“^”即 “与”、“非”、“或”、“异或”

这几种运算符都需要将判断的字符转换成2进制,

& 且运算符

两个操作数中位数都为1,结果才为1,否则为0
如 int a = 9;
int b = 10;
9的二进制是1001,10是1010,&的结果是1000 即8

| 或运算符

两个位数只要一个为1,结果就是1,否则为0
如 int a = 9;
int b = 10;
9的二进制是1001,10是1010,|的结果是1011 即11

~ 非运算符

如果位数为0,结果是1,如果位数为1,结果是0
如 int a = 9;
9的二进制是1001,~的结果是0110 即6

^ 异或运算符

相对应的位 相同则结果为0,不同则结果为1
如 int a = 9;
int b = 10;
9的二进制是1001,10是1010,^的结果是0011 即3

<< 按位左移运算符

左操作数按位左移右操作数指定的位数。
如 20 << 2
20的二进制补码:0001 0100

>> 按位右移运算符

左操作数按位右移右操作数指定的位数。

一些基础概念

机器数

一个数在计算机中的二进制表示形式,叫做这个数的机器数,机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1
如 1的二进制数计算机字长位8位,二进制就是 0000 0001 , -1就是 1000 0001

真值

因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如上面的有符号数 1000 0001,其最高位1代表负,其真正数值是 -1 而不是形式值129(1000 0001转换成十进制等于129)。所以,为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值。
所以 0000 0001 的真值为 +000 0001 即 1
1000 0001 的真值为 -000 0001 即 -1

原码

原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值. 比如如果是8位二进制:
1的原码 0000 0001
-1的原码 1000 0001
8位二进制的取值范围则是[1111 1111, 0111 1111] 即 [-127, 127]

反码

反码就是将原码除符号位以外的值全部取反,原来是1的变为0,原来是0的变为1
正数的反码是其本身
如1的原码是: 0000 0001
反码是: 0000 0001

如-1的原码是: 1000 0001
反码是: 1111 1110

补码

补码就是在反码的基础上,在二进制数的右端末位加1(逢2进1)
正数的补码就是其本身
如1的原码是: 0000 0001
反码是: 0111 1110
补码是: 0000 0001

如-1的原码是: 1000 0001
反码是: 1111 1110
补码是: 1111 1111

参考连接

移位运算

左移

数值的补码全部往左移动X位,符号位和最高位都舍弃,最低位补0
如 int a = 6;
int b = a << 2;
6的补码: [0000 0000 0000 0000 0000 0000 0000 0110]
结果: [0000 0000 0000 0000 0000 0000 0001 1000] 即24

int a = -6;
int b = a << -6
-6的原码: [1000 0000 0000 0000 0000 0000 0000 0110]
-6的反码: [1111 1111 1111 1111 1111 1111 1111 1001]
-6的补码: [1111 1111 1111 1111 1111 1111 1111 1010]
-6的左移动2位: [1111 1111 1111 1111 1111 1111 1110 1000]
然后将补码转成原码: 先补码的反码再加1
即 [1000 0000 0000 0000 0000 0000 0001 0111] =》 [1000 0000 0000 0000 0000 0000 0001 1000]
结果为 -24
左移n位就相当于乘以2的n次方

右移

数值的补码向右移X位,符号位不变(左边补上符号位)
int a=8
int b=a>> 2
8的原码 [0000 0000 0000 0000 0000 0000 0000 1000]
8向右移动两位 [0000 0000 0000 0000 0000 0000 0000 0010]
结果为 2

int a=-8
int b=a>> 2
-8的原码 [0000 0000 0000 0000 0000 0000 0000 1000]
-8的反码 [1111 1111 1111 1111 1111 1111 1111 0111]
-8的补码 [1111 1111 1111 1111 1111 1111 1111 1000]
-8向右移动两位 [1111 1111 1111 1111 1111 1111 1111 1110]
然后取补码的反码 [1000 0000 0000 0000 0000 0000 0000 0001]
补码的原码 [1000 0000 0000 0000 0000 0000 0000 0010]
结果为 -2

相关文章

  • Android 知识梳理目录 - 好吧,这是一个很"干

    一、Java 知识梳理 Java&Android 基础知识梳理(1) - 注解Java&Android 基础知识梳...

  • java基础知识

    title: java基础知识tags: [java基础知识] 位运算符 java种的运算符有 “&”,“|”,“...

  • Java基础知识整理(一)

    1.Java基础知识体系 2.Java技术体系平台 3.Java语言特点与核心机制 1.Java基础知识体系 2....

  • 大话Java持久层

    基础知识储备: Java SE(Java语言【java.lang】、Java集合框架【java.util】) Ja...

  • Android面试题4

    1 Java基础知识。线程,java虚拟机,内存模型等。2 Android基础知识。官方API,常用控件源码,自定...

  • Java 序列化

    title: Java 序列化categories: 后台开发tags: java 基础知识 必备 Java 序列...

  • Java基础知识脑图总结

    Java基础知识脑图总结

  • Android内存泄漏

    文章包括两部分: (1)java内存泄漏基础知识 (2)Android内存泄漏。 一.Java内存泄漏基础知识 1...

  • Java面试知识点汇总

    1.基础知识 【JAVA】JAVA 中的小知识(补充中...) 【JAVA】private、protected 和...

  • JNI 基础知识

    JNI 基础知识 什么是 JNI ? JNI (Java Native Interface) 是 Java 沟通 ...

网友评论

      本文标题:java基础知识

      本文链接:https://www.haomeiwen.com/subject/juihrctx.html