标签:
知识要点:
用于定义访问权限修饰符的关键字 |
||||
private |
protected |
public |
|
|
用于定义类,函数,变量修饰符的关键字 |
||||
abstract |
final |
static |
synchronized |
|
用于定义类与类之间关系的关键字 |
||||
extends |
implements |
|
|
|
用于定义建立实例及引用实例,判断实例的关键字 |
||||
new |
this |
super |
instanceof |
|
用于异常处理的关键字 |
||||
try |
catch |
finally |
throw |
throws |
用于包的关键字 |
||||
package |
import |
|
|
|
其他修饰符关键字 |
||||
native |
strictfp |
transient |
volatile |
assert |
思考题:在java中为什么 int的范围是-2^31到2^31-1
弄清楚为什么java中Byte类型的取值范围是-128~127 ?也就明白上面的问题了:
Byte占一个字节8位,首位是符号位,最大值为0111 1111即127,关键是这个-128,有人说首位是符号位,那就是剩余的7位表示真值,最大为111 1111,最小为000 0000,那最小即为1000 0000,就是-128,(关键是不是说好首位是符号位了么?怎么负数算真值得时候又把首位1给算进去了?)
(负数)最大 1111 1111 代表的是-1 最小1000 0000 代表的是 -128 这个很难理解嘛?
1111 1111、1000 0000代表的是-1,-128的补码,在内存中,存放的都是补码,不是涉及到负数,负数所谓的补码就是他们绝对值的原码的取反加+1
比如 -1的绝对值是1 1的原码是0000 0001 反码是 1111 1110
反码+1 也就是补码就是 1111 1111
-128的绝对值是 128 原码是 1000 0000 反码是 0111 1111
反码+1 也就是 1000 0000
(补充:)
-128:10000000 (这里的1即是符号位,也是数值位)
|
/*
byte b = 130;有没有问题?如果我想让赋值正确,
可以怎么做?结果是多少呢?
练习:byte b = (byte)300;
*/
class DataTypeDemo7 {
public static void main(String[] args) {
//因为byte的范围是:-128到127。
//而130不在此范围内,所以报错。
//byte b = 130;
//我们可以使用强制类型转换
byte b = (byte) 130;
//结果是多少呢?
System.out.println(b);
}
}
/*
分析过程:
我们要想知道结果是什么,就应该知道是如何进行计算的。
而我们又知道计算机中数据的运算都是补码进行的。
而要得到补码,首先要计算出数据的二进制。
A:获取130这个数据的二进制。
00000000 00000000 00000000 10000010
这是130的原码,也是反码,还是补码。
B:做截取操作,截成byte类型的了。
10000010
这个结果是补码。
C:已知补码求原码。
符号位 数值位
补码: 1 0000010
反码: 1 0000001
原码: 1 1111110 = -126
*/
|
运算符的优先级(从高到低)
优先级 |
描述 |
运算符 |
1 |
括号 |
()、[] |
2 |
正负号 |
+、- |
3 |
自增自减,非 |
++、--、! |
4 |
乘除,取余 |
*、/、% |
5 |
加减 |
+、- |
6 |
移位运算 |
<<、>>、>>> |
7 |
大小关系 |
>、>=、<、<= |
8 |
相等关系 |
==、!= |
9 |
按位与 |
& |
10 |
按位异或 |
^ |
11 |
按位或 |
| |
12 |
逻辑与 |
&& |
13 |
逻辑或 |
|| |
14 |
条件运算 |
?: |
15 |
赋值运算 |
=、+=、-=、*=、/=、%= |
16 |
位赋值运算 |
&=、|=、<<=、>>=、>>>=
|
标签:
原文地址:http://www.cnblogs.com/supoman2015/p/4484642.html