设计模式_CallBack

一.基本概念

if you call me, i will call back

什么是回调函数
  回调函数(callback Function),顾名思义,用于回调的函数。 回调函数只是一个功能片段,由用户按照回调函数调用约定来实现的一个函数。回调函数是一个工作流的一部分,由工作流来决定函数的调用(回调)时机。回调函数包含下面几个特性:
  1、属于工作流的一个部分;
  2、必须按照工作流指定的调用约定来申明(定义);
  3、他的调用时机由工作流决定,回调函数的实现者不能直接调用回调函数来实现工作流的功能;

回调机制
   回调机制是一种常见的设计模型,他把工作流内的某个功能,按照约定的接口暴露给外部使用者,为外部使用者提供数据,或要求外部使用者提供数据。
 java回调机制:
   软件模块之间总是存在着一定的接口,从调用方式上,可以把他们分为三类:同步调用、回调和异步调用。
  同步调用:一种阻塞式调用,调用方要等待对方执行完毕才返回,它是一种单向调用;
  回 调:一种双向调用模式,也就是说,被调用方在接口被调用时也会调用对方的接口;
  异步调用:一种类似消息或事件的机制,不过它的调用方向刚好相反,接口的服务在收到某种讯息或发生某种事件时,会主动通知客户方(即调用客户方的接口)。
   回调和异步调用的关系非常紧密:使用回调来实现异步消息的注册,通过异步调用来实现消息的通知。

二.举例说明

1.简单调用

 (1) 接口实现需要回调的方法

public interface  CallBack  {
    //需要回调的方法 String event
    public void postExec();
}

(2) 最终实现类 FooBar。 拥有参数为CallBack接口类型的函数,setCallBack(ICallBack   o)

public class FooBar {
    // 组合聚合原则
    private CallBack callBack;
    //设置接口函数
    public void setCallBack(CallBack callBack) {
        this.callBack = callBack;
        doSth();
    }
    //执行接口函数
    public void doSth() {
        System.out.println("FooBar 执行 ");
        callBack.postExec();
    }
}

(3) test

public class CallBackTest {
    public static void main(String[] args) {
        FooBar foo = new FooBar();
        foo.setCallBack(new CallBack() {
            @Override
            public void postExec() {
                System.out.println(" 在Test类中实现但不能被Test的对象引用,而由FooBar对象调用");
            }
        });
    }
}

2.使用已实现的类调用

 (1) 接口实现需要回调的方法

public interface ServiceProvider {
     public void customHintCallBack();
}

(2) 最终实现类 ChinaTelecom

public class ChinaTelecom {
    private ServiceProvider sp;  //callback接口作为属性
    private boolean isHappened=true;

    public void setSp(ServiceProvider sp) {
        this.sp = sp;
    }

    public void doWork() {
        System.out.println("Welcome, This is ChinaTelecom! ");
        if (isHappened) {
            // 事件发生时,通过调用接口的这个方法来通知
            sp.customHintCallBack();//sp自定义的操作
        }
    }
}

(3) 接口实现需要回调的方法

//实现接口
class KongNet implements ServiceProvider {

    @Override
    public void customHintCallBack() {
        System.out.println("优惠活动开始啦!");
    }
}

(4) Test

    public static void main(String[] args) {
        ChinaTelecom ct = new ChinaTelecom();
        //使用匿名类,调用自定义方法
        ct = new ChinaTelecom();
        ct.setSp(new ServiceProvider() {
            @Override
            public void customHintCallBack() {
                System.out.println("优惠活动开始啦  test1! ");
            }
        });
        ct.doWork();
        //使用已实现的类实现回调
        ct.setSp(new KongNet());
        ct.doWork();

        //使用已实现的类实现回调,自定义方法
        ct = new ChinaTelecom();
        ct.setSp(new KongNet() {
            @Override
            public void customHintCallBack() {
                super.customHintCallBack();
                System.out.println("优惠活动开始啦!  end back!!!");
            }
        });
        ct.doWork();
    }

3.设计模式实现消息通知

(1) 定义一个接口InterestingEvent ,回调方法nterestingEvent(String event) 简单接收一个String 参数

public interface  InterestingEvent {
    // 这只是一个普通的方法,可以接收参数、也可以返回值
    public void interestingEvent(String event);
}

(2) 实现InterestingEvent接口,事件处理类

class CallMe implements InterestingEvent {
    private String name;
    public CallMe(String name){
        this.name = name;
    }    

    @Override
    public void interestingEvent(String event) {
        System.out.println(name + ":[" +event  + "] happened");
    }

}

(3) 事件管理者,或事件通知者

public class EventNotifier {
    private List<CallMe> callMes = new ArrayList<CallMe>();

    public void regist(CallMe callMe){
        callMes.add(callMe);
    }

    public void doWork(){
        for(CallMe callMe: callMes) {
            callMe.interestingEvent("sample event");
        }
    }
}

(4) 测试

public class CallMeTest {
    public static void main(String[] args) {
        EventNotifier ren = new EventNotifier();
        CallMe a = new CallMe("CallMe A");
        CallMe b = new CallMe("CallMe B");

        // regiest
        ren.regist(a);
        ren.regist(b);

        // test
        ren.doWork();
    }
}
时间: 2024-10-29 20:01:29

设计模式_CallBack的相关文章

Java设计模式——创建型模式之单例模式

一.概述 作为第一个出场的设计模式,有必要先介绍一下设计模式(引用自百度百科): 设计模式(Design Pattern)是一套被反复使用.多数人知晓的.经过分类的.代码设计经验的总结. 使用设计模式的目的:为了代码可重用性.让代码更容易被他人理解.保证代码可靠性. 设计模式使代码编写真正工程化:设计模式是软件工程的基石脉络,如同大厦的结构一样. 设计模式概念的介绍,参见:http://blog.jobbole.com/101076/ 其中涉及的设计原则的概念,参见随笔:http://www.c

10大APP界面框架设计模式详解

随着移动互联网的发展,移动app已经成为了每个互联网公司的标配了,那作为产品经理,我们如何设计出更加符合用户体验的app产品呢?今天和大家分享的就是10中最常见的app界面光甲设计模式,一起来看看吧. 1.标签导航 标签导航是十大界面框架设计里最常用的界面框架设计,也是被业界之内公认的一种普遍使用的页面框架设计.那么这种页面框架设计在作业方面对一个用户来说也是最常见的一种页面框架设计,比如说微博.微信.手机百度.支付宝.淘宝,这些我们所谓的超级APP都是运用的标签导航,无一例外.从这个角度也可以

[js高手之路]设计模式系列课程-组合模式+寄生组合继承实战新闻列表

所谓组合模式,就是把一堆结构分解出来,组成在一起,现实中很多这样的例子,如: 1.肯德基套餐就是一种组合模式, 比如鸡腿堡套餐,一般是是由一个鸡腿堡,一包薯条,一杯可乐等组成的 2.组装的台式机同理,由主板,电源,内存条,显卡, 机箱,显示器,外设等组成的 把一个成型的产品组成部件,分成一个个独立的部件,这种方式可以做出很多灵活的产品,这就是组合模式的优势 比如:家用台式机电脑,要求配置比较低, 这个时候只需要主板+电源+内存条+机箱+显示器+外设就可以了,不需要配置独立显卡 鸡腿堡+鸡翅+紫薯

Happy 设计模式之适配器模式(JAVA)

设计模式-适配器模式 适配器模式定义 适配器模式,将一个类的的接口转换成客户或者产品希望的接口形式,就是原本不兼容或者甚至不相干的接口不能一起工作的接口一起工作,完成需求或者客户的需求. 适配器模式的使用场景 1.当你使用一个已经存在的类,而他的接口不符合你的需求. 2.你想要创建一个复用的类,该类可以与其相关的类或者不可见的类协同工作. 适配器角色 Target:目标接口 TargetImpl:目标实现类 Adapter:适配器 Adaptee:被适配者 代码解析: package com.d

设计模式 2/23 工厂模式

工厂模式是最常用的设计模式之一,用好了,代码优雅,可维护性高,对系统设计会上一个台阶 为什么这么说,因为工厂模式可以牵扯出抽象工厂模式,也有大家都会聊到的简单工厂模式 我们要了解一点,23中设计模式中,不包含简单工厂模式,之所以大家会去聊这个,四个字,渐进明细 通过对简单工厂模式的了解,我们引入工厂这个词,不然一个写代码的,天天给他讲工厂,工厂,工厂,西厂,东厂,会晕 同时,通过逐步的深入,从简单工厂,到工厂模式,再到抽象工厂,渐进明细的过程,逐步深入的理解,比较优劣,择优而为我们所用. 试想我

Java设计模式学习笔记,一:单例模式

开始学习Java的设计模式,因为做了很多年C语言,所以语言基础的学习很快,但是面向过程向面向对象的编程思想的转变还是需要耗费很多的代码量的.所有希望通过设计模式的学习,能更深入的学习. 把学习过程中的笔记,记录下来,只记干货. 第一部分:单例模式的内容 单例模式:类只能有一个实例. 类的特点:1.私有构造器:2.内部构造实例对象:3.对外提供获取唯一实例的public方法. 常见的单例模式实现有五种形式: 1.饿汉式. 2.懒汉式. 3.双重检查锁式. 4.静态内部类式. 5.枚举式. 以下分别

设计模式之单列模式

设计模式之单列模式 1,何为单列模式? 即singleton 在某个类采用了单列模式之后  其只能有一个实列对象 ,并且这个实列对象只能有内部自己创建并提供给外部的调用. 2.实现单列模式的方法 分为 :饿汉式 ,懒汉式 下面为饿汉式实现代码: public calss Singleton1{ //将构造函数私有化 防止外部通过new来创建对象 private Singleton1(){ } //创建一个私有静态变量并直接初始化 类加载的时候直接创建对象 private static Singl

设计模式之原型模式(Prototype)

1.初识原型模式 大家都知道连锁机构是现在灰常流行的商业模式,比如咖啡之翼,那么假设咖啡之翼要在长春新建立一个分店,所经营的产品和以前在其他的城市已经存在的店经营的产品差不多,那么面向对象开发的角度怎么解决这个问题呢?难道要重新的实例化一个咖啡之翼的店??这显然不太好吧,咖啡之翼里面经营的产品(假设是属性吧)都需要重新写,这就是在做大量的重复工作啊,这显然是不符合OO开发思想的.遇到这样的情况,并不是重新建立一个类来解决这样的问题,而是通过设计模式中的"原型模式"来解决这种问题.是这种

对设计模式的总结之简单工厂与策略模式

前言 面向对象编程追求的本质-提高扩展性.可维护性.灵活性和复用性.合理利用面向对象6个原则,能够很好的达到要求.如何利用好就是至关重要的了,前人总结了23+个设计模式能够让初学者更容易学到其中的精髓,本文就说说我对本人对简单工厂模式.策略模式的见解. 简单工厂模式与策略模式 简单工厂模式 工作中,常常遇到需要做一个功能(鸭子),这个功能中含有可控个数的子操作功能(鸭子叫,鸭子跑,鸭子飞),而且子功能在不同的情况下处理方式又不相同(成年鸭子/小鸭子叫,成年鸭子/小鸭子跑,成年鸭子/小鸭子飞).我