1.byte值的问题:
byte b1=127;
byte b2=(byte)128; //-128
byte b3=(byte)129; //-127
byte b4=(byte)130; //-126
byte的范围:-128 ~ 127,
128:10000000
-128:10000000(这里1既是符号位,也是数值位)。
2.数据类型转换之默认转换:
只要参与运算就会被提升为int。
byte、short、char -- int -- long -- float -- double,
long:8字节,float:4字节。
它们的底层存储结构不同,浮点数转成小数的二进制去运算,
17.625换算成二进制10001.101,
整数部分,除以2,直至商为0,余数反转,
小数部分,乘以2,直至乘为0,进位顺序取。
在将10001.101右移,直至小数点签只剩1位,1.0001101*2^4,因为右移了四位。
float表示的数据范围比long的范围要大,
long,2^63-1,
float,3.4*10^38 > 2*10^38 > 2*8^38 > 2*2^3^38 = 2*2^114 > 2^63-1。
Java语言中的字符char可以存储一个中文汉字,因为Java语言中字符占两个字节,
Java采用的是Unicode编码。
3.运算符:
运算符是对常量和变量进行操作的符号。
分类,算术运算符、赋值运算符、比较运算符、逻辑运算符、位运算符、三目运算符。
整数相除只能得到整数,要得到小数,只需要将操作的数据中任意一个数据变为浮点数。
x*1.0/y,既不改变数值,又能得到浮点数。
++、--运算符的使用,
单独使用,放在操作数前后效果一样,
参与运算使用,放在操作数前,先自增自减,再参与运算,放在操作数后,先参与运算,再自增自减。
int x=4; int y=(x++)+(++x)+(x*10); 4+6+60=70。
字符串连接符(+),
System.out.println("hello"+'a'+1); //helloa1
System.out.println('a'+1+"hello"); //98hello
扩展的赋值运算符其实隐含了强制类型转换,s+=1;是不等价于s=s+1;的,
而是等价于s=(s的数据类型)(s+1);。
&前后是数字,做位运算、前后是布尔值,做逻辑运算,其它同理。
&逻辑与,|逻辑或,^逻辑异或,!逻辑非。
&&相比&具有短路作用,左边是false,右边不执行,所以程序执行效率高于&,||与|同理。
位运算符,&(有0则0)、|(有1则1)、^(同则0不同则1)、~(按位取反),<<、>>、>>>。
交换两个变量的值,
用位异或实现,a=a^b; b=a^b; a=a^b; ,
用变量相加实现,a=a+b; b=a-b; a=a-b; ,
一句话搞定,b=(a+b)-(a=b); 。
位移运算符,
<<左移,左边最高位丢弃,右边补齐0,
>>右移,最高位是0,左边补齐0,;最高位是1,左边补齐1,
>>>无符号右移,无论最高位左边是0还是1,左边补齐0。
<<,把<<左边的数据乘以2的移动次幂,>>,把>>左边的数据除以2的移动次幂,
最有效率的2*16的方式,即2<<4。
单目运算符(~3),双目运算符(3+4),
三目运算符,比较表达式?表达式1:表达式2,返回true,执行表达式1,返回false,执行表达式2。
三个数比较大小,一步搞定,
int max=(a>b)?((a>c)?a:c):((b>c)?b:c); ,
boolean flag=(m==n)?true:false; 比较两数是否相同。
4.键盘录入:
导包,import java.util.Scanner;
创建键盘录入对象,Scanner sc=new Scanner(System.in);
通过对象获取数据,int x=sc.nextInt(); 。
5.流程控制语句:
流程控制语句分3类,顺序结构、选择结构、循环结构。