Java注意点

1) 如果对基本数据类型执行算法或按位运算,大家会发现,只要类型比Int小(即char,byte或者short),那么在运算之前,这些值会自动转换成int.

2) 垃圾回收器准备释放对象占用的存储空间,将首先调用其finalize()方法。

3) 序列化的方式是基于类本身的,当类中的属性发生了变化。类的签名就会发生变化。都会对已序列化的对象产生无法恢复的障碍。

4)java 反码,补码,原码

1、反码:
        一个数如果是正,则它的反码与原码相同;
        一个数如果是负,则符号位为1,其余各位是对原码取反;

为了简单起见,我们用1个字节表示一个整数:
       +7的原码为:00000111
       +7的反码为:00000111
       -7的反码为:11111000

2、补码:利用溢出,我们可以将减法变成加法
       对于十进制数,从9得到5可用减法:
       9-4=5    因为4+6=10,我们可以将6作为4的补数
       改写为加法:
       9+6=15(去掉高位1,也就是减10)得到5.

       对于十六进制数,从c到5可用减法:
       c-7=5    因为7+9=16 将9作为7的补数
       改写为加法:
       c+9=15(去掉高位1,也就是减16)得到5.

在计算机中,如果我们用1个字节表示一个数,一个字节有8位,超过8位就进1,在内存中情况为(100000000),进位1被丢弃。

⑴一个数为正,则它的原码、反码、补码相同
⑵一个数为负,刚符号位为1,其余各位是对原码取反,然后整个数加1
                          符号位
+7的补码为                00000111
   -7的补码为                11111000
                                               +1
                                   11111001

+0的补码为                 00000000
-0的补码为                  11111111
                                               +1
                                 100000000(舍掉打头的1)

例题:已知一个负数的补友,将其转换为十进制数

步骤:⑴先对各位取反
           ⑵将其转换为十进制数
           ⑶加上负号,再减去1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值