本文目錄一覽:
java匿名內部類
匿名類是不能有名稱的類,所以沒辦法引用它們。必須在創建時,作為new語句的一部分來聲明它們。這就要採用另一種形式的new語句,如下所示: new 類或介面 類的主體 這種形式的new語句聲明一個新的匿名類,它對一個給定的類進行擴展,或者實現一個給定的介面。它還創建那個類的一個新實例,並把它作為語句的結果而返回。要擴展的類和要實現的介面是new語句的操作數,後跟匿名類的主體。如果匿名類對另一個類進行擴展,它的主體可以訪問類的成員、覆蓋它的方法等等,這和其他任何標準的類都是一樣的。如果匿名類實現了一個介面,它的主體必須實現介面的方法。
java 代碼
interface pr
{
void print1();
}
public class noNameClass
{
public pr dest()
{
return new pr(){
public void print1()
{
System.out.println(“Hello world!!”);
}
};
}
public static void main(String args[])
{
noNameClass c=new noNameClass();
pr hw=c.dest();
hw.print1();
}
}
pr也可以是一個類但是你外部調用的方法必須在你的這個類或介面中聲明外部不能調用匿名類內部的方法
Java中內部匿名類用的最多的地方也許就是在Frame中加入Listner了吧。
如下:
java 代碼
import java.awt.*;
import java.awt.event.*;
public class QFrame extends Frame {
public QFrame() {
this.setTitle(\”my application\”);
addWindowListener(new WindowAdapter() {
public void windowClosing(WindowEvent e) {
dispose();
System.exit(0);
}
});
this.setBounds(10,10,200,200);
}
}
內部匿名類,就是建立一個內部的類,但沒有給你命名,也就是沒有引用實例的變數。
new WindowAdapter() {
public void windowClosing(WindowEvent e) {
dispose();
System.exit(0);
}
}
new 是建立一個 WindowAdapter對象 ,後面一個 {} 表示這個括弧中的操作作用於這個默認的對名象,而上面的Java程序中後面是一個函數體。
這個用法的作用是:創建一個對象的實例,並且 override 它的一個函數。打開 WindowAdapter 的代碼可以發現。它是一個抽象類。它是對 WindowListener 介面的一個實現。Frame.addWindowListner(); 的參數是一個 WindowListner ,而實現上是傳一個從WindowAdapter 派生出的一個匿名類。
1.怎樣判斷一個匿名類的存在啊?看不見名字,感覺只是父類new出一個對象而已,沒有匿名類的名字。
先看段偽代碼
abstract class Father(){
….
}
public class Test{
Father f1 = new Father(){ …. } //這裡就是有個匿名內部類
}
一般來說,new 一個對象時小括弧後應該是分號,也就是new出對象該語句就結束了。
但是出現匿名內部類就不一樣,小括弧後跟的是大括弧,大括弧中是該new 出對象的具體的實現方法。
因為我們知道,一個抽象類是不能直接new 的,必須先有實現類了我們才能new出它的實現類。
上面的偽代碼就是表示new 的是Father的實現類,這個實現類是個匿名內部類。
其實拆分上面的匿名內部類可為
class SonOne extends Father{
… //這裡的代碼和上面匿名內部類,大括弧中的代碼是一樣的
}
public class Test{
Father f1 = new SonOne() ;
}
2.匿名內部類的注意事項
注意匿名類的聲明是在編譯時進行的,實例化在運行時進行。這意味著for循環中的一個new語句會創建相同匿名類的幾個實例,而不是創建幾個不同匿名類的一個實例。
在使用匿名內部類時,要記住以下幾個原則:
·匿名內部類不能有構造方法。
·匿名內部類不能定義任何靜態成員、方法和類。
·匿名內部類不能是public,protected,private,static。
·只能創建匿名內部類的一個實例。
·一個匿名內部類一定是在new的後面,用其隱含實現一個介面或實現一個類。
·因匿名內部類為局部內部類,所以局部內部類的所有限制都對其生效。
·內部類只能訪問外部類的靜態變數或靜態方法。
匿名類和內部類中的中的this :
有時候,我們會用到一些內部類和匿名類。當在匿名類中用this時,這個this則指的是匿名類或內部類本身。這時如果我們要使用外部類的方法和變數的話,則應該加上外部類的類名
3.匿名內部類的作用
Java的內部類和C++中的嵌套類有本質的不同:C++的嵌套類沒有指向包裝類的句柄。僅僅表達一個封裝的概念;但是Java的內部類不同,它可以訪問包裝類的成員(這表示它擁有指向包裝類的句柄)。
匿名內部類是內部類的一種簡化寫法:return new Wrapper {
…
};
等價於:Wrapped extends Wrapper {
…
}
return new Wrapped();
難道匿名內部類就只這一點作用嗎?
考慮一下這樣的case:
interface ICount {
int count();
}
class Parent {
int i = 0;
int count() {
return i++;
}
}
有一個類Child,它既想繼承Parent的count()方法,又想實現ICount介面中的count方法,這個時候怎麼辦呢?內部類就可以大顯身手了:
class Child extends Parent {
ICount getCount() {
return new ICount {
int i = 0;
int count() {
return (i *= 2);
}
}
}
}
至於你說的只有一個方法或者必須有返回值,這個倒是沒有在語法上規定 , 所以應該不存在這一說法。
滿意請採納。
java匿名內部類具體概念是什麼,在什麼地方用到?
java匿名內部類一定是在new的後面,用其隱含實現一個介面或實現一個類,沒有類名,根據多態,我們使用其父類名。因他是局部內部類,那麼局部內部類的所有限制都對其生效。匿名內部類是唯一一種無構造方法類。大部分匿名內部類是用於介面回調用的。匿名內部類在編譯的時候由系統自動起名Out$1.class。如果一個對象編譯時的類型是介面,那麼其運行的類型為實現這個介面的類。因匿名內部類無構造方法,所以其使用範圍非常的有限。當需要多個對象時使用局部內部類,因此局部內部類的應用相對比較多。匿名內部類中不能定義構造方法。如果一個對象編譯時的類型是介面,那麼其運行的類型為實現這個介面的類。
示例如下:
public class Outer {
private static int i = 1;
private int j = 10;
public static void outer_f1(){
}
public void outer_f2(){
}
// 靜態內部類可以用public,protected,private修飾
// 靜態內部類中可以定義靜態或者非靜態的成員
static class Inner{
static int inner_i = 100;
int inner_j = 200;
static void inner_f1(){
System.out.println(“Outer.i”+i);//靜態內部類只能訪問外部類的靜態成員
outer_f1();//包括靜態變數和靜態方法
}
void inner_f2(){
// System.out.println(“Outer.i”+j);//靜態內部類不能訪問外部類的非靜態成員
// outer_f2();//包括非靜態變數和非靜態方法
}
}
public void outer_f3(){
// 外部類訪問內部類的靜態成員:內部類.靜態成員
System.out.println(Inner.inner_i);
Inner.inner_f1();
// 外部類訪問內部類的非靜態成員:實例化內部類即可
Inner inner = new Inner();
inner.inner_f2();
}
public static void main(String[] args) {
new Outer().outer_f3();
}
}
請教java的參數式匿名內部類
匿名內部類
java的匿名內部類的語法規則看上去有些古怪,不過如同匿名數組一樣,當你只需要創建一個類的對象而且用不上它的名字時,使用內部類可以使代碼看上去簡潔清楚。它的語法規則是這樣的:
new interfacename(){……};
或
new superclassname(){……};
下面接著前面繼續舉例子:
public class Goods3 {
public Contents cont(){
return new Contents(){
private int i = 11;
public int value() {
return i;
}
};
}
}
這裡方法cont()使用匿名內部類直接返回了一個實現了介面Contents的類的對象,看上去的確十分簡潔。
在java的事件處理的匿名適配器中,匿名內部類被大量的使用。例如在想關閉窗口時加上這樣一句代碼:
frame.addWindowListener(new WindowAdapter(){
public void windowClosing(WindowEvent e){
System.exit(0);
}
});
有一點需要注意的是,匿名內部類由於沒有名字,所以它沒有構造函數(但是如果這個匿名內部類繼承了一個只含有帶參數構造函數的父類,創建它的時候必須帶上這些參數,並在實現的過程中使用super關鍵字調用相應的內容)。如果你想要初始化它的成員變數,有下面幾種方法:
如果是在一個方法的匿名內部類,可以利用這個方法傳進你想要的參數,不過記住,這些參數必須被聲明為final。
將匿名內部類改造成有名字的局部內部類,這樣它就可以擁有構造函數了。
在這個匿名內部類中使用初始化代碼塊。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/198307.html