- 累P了~必须早睡了~
通过强制类型转换之后,变量a, b的值分别为( )short a = 128; byte b = (byte) a;
正确答案: B
A 128 127
B 128 -128
C 128 128
D 编译错误java
一、Java中用补码形式表示 二、第一位正负位,1表示负,0表示正。 三、原码:一个数的二进制表示。 3的原码00000011 -3的 原码 10000011 四、反码:负数原码按位取反(符号位不变)。正数原码自己。 3的反码00000011 -3的反码11111100 五、补码:正数是原码自己。负数反码加1。 3的补码是00000011 -3的补码是11111101 ------------------------------------------------------------------------------- int占4个字节,32位 byte占1个字节,8位 因此强转时会截断。前24位 --------------------------------------------------------------------------- 在内存中表示形式( 注意java中是以补码表示一个数,因此表示形式是补码,不是原码! ): int a = 3 00000000 00000000 00000000 00000011 (强转byte时前面24个0被截断) byte b = 3 00000011 int a = -3 11111111 11111111 11111111 11111101 (强转byte时前面24个1被截断) byte b = -3 11111101 ---------------------------------------------------------------------------- 已知负数的补码,求负数: 补码-1=反码,反码按位取反=该负数绝对值 已知负数,求负数的补码: 一、负数原码除了符号位,按位取反(不含符号位),加1。 二、负数绝对值的补码(也就是原码),按位取反(含符号位),加1 ------------------------------------------------------------------------------- 例子: java int 128转为byte,值: 128为正数,补码为10000000(前面24个0省略),变成byte,只剩下10000000(byte为1个字节),由于开头是1,因此为负数。即1个负数的补码是10000000。反码是01111111,原码是1000000。是128.由于是负数,因此是-128。 【已知负数的补码,求负数: 补码-1=反码,反码按位取反=该负数绝对值 】 因此这里的中的1首先只是用来做判断,是正仍是负。 首位为1,因此是负数。因此说明10000000是一个负数的补码。 (为撒连符号位的1也扯进去了?由于符号位不参与转码的前提是给到的是负数的原码,而在这里给到的是补码【128是正数,正数的补码,反码都是其原码】) 根据补码-1=反码,因此获得反码=10000000-1=01111111(反码)---->按位取反获得10000000,也就是128,由于该数是负的,因此最后的结果是-128
考虑下面这个简单的例子,让咱们看看reflection是如何工做的。code
import java.lang.reflect.*; public class DumpMethods{ public static void main(String[] args) { try { Class c=Class.forName(args[0]); Method m[]=c.getDeclaredMethods(); for (int i = 0; i < m.length; i++) { System.out.println(m[i].toString()); } } catch (Throwable e) { System.err.println(e); } } }
其中"c.getDeclaredMethods"的做用是:
正确答案: D
A 取得类的公有方法对象
B 取得类的全部公有方法名称
C 取得类的全部方法对象
D 以上选项都不正确对象
public Method[] getDeclaredMethods()返回类或接口声明的全部方法,包括public, protected, default (package) 访问和private方法的Method对象,但不包括继承的方法。固然也包括它所实现接口的方法。 public Method[] getMethods()返回类的全部public方法,包括其继承类的公用方法,固然也包括它所实现接口的方法