zhongwang

来源:互联网 发布:java游戏开发有前途 编辑:程序博客网 时间:2024/06/03 10:55

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参数传递的方式: http://hi.baidu.com/mltong2008/blog/item/b73a434b8ec837f783025c38.html ●传递基本类型: 类型的值 ●传递引用: 传递引用的地址的值, 若在函数中改变了引用的对象就会类似于传值...在java中对象作为参数传递时,是把对象在内存中的地址拷贝了一份传给了参数.

19.父类默认构造方法的自动调用: 子类的构造方法没有用super()语句显示调用父类的构造方法, 用这样的方法创建子类对象时, java虚拟机会自动先调用父类的默认构造方法. 如果父类没有提供默认的构造方法时, 会出现编译错误.

20.this,super关键字作用:覆盖java语言的默认作用域,使被屏蔽的方法和变量成为可见. ●场合一: 方法中局部变量和类的成员变量同名 ●场合二: 子类某个方法覆盖了父类的方法 场合三: 子类定义了父类同名的成员变量.

21.内部类总结: http://www.cnblogs.com/jerrychoi/archive/2010/03/12/1684394.html.

22.成员变量在编译时解析; 成员函数在运行时解析.


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
原创粉丝点击