Ⅰ java中為什麼要引入匿名類
java既不支持指針,又不能將方法作為對象傳遞.
匿名類往往被用來實現方法對象(只為回調一個方法而存在的實例).
匿名類多了代碼可讀性大大降低,我們平時會節制使用,通過代理模式,以固定的介面實例代替匿名類.
但當兩個高內聚的模塊之間,進行不特定非同步回調的時候(例如注冊事件),匿名類幾乎是不可規避的.
Ⅱ java匿名內部類具體概念是什麼,在什麼地方用到
java匿名內部類一定是在new的後面,用其隱含實現一個介面或實現一個類,沒有類名,根據多態,我們使用其父類名。因他是局部內部類,那麼局部內部類的所有限制都對其生效。匿名內部類是唯一一種無構造方法類。大部分匿名內部類是用於介面回調用的。匿名內部類在編譯的時候由系統自動起名Out$1.class。如果一個對象編譯時的類型是介面,那麼其運行的類型為實現這個介面的類。因匿名內部類無構造方法,所以其使用范圍非常的有限。當需要多個對象時使用局部內部類,因此局部內部類的應用相對比較多。匿名內部類中不能定義構造方法。如果一個對象編譯時的類型是介面,那麼其運行的類型為實現這個介面的類。
示例如下:
publicclassOuter{
privatestaticinti=1;
privateintj=10;
publicstaticvoidouter_f1(){
}
publicvoidouter_f2(){
}
//靜態內部類可以用public,protected,private修飾
//靜態內部類中可以定義靜態或者非靜態的成員
staticclassInner{
staticintinner_i=100;
intinner_j=200;
staticvoidinner_f1(){
System.out.println("Outer.i"+i);//靜態內部類只能訪問外部類的靜態成員
outer_f1();//包括靜態變數和靜態方法
}
voidinner_f2(){
//System.out.println("Outer.i"+j);//靜態內部類不能訪問外部類的非靜態成員
//outer_f2();//包括非靜態變數和非靜態方法
}
}
publicvoidouter_f3(){
//外部類訪問內部類的靜態成員:內部類.靜態成員
System.out.println(Inner.inner_i);
Inner.inner_f1();
//外部類訪問內部類的非靜態成員:實例化內部類即可
Innerinner=newInner();
inner.inner_f2();
}
publicstaticvoidmain(String[]args){
newOuter().outer_f3();
}
}
Ⅲ JAVA匿名類是什麼,怎麼用
匿名類是一種特殊的內部類,它是在一個表達式內部包含一個完整的類定義。
內部類是在一個類的內部嵌套定義的類,它可以是其它類的成員,也可以在一個語句塊的內部定義,還可以在表達式內部匿名定義。
匿名類與其他類的不同就在於匿名,也就是沒有名稱。
Java中允許創建子類對象時,除了使用父類的構造方法外,還可以用類體。 匿名類就是一個沒有類申明的類體,因為沒有名稱,所有匿名類不可以申明對象,但卻可以創建對象。 例如:
A是一個子類,那麼下面的代碼就是A的一個子類(匿名類)創建對象。
new A(){
匿名類的類體
};
由於匿名類是一個子類,所以和有一般子類的特徵。可以繼承父類的方法,同樣也可以重寫父類的方法。值得提醒的是,在使用匿名類時,一定是在某個類中直接用匿名類創建對象,因此匿名類必定是內部類,所以和其他匿名類一樣可以訪問外嵌類中的成員變數和方法,匿名類的類體中不可以什麼。
static成員變數和static方法。
盡管匿名類沒有申明的步驟,但可以在創建匿名對象時返回一個引用賦值給匹配參數。 匿名類的常用方式是向方法的參數傳值。
具體方法如下:
abstractclassSpeak{
publicabstractvoidspeakHello();
}
classStudent{
voidf(Speaksp){
sp.speakHello();
}
}
publicclassAnonymousClassDemo{
publicstaticvoidmain(String[]args){
Speakspeak=newSpeak(){
publicvoidspeakHello(){
System.out.println("大家好,祝工作愉快!");
}
};
speak.speakHello();
Studentst=newStudent();
st.f(newSpeak(){
publicvoidspeakHello(){
System.out.println("Iamastudent,howareyou");
}
});
}
}
上面代碼的抽象類改成介面同樣適用。
Ⅳ JAVA中局部內部類和匿名內部類的特點和作用是什麼
Java 內部類
分四種:成員內部類、局部內部類、靜態內部類和匿名內部類。
1、成員內部類: 即作為外部類的一個成員存在,與外部類的屬性、方法並列。
注意:成員內部類中不能定義靜態變數,但可以訪問外部類的所有成員。
public class Outer{
private static int i = 1;
private int j=10;
private int k=20;
public static void outer_f1(){
//do more something
}
public void out_f2(){
//do more something
}
//成員內部類
class Inner{
//static int inner_i =100; //內部類中不允許定義靜態變數
int j=100;//內部類中外部類的實例變數可以共存
int inner_i=1;
void inner_f1(){
System.out.println(i);//外部類的變數如果和內部類的變數沒有同名的,則可以直接用變數名訪問外部類的變數
System.out.println(j);//在內部類中訪問內部類自己的變數直接用變數名
System.out.println(this.j);//也可以在內部類中用"this.變數名"來訪問內部類變數
//訪問外部類中與內部類同名的實例變數可用"外部類名.this.變數名"。
System.out.println(k);//外部類的變數如果和內部類的變數沒有同名的,則可以直接用變數名訪問外部類的變數
outer_f1();
outer_f2();
}
}
//外部類的非靜態方法訪問成員內部類
public void outer_f3(){
Inner inner = new Inner();
inner.inner_f1();
}
//外部類的靜態方法訪問成員內部類,與在外部類外部訪問成員內部類一樣
public static void outer_f4(){
//step1 建立外部類對象
Outer out = new Outer();
//***step2 根據外部類對象建立內部類對象***
Inner inner=out.new Inner();
//step3 訪問內部類的方法
inner.inner_f1();
}
public static void main(String[] args){
outer_f4();
}
}
成員內部類的優點:
⑴ 內部類作為外部類的成員,可以訪問外部類的私有成員或屬性。(即使將外部類聲明為PRIVATE,但是對於處於其內部的內部類還是可見的。)
⑵ 用內部類定義在外部類中不可訪問的屬性。這樣就在外部類中實現了比外部類的private還要小的訪問許可權。
注意:內部類是一個編譯時的概念,一旦編譯成功,就會成為完全不同的兩類。對於一個名為outer的外部類和其內部定義的名為inner的內部類。編譯完成後出現outer.class和outer$inner.class兩類。
2、局部內部類: 即在方法中定義的內部類,與局部變數類似,在局部內部類前不加修飾符public或private,其范圍為定義它的代碼塊。
注意:局部內部類中不可定義靜態變數,可以訪問外部類的局部變數(即方法內的變數),但是變數必須是final的。
public class Outer {
private int s = 100;
private int out_i = 1;
public void f(final int k){
final int s = 200;
int i = 1;
final int j = 10;
class Inner{ //定義在方法內部
int s = 300;//可以定義與外部類同名的變數
//static int m = 20;//不可以定義靜態變數
Inner(int k){
inner_f(k);
}
int inner_i = 100;
void inner_f(int k){
System.out.println(out_i);//如果內部類沒有與外部類同名的變數,在內部類中可以直接訪問外部類的實例變數
System.out.println(k);//*****可以訪問外部類的局部變數(即方法內的變數),但是變數必須是final的*****
// System.out.println(i);
System.out.println(s);//如果內部類中有與外部類同名的變數,直接用變數名訪問的是內部類的變數
System.out.println(this.s);//用"this.變數名" 訪問的也是內部類變數
System.out.println(Outer.this.s);//用外部"外部類類名.this.變數名" 訪問的是外部類變數
}
}
new Inner(k);
}
public static void main(String[] args) {
//訪問局部內部類必須先有外部類對象
Outer out = new Outer();
out.f(3);
}
}
注意:
在類外不可直接生成局部內部類(保證局部內部類對外是不可見的)。要想使用局部內部類時需要生成對象,對象調用方法,在方法中才能調用其局部內部類。通過內部類和介面達到一個強制的弱耦合,用局部內部類來實現介面,並在方法中返回介面類型,使局部內部類不可見,屏蔽實現類的可見性。
3、靜態內部類: 靜態內部類定義在類中,任何方法外,用static定義。
注意:靜態內部類中可以定義靜態或者非靜態的成員
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();
}
}
注意:*******生成(new)一個靜態內部類不需要外部類成員:這是靜態內部類和成員內部類的區別。靜態內部類的對象可以直接生成:
Outer.Inner in=new Outer.Inner();
而不需要通過生成外部類對象來生成。這樣實際上使靜態內部類成為了一個頂級類。靜態內部類不可用private來進行定義。*******
例子:
對於兩個類,擁有相同的方法:
class People
{
run();
}
class Machine{
run();
}
此時有一個robot類:
class Robot extends People implement Machine.
此時run()不可直接實現。
注意:當類與介面(或者是介面與介面)發生方法命名沖突的時候,此時必須使用內部類來實現。用介面不能完全地實現多繼承,用介面配合內部類才能實現真正的多繼承。
4、匿名內部類
匿名內部類是一種特殊的局部內部類,它是通過匿名類實現介面。
IA被定義為介面。
IA I=new IA(){};
匿名內部類的特點:
1,一個類用於繼承其他類或是實現介面,並不需要增加額外的方法,只是對繼承方法的事先或是覆蓋。
2,只是為了獲得一個對象實例,不需要知道其實際類型。
3,類名沒有意義,也就是不需要使用到。
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();
}
}
註:一個匿名內部類一定是在new的後面,用其隱含實現一個介面或實現一個類,沒有類名,根據多態,我們使用其父類名。因他是局部內部類,那麼局部內部類的所有限制都對其生效。匿名內部類是唯一一種無構造方法類。大部分匿名內部類是用於介面回調用的。匿名內部類在編譯的時候由系統自動起名Out$1.class。如果一個對象編譯時的類型是介面,那麼其運行的類型為實現這個介面的類。因匿名內部類無構造方法,所以其使用范圍非常的有限。當需要多個對象時使用局部內部類,因此局部內部類的應用相對比較多。匿名內部類中不能定義構造方法。如果一個對象編譯時的類型是介面,那麼其運行的類型為實現這個介面的類。
________________________________________________________________________________
內部類總結:
1.首先,把內部類作為外部類的一個特殊的成員來看待,因此它有類成員的封閉等級:private ,protected,默認(friendly),public
它有類成員的修飾符: static,final,abstract
2.非靜態內部類nested inner class,內部類隱含有一個外部類的指針this,因此,它可以訪問外部類的一切資源(當然包括private)
外部類訪問內部類的成員,先要取得內部類的對象,並且取決於內部類成員的封裝等級。
非靜態內部類不能包含任何static成員.
3.靜態內部類:static inner class,不再包含外部類的this指針,並且在外部類裝載時初始化.
靜態內部類能包含static或非static成員.
靜態內部類只能訪問外部類static成員.
外部類訪問靜態內部類的成員,循一般類法規。對於static成員,用類名.成員即可訪問,對於非static成員,只能
用對象.成員進行訪問
4.對於方法中的內部類或塊中內部類只能訪問塊中或方法中的final變數。
類成員有兩種static , non-static,同樣內部類也有這兩種
non-static 內部類的實例,必須在外部類的方法中創建或通過外部類的實例來創建(OuterClassInstanceName.new innerClassName(ConstructorParameter)),並且可直接訪問外部類的信息,外部類對象可通過OuterClassName.this來引用
static 內部類的實例, 直接創建即可,沒有對外部類實例的引用。
內部類不管static還是non-static都有對外部類的引用
non-static 內部類不允許有static成員
方法中的內部類只允許訪問方法中的final局部變數和方法的final參數列表,所以說方法中的內部類和內部類沒什麽區別。但方法中的內部類不能在方法以外訪問,方法中不可以有static內部類
匿名內部類如果繼承自介面,必須實現指定介面的方法,且無參數
匿名內部類如果繼承自類,參數必須按父類的構造函數的參數傳遞
Ⅳ Java匿名內部類可以實現介面嗎
匿名內部類可以用於介面上,只要一個類是抽象的或是一個介面,那麼其子類中的方法都可以使用匿名內部類來實現。最常用的情況就是在多線程的困鬧兆實現上,因為汪租要實現多線程必須繼承Thread類或是繼承Runnable介面。
具體示例代碼彎李如下:
interface
Person
{
public
void
eat();
}
public
class
Demo
{
public
static
void
main(String[]
args)
{
Person
p
=
new
Person()
{
public
void
eat()
{
System.out.println("eat
something");
}
};
p.eat();
}
}
運行結果:eat
something
Ⅵ java中 介面不是不能實例化嗎,為什麼匿名內部類中用new實例化了呢,比如下面代碼
new ActionListener() 是創建一個繼承自ActionListener的匿名類對象,通過new表達式返回的專引用自動向上轉型為對ActionListener的引用。因為屬匿名類本身無名,也就不存在構造方法,需要顯式調用父類的構造方法,並重寫父類的方法。
Ⅶ java中介面是不能new的,當new一個介面的時候,那麼這個就是一個實現該介面的匿名類,這么理解
對,當一個對罩遲象只需要使用一次時,就new匿名對象。當只需要用這個類的靜態方法時做清,物胡李定義一個匿名類就好。
Ⅷ Java匿名內部類怎樣創建有何作用和優點創建線程怎樣使用匿名內部類
1、匿名內部類就是沒有名字的內部類。這是Java為了方便我們編寫程序而設計的一個機制。因為有時候有的內部類只需要創建一個如褲它的對象就可以了,以後再不會用到這個類,這時候使用匿名內部類就比較合適,而且也免橡手去了給它取名字的煩惱。x0dx0ax0dx0a2、如果滿足下面的一些條件,使用匿名內部類是比較合適的: x0dx0a·只用到類的一個實例。 x0dx0a·類在定義後馬上用到。 x0dx0a·類非常小(SUN推薦是在4行代碼以下) x0dx0a·給類命名並不會導致你的代碼更容易被理解。 x0dx0a在使用匿名內部類時,梁橡嫌要記住以下幾個原則: x0dx0a·匿名內部類不能有構造方法。 x0dx0a·匿名內部類不能定義任何靜態成員、方法和類。 x0dx0a·匿名內部類不能是public,protected,private,static。 x0dx0a·只能創建匿名內部類的一個實例。 x0dx0a·一個匿名內部類一定是在new的後面,用其隱含實現一個介面或實現一個類。 x0dx0a·因匿名內部類為局部內部類,所以局部內部類的所有限制都對其生效。 x0dx0ax0dx0a3、用匿名內部類創建多線程有兩種方式,和創建一個線程是一樣的。x0dx0a第①種繼承Thread:x0dx0anew Thread(){x0dx0apublic void run(){x0dx0a//do somethingx0dx0a};x0dx0a}.start();x0dx0ax0dx0a第②種實現 Runnable介面:x0dx0anew Thread(new Runnable() {x0dx0apublic void run() {x0dx0a //do somethingx0dx0a};x0dx0a}) { }.start();
Ⅸ 請問JAVA中匿名內部類有什麼用,舉個例子,謝謝
內部類允許一個類定胡信配義被放到另一個類定義里。內部類是一個有用的特徵,因為它們允許將邏輯上同屬性的類組合到一起,並在另一個類中控制一個類的可視性。內部類可以訪問外部類的屬性和方法。你可以把內部類看作"方法"一樣,在使用的時候調用執行。你也可以把內部類看作"屬性"一樣,在構造內部類對象的時候,也會在堆里為內部類的屬性分配存儲空間。所以內部類也有類似像修飾屬性,方法那樣的修飾符,比如:public,private,static 等等。當一個類沒有用static 關鍵字修飾的時候,這個內部類就叫做成員類,類似屬性,方法,作為類的成員。 內部類的特點總結:
兩個或兩個以上坦敬的類邏輯上緊密相連的時候,我們可以考慮使用內部類。如果你不需要內部類對象與其外圍類對象之間有聯系,那你可以將褲指內部類聲明為static。這通常稱為嵌套類(nested class)。想要理解static應用於內部類時的含義,你就必須記住,普通的內部類對象隱含地保存了一個引用,指向創建它的外圍類對象。然而,當內部類是static的時,就不是這樣了。嵌套類意味著:
1. 要創建嵌套類的對象,並不需要其外圍類的對象。
2. 不能從嵌套類的對象中訪問非靜態的外圍類對象。
Ⅹ java中匿名內部類到底可不可以繼承其他類是否可以實現介面
匿名內部類可以實現介面,但不能繼承其他類,匿名內部答凱類的類型是已經存在的,既然嫌指類型已經存在那就不可能去繼承其他類來改變清者喚類型了