一个字节包含8位, 第一位是符号位, 8位就可以是代码27次方, 所以范围为-2^7 ~ 2^7 - 1, 即-128到+127;

  一个字节包含8位,八位转化为二进制位11111111,此时的值为FF,或者00000000,值为00; 其中十进制的0-127也就是十六进制的00-7E,代表了ascll的英文码表,就是说英文只要一个字节就能够表示清楚....

  各种数据类型:

    byte类型就是1个字节,能够代表的范围为-2^7 ~ 2^7 - 1;

    short类型为2个字节,能够代表的范围为-2^16 ~ 2^16 - 1;

    int类型为4个字节,能够代表的范围为-2^31 ~ 2^31 - 1;

    long类型为8个字节,能够代表的范围为-2^64 ~ 2^64 - 1;

    flaot的类型也为4字节, 但是它的范围比int大得多(​​来自百度知道​​:位符号位+8位指数(q)+23位底数(b),其解释出来的形式是:b^q,由于指数q是8位有符号整数,范围是-128 ~ 127,23位的底数(无符号)最大值就是2 ^ 23,算上指数的话,最大可以表达到2 ^ 23 ^ 127,但是由于计算机的运算能力限制,并不能处理到如此大的数,但是其取值范围也会比32位整数大很多。 由于float类型是一个幂计算式,所以很多时候并不能表达一个精确值,例如0.1,如果使用float在内存中会被表示为0.10000000000000001,如果进行反复计算将会导致非常大的误);

    double类型也为8个字节;

  移位运算, 有符号左移"<<":

public class Test {
public static void main(String args[]) {
System.out.println( 10<<1 ); //相当于: 10*2
System.out.println( 10<<2 ); //相当于:10*2^2
System.out.println( 10<<3 ); //相当于:10*2^3
System.out.println( 10<<4 ); //相当于:10*2^4
}
}

//输出:

  20
  40
  80
  160

  

作者: ​​NONO

  有符号右移动">>":

public class Test {
public static void main(String args[]) {
int num = 160;
System.out.println( num>>1 );
System.out.println( num>>2 );
System.out.println( num>>3 );
System.out.println( num>>4 );
}
}
//输出:
80
40
20
10

   >>>:无符号右移,忽略符号位,空位都以0补齐;

   无符号右移有个特性必须记住,因为在二进制中:负数的值正数的取反+1 ,当我们对一个负数进行无符号右移, 那么无符号右移的值将会非常大:

public class Test {
public static void main(String args[]) {
int num = -1;
System.out.println( num>>>1 );
}
}
//输出:2147483647

 

  ~:按位取反;

  &:按位且;

  |:按位或;

  ^:按位异或;

  但是这些玩意儿有什么用呢, 参考如下的js代码,

(!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]]

  会输出:"sb"

 

  或者这样装逼...

((""[~+[]]++)+"")[(+[])]+(!+[]+{})[(~((~+[]+~+[])<<(-(~+[]))))]

  会输出:"Ne"

 

  进制之间的转化参考, ​​进制参考​​:

  10进制到2进制:

  

软件开发数据类型基础_进制

      

软件开发数据类型基础_Test_02

  2进制到10进制:

软件开发数据类型基础_Test_03

      

软件开发数据类型基础_Test_04

 

  

作者: ​​NONO

天道酬勤