国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - 妙解Java中的回調機制(CallBack)

妙解Java中的回調機制(CallBack)

2020-06-01 13:24yaosese JAVA教程

本文以最簡明扼要的例子將Java的回調機制介紹給大家,感興趣的朋友可以參考一下。

前言

最近學習java,接觸到了回調機制(CallBack)。初識時感覺比較混亂,而且在網上搜索到的相關的講解,要么一言帶過,要么說的比較單純的像是給CallBack做了一個定義。當然了,我在理解了回調之后,再去看網上的各種講解,確實沒什么問題。但是,對于初學的我來說,缺了一個循序漸進的過程。

回調是一種雙向調用模式,什么意思呢,就是說,被調用方在被調用時也會調用對方,這就叫回調。“If you call me, i will call back”。

不理解?沒關系,先看看這個可以說比較經典的使用回調的方式:

class A實現接口InA ——背景1

class A中包含一個class B的引用b ——背景2

class B有一個參數為InA的方法test(InA a) ——背景3

A的對象a調用B的方法傳入自己,test(a) ——這一步相當于you call me

然后b就可以在test方法中調用InA的方法 ——這一步相當于i call you back

開始之前,先想象一個場景:幼稚園的小朋友剛剛學習了10以內的加法。

下面,將我對回調機制的個人理解,按照由淺到深的順序描述一下,如有不妥之處,望不吝賜教!

第1章. 故事的緣起

幼師在黑板上寫一個式子 “1 + 1 = ”,由小明同學來填空。

由于已經學習了10以內的加法,小明同學可以完全靠自己來計算這個題目,模擬該過程的代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
public class Student
 {
  private String name = null;
 
  public Student(String name)
  {
   // TODO Auto-generated constructor stub
   this.name = name;
  }
 
  public void setName(String name)
  {
   this.name = name;
  }
 
  private int calcADD(int a, int b)
  {
   return a + b;
  }
 
  public void fillBlank(int a, int b)
  {
   int result = calcADD(a, b);
   System.out.println(name + "心算:" + a + " + " + b + " = " + result);
  }
 }

小明同學在填空(fillBalnk)的時候,直接心算(clacADD)了一下,得出結果是2,并將結果寫在空格里。測試代碼如下:

?
1
2
3
4
5
6
7
8
9
10
public class Test
 {
  public static void main(String[] args)
  {
  int a = 1;
   int b = 1;
   Student s = new Student("小明");
   s.fillBlank(a, b);
  }
 }

運行結果如下:

小明心算:1 + 1 = 2

該過程完全由Student類的實例對象單獨完成,并未涉及回調機制。

第2章. 幼師的找茬

課間,幼師突發奇想在黑板上寫了“168 + 291 = ”讓小明完成,然后回辦公室了。

花擦!為什么所有老師都跟小明過不去啊?明明超綱了好不好!這時候小明同學明顯不能再像上面那樣靠心算來完成了,正在懵逼的時候,班上的小紅同學遞過來一個只能計算加法的計算器(奸商啊)!!!!而小明同學恰好知道怎么用計算器,于是通過計算器計算得到結果并完成了填空。

計算器的代碼為:

?
1
2
3
4
5
6
7
public class Calculator
 {
  public int add(int a, int b)
  {
   return a + b;
  }
 }

修改Student類,添加使用計算器的方法:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public class Student
 {
  private String name = null;
 
  public Student(String name)
  {
   // TODO Auto-generated constructor stub
   this.name = name;
  }
 
  public void setName(String name)
  {
   this.name = name;
  }
 
  @SuppressWarnings("unused")
  private int calcADD(int a, int b)
  {
   return a + b;
  }
 
  private int useCalculator(int a, int b)
  {
   return new Calculator().add(a, b);
  }
 
  public void fillBlank(int a, int b)
  {
   int result = useCalculator(a, b);
   System.out.println(name + "使用計算器:" + a + " + " + b + " = " + result);
  }
 }

測試代碼如下:

?
1
2
3
4
5
6
7
8
9
10
public class Test
 {
  public static void main(String[] args)
  {
   int a = 168;
   int b = 291;
   Student s = new Student("小明");
   s.fillBlank(a, b);
  }
 }

運行結果如下:

小明使用計算器:168 + 291 = 459

該過程中仍未涉及到回調機制,但是部分小明的部分工作已經實現了轉移,由計算器來協助實現。

3. 幼師回來了

發現小明完成了3位數的加法,老師覺得小明很聰明,是個可塑之才。于是又在黑板上寫下了“26549 + 16487 = ”,讓小明上課之前完成填空,然后又回辦公室了。

小明看著教室外面撒歡兒的小伙伴,不禁悲從中來。再不出去玩,這個課間就要廢了啊!!!! 看著小紅再一次遞上來的計算器,小明心生一計:讓小紅代勞。

小明告訴小紅題目是“26549 + 16487 = ”,然后指出填寫結果的具體位置,然后就出去快樂的玩耍了。

這里,不把小紅單獨實現出來,而是把這個只能算加法的計算器和小紅看成一個整體,一個會算結果還會填空的超級計算器。這個超級計算器需要傳的參數是兩個加數和要填空的位置,而這些內容需要小明提前告知,也就是小明要把自己的一部分方法暴漏給小紅,最簡單的方法就是把自己的引用和兩個加數一塊告訴小紅。

因此,超級計算器的add方法應該包含兩個操作數和小明自身的引用,代碼如下:

?
1
2
3
4
5
6
7
8
public class SuperCalculator
 {
  public void add(int a, int b, Student xiaoming)
  {
   int result = a + b;
   xiaoming.fillBlank(a, b, result);
  }
 }

小明這邊現在已經不需要心算,也不需要使用計算器了,因此只需要有一個方法可以向小紅尋求幫助就行了,代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
public class Student
 {
  private String name = null;
 
  public Student(String name)
  {
   // TODO Auto-generated constructor stub
   this.name = name;
  }
 
  public void setName(String name)
  {
   this.name = name;
  }
 
  public void callHelp (int a, int b)
  {
   new SuperCalculator().add(a, b, this);
  }
 
  public void fillBlank(int a, int b, int result)
  {
   System.out.println(name + "求助小紅計算:" + a + " + " + b + " = " + result);
  }
 }

測試代碼如下:

?
1
2
3
4
5
6
7
8
9
10
public class Test
 {
  public static void main(String[] args)
  {
   int a = 26549;
   int b = 16487;
   Student s = new Student("小明");
   s.callHelp(a, b);
  }
 }

運行結果為:

小明求助小紅計算:26549 + 16487 = 43036

執行流程為:小明通過自身的callHelp方法調用了小紅(new SuperCalculator())的add方法,在調用的時候將自身的引用(this)當做參數一并傳入,小紅在使用計算器得出結果之后,回調了小明的fillBlank方法,將結果填在了黑板上的空格里。

燈燈燈!到這里,回調功能就正式登場了,小明的fillBlank方法就是我們常說的回調函數。

通過這種方式,可以很明顯的看出,對于完成老師的填空題這個任務上,小明已經不需要等待到加法做完且結果填寫在黑板上才能去跟小伙伴們撒歡了,填空這個工作由超級計算器小紅來做了。回調的優勢已經開始體現了。

第4章. 門口的婆婆

幼稚園的門口有一個頭發花白的老婆婆,每天風雨無阻在那里擺著地攤賣一些快過期的垃圾食品。由于年紀大了,腦子有些糊涂,經常算不清楚自己掙了多少錢。有一天,她無意間聽到了小明跟小伙伴們吹噓自己如何在小紅的幫助下與幼師斗智斗勇。于是,婆婆決定找到小紅牌超級計算器來做自己的小幫手,并提供一包衛龍辣條作為報酬。小紅經不住誘惑,答應了。

回看一下上一章的代碼,我們發現小紅牌超級計算器的add方法需要的參數是兩個整型變量和一個Student對象,但是老婆婆她不是學生,是個小商販啊,這里肯定要做修改。這種情況下,我們很自然的會想到繼承和多態。如果讓小明這個學生和老婆婆這個小商販從一個父類進行繼承,那么我們只需要給小紅牌超級計算器傳入一個父類的引用就可以啦。

不過,實際使用中,考慮到java的單繼承,以及不希望把自身太多東西暴漏給別人,這里使用從接口繼承的方式配合內部類來做。

換句話說,小紅希望以后繼續向班里的小朋友們提供計算服務,同時還能向老婆婆提供算賬服務,甚至以后能夠拓展其他人的業務,于是她向所有的顧客約定了一個辦法,用于統一的處理,也就是自己需要的操作數和做完計算之后應該怎么做。這個統一的方法,小紅做成了一個接口,提供給了大家,代碼如下:

?
1
2
3
4
public interface doJob
 {
  public void fillBlank(int a, int b, int result);
 }

因為靈感來自幫小明填空,因此小紅保留了初心,把所有業務都當做填空(fillBlank)來做。

同時,小紅修改了自己的計算器,使其可以同時處理不同的實現了doJob接口的人,代碼如下:

?
1
2
3
4
5
6
7
8
public class SuperCalculator
 {
  public void add(int a, int b, doJob customer)
  {
   int result = a + b;
   customer.fillBlank(a, b, result);
  }
 }

小明和老婆婆拿到這個接口之后,只要實現了這個接口,就相當于按照統一的模式告訴小紅得到結果之后的處理辦法,按照之前說的使用內部類來做,代碼如下:
小明的:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public class Student
 {
  private String name = null;
 
  public Student(String name)
  {
   // TODO Auto-generated constructor stub
   this.name = name;
  }
 
  public void setName(String name)
  {
   this.name = name;
  }
 
  public class doHomeWork implements doJob
  {
 
   @Override
   public void fillBlank(int a, int b, int result)
   {
    // TODO Auto-generated method stub
    System.out.println(name + "求助小紅計算:" + a + " + " + b + " = " + result);
   }
 
  }
 
  public void callHelp (int a, int b)
  {
   new SuperCalculator().add(a, b, new doHomeWork());
  }
 }

老婆婆的:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public class Seller
{
 private String name = null;
 
 public Seller(String name)
 {
  // TODO Auto-generated constructor stub
  this.name = name;
 }
 
 public void setName(String name)
 {
  this.name = name;
 }
 
 public class doHomeWork implements doJob
 {
 
  @Override
  public void fillBlank(int a, int b, int result)
  {
   // TODO Auto-generated method stub
   System.out.println(name + "求助小紅算賬:" + a + " + " + b + " = " + result + "元");
  }
 
 }
 
 public void callHelp (int a, int b)
 {
  new SuperCalculator().add(a, b, new doHomeWork());
 }
}

測試程序如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class Test
{
 public static void main(String[] args)
 {
  int a = 56;
  int b = 31;
  int c = 26497;
  int d = 11256;
  Student s1 = new Student("小明");
  Seller s2 = new Seller("老婆婆");
 
  s1.callHelp(a, b);
  s2.callHelp(c, d);
 }
}

運行結果如下:

小明求助小紅計算:56 + 31 = 87

老婆婆求助小紅算賬:26497 + 11256 = 37753元

總結

可以很明顯的看到,小紅已經把這件事情當做一個事業來做了,看她給接口命的名字doJob就知道了。

有人也許會問,為什么老婆婆擺攤能掙那么多錢? 你的關注點有問題好嗎!!這里聊的是回調機制啊!!

我只知道,后來小紅的業務不斷擴大,終于在幼稚園畢業之前,用掙到的錢買了人生的第一套房子。

以上就是本文對于Java中的回調機制(CallBack) 的有趣詳解,希望給大家學習java有所幫助。也謝謝大家對服務器之家的支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 成人综合视频在线 | 精品久久国产 | 精品无码久久久久久国产 | 国外成人在线视频 | 黄色三及毛片 | 中文在线一区二区 | 一区二区三区在线看 | 欧美一级内谢 | 欧美黄色网页 | 亚洲国产成人av | 国产一区二区视频在线 | 久久99深爱久久99精品 | 亚洲一区中文字幕在线观看 | 欧美激情视频一区二区三区不卡 | 欧美日韩一区精品 | 欧美福利在线观看 | 亚洲久久久久 | 国产精品永久免费自在线观看 | 亚洲第一av | 精品亚洲永久免费精品 | 亚洲a网| av大全在线 | 国产精品美女久久久久久久久久久 | 国产精品久久久久久久久久新婚 | 欧美另类视频在线 | 国产激情不卡 | 黄色在线免费观看视频网站 | 国产精品视频播放 | 黄色直接看 | 亚洲视频成人 | 日韩在线视频免费观看 | 美女视频黄8频a美女大全 | 中文字幕在线看 | 欧美午夜一区二区三区免费大片 | 91网站免费| 色中色综合 | 一区二区三区在线 | 在线成人av | 成人羞羞视频在线看网址 | 国产在线不卡 | 国产日韩欧美在线 |