1.一个变量可以声明为final,这样做的目的是阻止它的内容被修改。这意味着在声明final 变量的时候,你必须初始化它(在这种用法上,final类似于C/C++中的const)。
例如:
final int FILE_NEW = 1;
final int FILE_OPEN = 2;
final int FILE_SAVE = 3;
final int FILE_SAVEAS = 4;
final int FILE_QUIT = 5;
你的程序的随后部分现在可以使用 FILE_OPEN等等,就好像它们是常数,不必担心 它们的值会被改变。 为final变量的所有的字符选择大写是一个普遍的编码约定。声明为final的变量在实例 中不占用内存。这样,一个final变量实质上是一个常数。 关键字final也可以被应用于方法,但是它的意思和它被用于变量实质上是不同的。
2.介绍嵌套类和内部类[个人理解主要是用于解析JSON数据结构]
在另一个类中定义的类就是嵌套类(nested classes)。嵌套类的范围由装入它的类的范 围限制。这样,如果类B被定义在类A之内,那么B为A所知,然而不被A的外面所知。嵌套 类可以访问嵌套它的类的成员,包括private成员。但是,包围类不能访问嵌套类的成员。 嵌套类一般有2种类型:前面加static标识符的和不加static标识符的。一个static的嵌套 类有static修饰符。因为它是static,所以只能通过对象来访问它包围类的成员。也就是说, 它不能直接引用它包围类的成员。因为有这个限制,所以static嵌套类很少使用。 嵌套类最重要的类型是内部类(inner class)。内部类是非static的嵌套类。它可以访问 它的外部类的所有变量和方法,它可以直接引用它们,就像外部类中的其他非static成员的 功能一样。这样,一个内部类完全在它的包围类的范围之内。
3.继承中使用final(类似密封类seal,不能被重写)
Final关键字有三个用途。第一,它可以用来创建一个已命名常量的等价物。这个用法 在前面的章节中已有描述。Final的其他两个用法是应用于继承的,这两种用法都会在下面 阐述。 8.8.1 使用final阻止重载 尽管方法重载是Java的一个最强大的特性,有些时候你希望防止它的发生。不接受方 法被重载,在方法前定义final修饰符。声明成final的方法不能被重载。下面的程序段阐述
了final的用法:
class A
{
final void meth()
{ System.out.println("This is a final method.");}
} class B extends A { void meth() { // ERROR! Can't override. System.out.println("Illegal!"); } }
因为meth( )被声明成final,它不能被B重载,如果你试图这样做,将会生成一个编译时 错误。 定义成final的方法有时可以提高程序性能:编译器可以自由的内嵌调用final方法因为 它知道这些方法不能被子类重载。当一个小的final函数被调用,通常Java编译器可以通过调 用方法的编译代码直接内嵌来备份子程序的字节码,这样减小了与方法调用有关的昂贵开 销。内嵌仅仅是final方法的一个可选项。通常,Java在运行时动态的调用方法,这叫做后期 绑定(late binding)。然而既然final方法不能被重载,对方法的调用可以在编译时解决,这 叫做早期绑定(early binding)。
使用final阻止继承 有时你希望防止一个类被继承。做到这点只需在类声明前加final。声明一个final类含 蓄的宣告了它的所有方法也都是final。你可能会想到,声明一个既是abstract的又是final的 类是不合法的,因为抽象类本身是不完整的,它依靠它的子类提供完整的实现。 下面是一个final类的例子: final class A { // ... } // The following class is illegal. class B extends A { // ERROR! Can't subclass A // ... } 像注释暗示的,B继承A是不合法的,因为A声明成final。
4.java中的Package 类似于C#中的namespace 一个包类似一个程序集的作用
import pk1.pk11.classname ->using namespace.subnamespace.classname
5.interface 默认修饰符为:public
6.继承 extends 实现接口:implents
7.局部实现 如果一个类包含一个接口但是不完全实现接口定义的方法,那么该类必须定义成 abstract型
abstract class Incomplete implements Callback { int a, b; void show() { System.out.println(a + " " + b); } // ... }
这里,类Incomplete没有实现callback( )方法,必须定义成抽象类。任何继承Incomplete 的类都必须实现callback( )方法或者它自己定义成abstract类。
8.Java的内置异常
9.instanceof 类型判断
10.JAVA的本机方法,有点类似于C#的 external 方法【本地方法的编写是利用JNI来实现的,区别于特定的平台】