`

SCJP笔记整理(三)

阅读更多

说明:这是2007年复习SCJP期间的学习笔记(JavaSE 5.0),有部分遗失。现在整理一下发到Blog上,一方面做个备份,另一方面分享出来,希望对需要的人有用。

-----------------------------------------

第三部分        赋值

1、  八进制整数:在前面加一个0,后面是0-7

int six=06; //6

int seven=07; //7

int eight=010; //8

2、  十六进制整数:在前面加一个0x,后面是0-f,最多8位,不区分大小写。

int x=0xffffffff;

3、  十进制、八进制、十六进制整型字面值都默认为int,如果定义为long,需要加L | l

long a=0x0123ffffl

4、  浮点字面值定义为double(64)double d=12345.6789;

转化为32float,要加f | F,否则编译失败:

float f=1234.56 //编译失败。

float f=1234.56F;

5、  char字面值为单引号:char a=’a’;

Unicode表示法: char a=’\u004E’;  //N

char16位无符号整数,范围0-65535

6、  一个占用int或更短表达式的结果总是int.

byte b=6;

byte c=7;

byte d=b+c; //编译失败,int d=b+c;byte d=(byte) (b+c);

7、  数组总是对象,只声明没有初始化的数组将有一个null值。

8、  数组元素总是被赋予默认值,局部变量不会被赋予默认值。

9、  在逻辑条件块中初始化编译器会认为初始化没有发生,则导致编译失败。

局部变量需要显示初始化为null,否则不能通过null检查。

数组被局部声明,则不会被初始化。

10、引用变量的内容是一种位模式,引用变量a 赋给 b,就把a内的位模式的副本赋给b

11、两个变量引用对象的同一个实例,当一个变量修改该实例的属性时,另一个随之修改。但基本类型则不修改。

12、直接声明一个相同名称的局部变量,或者作为参数的一部分声明一个相同名称的局部变量,这两种方法都能够隐藏一个实例变量。

   基本类型的隐藏不影响实例变量,即基本类型的局部变量会被修改但实例变量不会被修改。

   被隐藏的变量是一个对象引用而不是一个基本变量时,隐藏变量会影响到实例变量。但若将隐藏变量重新赋予一个对象,则不会影响实例变量。

13、数组越界(包括负下标访问)会抛出运行时异常,而不是编译错误。

14、匿名数组创建:

int[] array;   array=new int[]{1,2,3,4};

使用匿名数组创建实时数组:

void takeArrays(int[] a){  //此处不限制元素个数。

    //操作数组a

}

调用时:takeArrays(new int[]{1,2,3});   //可以传入任意个元素的数组。

15、基本类型数组可以声明为能够隐式提升为所声明类型的任何值。

16、数组声明为接口类型,该数组元素可以引用实现了声明这种接口的任何实例。

17、初始化块:当第一次加载类(main函数之前)或者创建一个实例时,就会分别运行静态初始化块和实例初始化块。

第一次加载类时(main函数之前),会运行静态初始化块。每创建一个新实例时,会运行一次实例初始化块。

静态初始化块只调用一次,如果有父类则从父类到子类按书写顺序调用。

实例初始化块运行时间在调用构造函数super()之后,即在所有超类构造函数运行之后运行。

18Java5后,boolean测试中可以使用Boolean对象,编译器会自动取消装箱。

19valueOf()----String到包装类型:

      Integer i= Integer.valueOf(“10001”,2);   //二进制化为十进制包装型。

parseXxx()----String到基本类型:

  long b=Long.parseLong(“101001”,2);   //二进制化为十进制基本型。

xxxValue()----包装类型到基本类型:

  Integer i=new Integer(43);

  byte b=i.byteValue();

  short s=i.shortValue();

toString()----包装类型到String

  String s=Double.toString(3.14);

String s=Long.toString(254,16);

//16进制转化254,只有IntegerLong提供该toString方法。

toXxxString()----包装类型到String类型:(Integer\Long有该方法)

  String s=Integer.toHexString(254);  //16为基数(默认是10),s=FE.

  Stirng s=Integer.toOctalString(254);  //8为基数。s=376.

20、自动装箱:创建(new)一个新的包装器对象,然后赋予新值。

21equals()方法用于确定给定类的两个实例是否值等价。

==判断引用等价。

22、为了节省内存,以下包装器对象的两个实例:

Boolean,Byte,Character(\u0000~\u007f),Integer(-128~127)

当他们的基本值相同时总是==的,即使他们来自不同对象引用:

Integer i1=10;

Integer i2=10;

if(i1==i2) {System.out.println(“same object”);}  //此处将打印。

23、隐式加宽:未找到精确匹配时,JVM就会使用一个方法,它带有比形参更宽的最小实参。

void go(int x){

  //……

}

……

byte b=5;

short s=6;

go(b);  //byte隐式加宽为int.

go(s);  //short隐式加宽为int.

24、加宽优于装箱,加宽优于vararg,装箱优于vararg.

25、引用加宽依赖于继承。

26、任何一种包装器都不能加宽到另一种包装器。

27、加宽后再自动装箱操作会导致编译失败,因此代码执行时都先装箱后加宽。(int不能到Longint可以通过IntegerObject)。

   装箱与vararg都可与重载兼容。

   Vararg可以与加宽或装箱结合使用。

28、请求JVM垃圾收集:Runtime rt=Runtime.getRuntime();   rt.gc();

或:System.gc();

29try块内局部变量的作用域只限制在{}中。

30、垃圾回收时类中的实例变量初始化也算做对象。

31、代码中强制转换失败不会导致编译失败,而是抛出ClassCastException.

32、不论先加宽还是先装箱,都是以相同的参数个数先比较,不行最后再用vararg

33、数组变量的引用可以为null

String[] x;

Object[] a=x;  //编译通过。

34final基本类型不能改变值,final对象类型不能改变引用,但不确保不能改变对象属性。

    final基本类型不能改变值,但若有与其同名的隐藏变量的值却可以改变。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics