以下是java基础总结,java语言的基本结构:
1.每个java程序可以包含多个类的定义,但是只能有一个类是public的,而且java源文件必须以其中public类型的类的名字命名。
2.关于包的引入:(1)尽管包名中的“.”,能够体现各个包中间的层次结构,但是每个包是独立的,顶层包并不包含子包中的类。(2)package和import的顺序是固定的,package语句必须位于第一行。
3.java语言要求java源文件的存放路径与文件中声明的包名存在对应的关系。例如,Monkey.java中的Monkey类位于hgs.angel包中,与此对应,Monkey.java文件位于src目录的hgs/angel子目录下 .
4.方法覆盖与方法重载:(1)覆盖要求参数签名必须一致,方法重载要求参数签名必须不一样(2)方法覆盖要求返回类型必须一致, 方法重载对此没有要求 (3)方法覆盖对方法的访问级别及抛出的异常有特殊的要求.
5.多态 (1)对于一个引用类型的变量, java编译器按照它声明的类型进行处理. 例如: Base who=new Sub(); who.subVar; who.subMethod()使用子类的属性和方法都会出错. (2)对于一个引用类型的对象, java虚拟机按照它实际指向对象的类型来进行处理. Creature c=new Dog(); Animal a=(Animal)c;//正常, c指向的其实是Dog对象 Dog d=(Dog)c;//正常 Cat cat=(Cat)c;//Dog对象不能转换为Cat对象. (3)综合1,2, java语言允许某个类型的引用变量引用子类的实例,且可以对这个引用对象进行类型转换(见(2), 按照实际指向对象类型判断). (4)绑定规则: ●实例方法与实际引用对象的实例方法绑定; ●静态方法与声明类型的静态方法绑定; ●变量(成员/静态)与声明类型的变量绑定.
6.== & equal: ==两边都是引用对象时, 必须引用同一个对象, 结果才是true; ●Object的equal()与==的比较一样, ●JDK库中,一些类覆盖了Object的方法, 如果两个对象类型一致, 并且内容一致, 就是true.
7.一个类的实例, 可以看做是直接父类和间接父类的实例. m instanceof Object 必定为true.
8.abstract ●修饰类, 表示抽象类, 不能被实例化; 修饰方法, 表示抽象方法, 不提供具体的实现. ●抽象类中可以没有抽象方法, 但是抽象方法中一定有抽象类 ●抽象类不能被实例化, 但是可以创建一个引用, 引用非抽象子类的实例对象. ●abstract 和 static是冤家
9. final ●final类不允许有子类, 方法不能被覆盖, 类不会再被扩展; ●final方法不允许被子类方法覆盖; ●final变量表示常量, 只允许被赋值一次.
10.static ●static修饰变量, 静态变量; ●static修饰方法, 静态方法; ●static修饰的程序代码块, 静态代码块, 当java虚拟机加载类时, 就会执行该代码块.
11.static变量 ●java虚拟机加载类时, 会给静态变量分配内存, 只会分配一次内存, 每个静态变量在内存中只有一份 ●对于实例变量, 每次创建一个实例, 就会分配一次内存, 实例变量可以在内存中有多个备份, 互不影响.
12.static方法 ●由于静态方法能够不通过它所属的类的实例直接调用, 因此, 静态方法不能使用当前对象的引用的关键字this, 不能直接访问所属类的实例变量和实例方法, 只能直接访问所属类的静态变量和静态方法. ●实例方法能够访问实例方法, 实例变量, 静态方法,静态变量.
13.static代码块:类中可以包含静态代码块, 它不会存在于任何方法体中, java虚拟机在加载类的时候按照他们在类中出现的顺序依次执行它们.
14.java允许在一个构造方法中,用this调用另一个构造方法, 但必须遵循以下规则: ●this语句必须作为构造方法的第一条语句; ●只能通过this来调用其他的构造函数.
15.默认构造方法: 没有参数的构造方法. 如果一个类显示的定义了一个或者多个构造函数, 带参, 那么这个类就失去���默认的构造方法.
16.子类构造函数调用父类构造函数: ●只能通过super来进行调用 ●调用语句必须放在构造方法中的第一条语句.
17.finalize():程序不能完全依赖对象的finalize()方法来完成收尾工作,而应该在哪学确信能执行的方法中完成收尾工作. 通过编程影响垃圾回收虽然程序员无法控制JVM的垃圾回收机制。但是可以通过编程的手段来影响,影响的方法是,让对象符合垃圾回收条件。分别说来有一下几种:●将无用对象赋值为null。●重新为引用变量赋值。比如:Person p = new Person("aaa");p = new Person("bbb");这样,new Person("aaa")这个对象就是垃圾了----符合垃圾回收条件了。●让相互联系的对象称为“岛”对象Person p1 = new Person("aaa");Person p2 = new Person("bbb");Person p3 = new Person("ccc");p1=p2; p2=p3; p3=p1;p1=null; p2=null; p3=null;在没有对p1、p2、p3置null之前,它们之间是一种三角恋关系。分别置null,三角恋关系依然存在,但是三个变量不在使用它们了。三个Person对象就组成了一个孤岛,最后死在堆上----被垃圾回收掉。●强制的垃圾回收System.gc(), Runtime.gc()实际上这里的强制,是程序员的意愿、建议,什么时候执行是JVM的垃圾回收器说了算。调用垃圾回收也不一定能保证未使用的对象一定能从内存中删除。唯一能保证的是,当你内存在极少的情况,垃圾回收器在程序抛出OutofMemaryException之前运行一次。
18.java参数传递的方式:
●传递基本类型: 类型的值 ●传递引用: 传递引用的地址的值, 若在函数中改变了引用的对象就会类似于传值...在Java中对象作为参数传递时,是把对象在内存中的地址拷贝了一份传给了参数.
19.父类默认构造方法的自动调用: 子类的构造方法没有用super()语句显示调用父类的构造方法, 用这样的方法创建子类对象时, java虚拟机会自��先调用父类的默认构造方法. 如果父类没有提供默认的构造方法时, 会出现编译错误.
20.this,super关键字作用:覆盖java语言的默认作用域,使被屏蔽的方法和变量成为可见. ●场合一: 方法中局部变量和类的成员变量同名 ●场合二: 子类某个方法覆盖了父类的方法 场合三: 子类定义了父类同名的成员变量.
21.内部类总结: 成员变量在编译时解析; 成员函数在运行时解析.