幾種內部類的***性:
A、內部類仍然是壹個獨立的類,在編譯之後會內部類會被編譯成獨立的.class文件,但是前面冠以外部類的類命和$符號。
B、內部類不能用普通的方式訪問。內部類是外部類的壹個成員,因此內部類可以自由地訪問外部類的成員變量,無論是否是private的。
2、成員內部類:形式如下
class Outer {
class Inner{}
}
編譯上述代碼會產生兩個文件:Outer.class和Outer$Inner.class。
3、方法內部類。
顧名思義,把類放在方法內。
class Outer {
public void doSomething(){
class Inner{
public void seeOuter(){
}
}
}
}
A、方法內部類只能在定義該內部類的方法內實例化,不可以在此方法外對其實例化。
B、方法內部類對象不能使用該內部類所在方法的非final局部變量。
因為方法的局部變量位於棧上,只存在於該方法的生命期內。當壹個方法結束,其棧結構被刪除,局部變量成為歷史。但是該方法結束之後,在方法內創建的內部類對象可能仍然存在於堆中!例如,如果對它的引用被傳遞到其他某些代碼,並存儲在壹個成員變量內。正因為不能保證局部變量的存活期和方法內部類對象的壹樣長,所以內部類對象不能使用它們。
下面是完整的例子:
class Outer {
public void doSomething(){
final int a =10;
class Inner{
public void seeOuter(){
System.out.println(a);
}
}
Inner in = new Inner();
in.seeOuter();
}
public static void main(String[] args) {
Outer out = new Outer();
out.doSomething();
}
}
4、匿名內部類。
顧名思義,沒有名字的內部類。表面上看起來它們似乎有名字,實際那不是它們的名字。
A、繼承式的匿名內部類。
class Car {
public void drive(){
System.out.println("Driving a car!");
}
}
class Test{
public static void main(String[] args) {
Car car = new Car(){
public void drive(){
System.out.println("Driving another car!");
}
};
car.drive();
}
}
結果輸出了:Driving another car! Car引用變量不是引用Car對象,而是Car匿名子類的對象。
B、接口式的匿名內部類。
interface Vehicle {
public void drive();
}
class Test{
public static void main(String[] args) {
Vehicle v = new Vehicle(){
public void drive(){
System.out.println("Driving a car!");
}
};
v.drive();
}
}
上面的代碼很怪,好像是在實例化壹個接口。事實並非如此,接口式的匿名內部類是實現了壹個接口的匿名類。而且只能實現壹個接口。
C、參數式的匿名內部類。
class Bar{
void doStuff(Foo f){}
}
interface Foo{
void foo();
}
class Test{
static void go(){
Bar b = new Bar();
b.doStuff(new Foo(){
public void foo(){
System.out.println("foofy");
}
});
}
}
5、靜態嵌套類。
從技術上講,靜態嵌套類不屬於內部類。因為內部類與外部類***享壹種特殊關系,更確切地說是對實例的***享關系。而靜態嵌套類則沒有上述關系。它只是位置在另壹個類的內部,因此也被稱為頂級嵌套類。
詳細內容請見:/honglin_bd/blog/item/fa60c4d3866f972933fa1c87.html