javaSE基础03

生活中常见的进制:
十进制(0-9)、星期(七进制(0-6))、时间(十二进制(0-11))、二十四进制(0-23)

进制之间的转换

十进制转为二进制: 将十进制除以2,直到商为0 ,将余数从下上连接起来就是二进制

10---->1010

二进制转十进制:将二进制的每一位乘以2^n ,n从0开始,n每一次加一,在将结果相加。

1001 ----》  1*2^0 +0*2^1 +0*2^2+1*2^3 = 9

将二进制换为八进制:

方式一:二进制--->十进制--->八进制

方式二:一个八进制相当于三个二进制位,将二进制三位一分割,计算出来

010 100 101 =  245

将二进制换为十六进制 :(0-9)(a(10)-f(15))

0000 1010 0101 = a5

1.2变量:

Java数据类型分为两种:

基本数据类型

Byte (字节) 8位(bit)

2.引用数据类型

String 字符串

变量的声明方式:

  1.数据类型  变量名

  2.数据类型  变量名1,变量名2...

数据类型:

  数据类型的转换

1.自动类型转换

  小数据类型--->大数据类型转换

2.强制类型转换

  大的数据类型 ----> 小的数据类型。

数据类型转换中需要注意的点:

1.凡是short ,byte ,char 定义的变量,在做运算 的时候,数据类型都会自动转换为int

2.两个不同数据类型做运算,给过取决于大的数 据类型。

运算符:

1.1算数运算符:+,-,*,/,%

1.2自增自减 :++ ,--

1.3赋值运算符 : = ,+=,-=,*=,/=

1.4关系运算符 : >,<,>=,<=,== ,!=  (结果只有两种,要么为真,要么为假)

1.5逻辑运算符: & ,| ,! ,&& ,||

Int 在计算机中有32位字节

位运算:只能计算二进制

&(与):两者为1,才是1,其他的为0

|(或):两者为0,才是0,其他的为1

^(异或):相同为0,不同为1

~(取反):将0变1,将1变0

负数的表现形式:二进制位的最高位为1 ,那么这个数就是一个负数

全1为 -1

1111-1111 1111-1111 1111-1111 1111-1111

全0为0

0000-0000 0000-0000 0000-0000 0000-0000

负数由来:负数所对应的正数-1 再取反

负数所对应的正数取反再 +1

比如:int a=6;

Int b=3;

0000-0000 0000-0000 0000-0000 0000-0110

0000-0000 0000-0000 0000-0000 0000-0011

           &

--------------------------------------------------------------------

0000-0000 0000-0000 0000-0000 0000-0010   = 2

0000-0000 0000-0000 0000-0000 0000-0110

0000-0000 0000-0000 0000-0000 0000-0011

           |

-----------------------------------------------------------------------

0000-0000 0000-0000 0000-0000 0000-0111   = 7

位运算:用来对数据进行加密

1.6右移

>> 右移  :右移多少,就需要用移动的数除以2的多少次方

原理: 6>>1

空缺的位自动补0

0000-0000 0000-0000 0000-0000 0000-0110

000-0000 0000-0000 0000-0000 0000-0011  ---> 3

将整体向右移动移位,超出的位就去掉,空缺位就补0,必须是最高 位补0

如果最高位是1,空缺补1

如果最高位是0,空缺位补0

<< 左移 :左移多少位,就用这个数乘以2的多少次方

原理:6 <<1

特点:整体往左移,被移除的最高位丢弃,空缺的位就补0

0000-0000 0000-0000 0000-0000 0000-0110

0000-0000 0000-0000 0000-0000 0000-1100  --->12

>>> 无符号右移

6>>>1的结果和右移是一样的

-6>>>2

1111-1111 1111-1111 1111-1111 1111-1010   ---  -6

0011-1111 1111-1111 1111-1111 1111-1110

无论你的最高位是零还是1,最空缺位都补0

两个数相交换:三种方式

一个数两个相同的^最后结果还是原来的数A。

(B ^ A ) B

05-01 02:24