回调--闭包--同步--异步--阻塞--非阻塞

回调-- 一个方法的指针传递给事件源, 事件源在事件发生之后, 反过来调用这个方法. 这个方法就叫回调函数

在java中, 一般通过抽象类或接口定义回调函数, 如:

interface CallBackI
{
    void callback(Object obj) ;
}
class A implements CallBackI
{
    private Object obj ;

    public void callback(Object obj)
    {
        this.obj = obj ;
    }

    public void getInfo(B b)
    {
        b.event(this) ;
    }
}

class B
{
    public boolean somethingHappend()
    {
        //dosomething....
        return true ;
    }

    public void event(CallBackI callback)
    {
        if(somethingHappend())
            callback.callback(someInfo) ;
    }
}

A需要从B中获取某些信息, 于是调用B的even方法, 并把自己当作参数传递进去, b在事件发生并处理结束(somethingHappend返回)之后, 调用a的callback方法(回调函数)将信息传递会a.

java api中的观察者模式就是一个回调机制的例子:

    public void notifyObservers(Object arg) {
            if (!changed)
                return;
            arrLocal = obs.toArray();
            clearChanged();
        }

        for (int i = arrLocal.length-1; i>=0; i--)
            ((Observer)arrLocal[i]).update(this, arg);
    }

这段代码是Observable类中的notifyObservers方法, 他在事件发生之后回调observer的update方法来达到通知观察者的目的

设计模式中的好莱坞原则, 我感觉也是回调机制的一种表现, 低层组件依赖于高层组件, 高层组件通过调用低层组件接口方法的形式来回调低层组件.

好莱坞原则是: 别打电话给我们,有事我会打电话给你

依赖倒置: 依赖于抽象编程, 不要依赖于具体实现, 低层具体组件应该依赖于高层抽象组件; 我感觉由此可见依赖倒置是好莱坞原则的一个实现..

ajax也是回调机制的例子,

xmlhttp.open("GET","ajax_test.asp",true);
xmlhttp.onreadystatechange=function()
  {
  if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
    document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","test1.txt",true);
xmlhttp.send();

这个function就是一个回调函数, 当服务器给浏览器返回一个结果之后, 就会调用这个方法

我在看回调机制的时候, 突然想到ajax属于异步调用, 而我写的那个属于同步调用(与回调机制无关) , 于是想小结一下上周对同步,异步, 阻塞式, 非阻塞式的理解

同步与异步这个概念是指消息传递的机制不同, 同步调用在没有得到返回结果之前不会返回, 而是主动等待这个返回结果; 而异步调用在得到结果之前会立即返回, 也就是异步调用不会立即得到返回结果, 而是等待被调用者给调用者一个信号, 当信号出现之后再来处理这个返回的结果

阻塞式与非阻塞式则是程序等待调用结果的方式不同, 阻塞式在得到结果前, 会将自身的进程或线程挂起等待结果, 在结果数据的接收过程中等待数据传输结束;而非阻塞式则是会立即返回一个结果,不会使进程或线程进入等待态.

linux的5种I/O模型

阻塞式I/O: recefrom在返回前(没有结果), 会将进程挂起,进入等待态? , 且在进行IO时, 等待IO结束, 属于同步IO

非阻塞式I/O: recefrom在没有IO结果时, 会立即返回一个标志位, 且在进行IO时, 等待IO结束, 属于同步IO

IO复用: select在IO未准备好时, 会立即返回一个标志位, 通过轮询标志来检查是否有数据准备好, 且在进行IO时, 等待IO结束, 属于同步IO

任务驱动: 四个nation在IO未准备好时, 会立即返回一个标志位(非阻塞), 且在IO过程中, 等待IO结束, 属于同步IO

异步IO: 在IO未准备好时, 会立即返回一个标志位(非阻塞); 当IO准备好时, 由OS内核完成IO, 然后通知异步IO的进程对数据进行处理, 而不是在IO过程中等待IO, 因此属于异步IO

暂时就理解到这里, 不完全对吧... 等有时间再仔细琢磨这些东西

回调机制//http://blog.sina.com.cn/s/blog_77c632410101cjty.htm

public void notifyObservers(Object arg) {    /*     * a temporary array buffer, used as a snapshot of the state of     * current Observers.     */Object[] arrLocal;

    synchronized (this) {        /* We don‘t want the Observer doing callbacks into         * arbitrary code while holding its own Monitor.         * The code where we extract each Observable from         * the Vector and store the state of the Observer         * needs synchronization, but notifying observers         * does not (should not).  The worst result of any         * potential race-condition here is that:         * 1) a newly-added Observer will miss a         *   notification in progress         * 2) a recently unregistered Observer will be         *   wrongly notified when it doesn‘t care         */if (!changed)            return;arrLocal = obs.toArray();clearChanged();}

    for (int i = arrLocal.length-1; i>=0; i--)        ((Observer)arrLocal[i]).update(this, arg);}
时间: 2024-10-14 11:38:05

回调--闭包--同步--异步--阻塞--非阻塞的相关文章

理解同步异步与阻塞非阻塞

本篇文章我准本从三个大方面来解释下同步异步.阻塞非阻塞的知识,第一个方面主要是说下,到底什么是同步异步.阻塞非阻塞:第二个方面主要是解释下在I/O场景下,同步异步阻塞非阻塞又是怎么定义的,第三个方面介绍下在unix下同步异步又有哪些阻塞非阻塞IO. 1.同步异步与阻塞非阻塞 首先从大的方面来说,"阻塞"与"非阻塞"与"同步"与"异步"不能简单的从字面理解,提供一个从分布式系统角度的回答. 1).同步与异步 同步和异步关注的是消

同步/异步与阻塞/非阻塞

一.同步与异步同步/异步, 它们是消息的通知机制 1. 概念解释A. 同步所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回. 按照这个定义,其实绝大多数函数都是同步调用(例如sin isdigit等).但是一般而言,我们在说同步.异步的时候,特指那些需要其他部件协作或者需要一定时间完成的任务.最常见的例子就是 SendMessage.该函数发送一个消息给某个窗口,在对方处理完消息之前,这个函数不返回.当对方处理完毕以后,该函数才把消息处理函数所返回的值返回给调用者. B.

基础入门_Python-网络编程.分分钟掌握阻塞/非阻塞/同步/异步IO模型?

概念梳理: 故事独白: 满满爱喝茶,废话不多说,开始煮开水. 出场人物: 满满, 普通水壶, 高级水壶(水开会响) 1. 满满把水壶放在火上, 站在那里等水开(同步阻塞) 满满觉得自己有点儿傻逼~ 2. 满满把水壶放在火上,去客厅看电视,时不时的去厨房瞅瞅水开木有(同步非阻塞) 满满觉得自己还是有点傻~,于是买了个高级水壶, 水开后会响~ 3. 满满把高级水壶放在火上, 站在那里等水开(异步阻塞) 满满想高级水壶水开会自己叫~为毛不去看个电视哪? 4. 满满把高级水壶放在火上, 去客厅看电视,

同步/异步-阻塞/非阻塞

(A)同步和异步,是针对 调用结果是如何返回给调用者来说的,即调用的结果是调用者主动去获取的(比如一直等待recvfrom或者设置超时等待select),则为同步,而调用结果是被调用者在完成之后通知调用者的,则为异步(比如windows的IOCP).(B)阻塞和非阻塞,是针对调用者所在线程是否在调用之后主动挂起来说的,即如果在线程中调用者发出调用之后,再被调用这返回之前,该线程主动挂起,则为阻塞,若线程不主动挂起,而继续向下执行,则为非阻塞. 这样,在网络IO中,同步异步,阻塞非阻塞,就可以形成

深入理解同步/异步与阻塞/非阻塞区别 (转)

转载自:http://chuansong.me/n/2124760 几年前曾写过一篇描写同步/异步以及阻塞/非阻塞的文章,最近再回头看,还存在一些理解和认知误区,于是重新整理一下相关的概念,希望对网络编程的同行能有所启发. 同步与异步 首先来解释同步和异步的概念,这两个概念与消息的通知机制有关. 举个例子,比如一个用户去银行办理业务,他可以自己去排队办理,也可以叫人代办,办完之后再告知用户结果.对于要办理这个银行业务的人而言,自己去办理是同步方式,而别人代办完毕再告知则是异步方式. 两者的区别在

异步/同步、阻塞/非阻塞的理解

[同步和异步] 通俗的讲:同步是指:发送方发出数据后,等接收方发回响应以后才发下一个数据包的通讯方式. 异步是指:发送方发出数据后,不等接收方发回响应,接着发送下个数据包的通讯方式.同步:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事异步: 请求通过事件触发->服务器处理(这是浏览器仍然可以作其他事情)->处理完毕 概念从现实中来:同步:打电话,你拨通电话后必须等在那里,直到对方有人接了,你们才能通信或者说你才能继续打下一个电话.异步:发短信,你可以发

(转)同步异步/阻塞非阻塞 和 5种linux网络通信模型

会阻塞的函数:connect, accept,send/recv/sendto/recvfrom等读写函数. 不会阻塞的函数:bind, listen,socket, closesocket. linux网络通信模型有: 阻塞IO模型(同步),非阻塞IO模型(拷贝同步),IO复用模型(多线程同步),信号驱动IO模型((拷贝同步),异步IO模型(异步). node.js对同步/异步,阻塞非阻塞的解释: 线程在执行中如果遇到磁盘读写或网络通信(统称为I/O 操作),通常要耗费较长的时间,这时 操作系

单线程,同步异步,阻塞非阻塞的理解

一.概念理解 1.同步异步: 同步和异步关注的是消息通信机制 (synchronous communication/ asynchronous communication)所谓同步,就是在发出一个*调用*时,在没有得到结果之前,该*调用*就不返回.但是一旦调用返回,就得到返回值了.换句话说,就是由*调用者*主动等待这个*调用*的结果. 而异步则是相反,*调用*在发出之后,这个调用就直接返回了,所以没有返回结果.换句话说,当一个异步过程调用发出后,调用者不会立刻得到结果.而是在*调用*发出后,*被

[Z] linux基础编程:IO模型:阻塞/非阻塞/IO复用 同步/异步 Select/Epoll/AIO

原文链接:http://blog.csdn.net/colzer/article/details/8169075 IO概念 Linux的内核将所有外部设备都可以看做一个文件来操作.那么我们对与外部设备的操作都可以看做对文件进行操作.我们对一个文件的读写,都通过调用内核提供的系统调用:内核给我们返回一个file descriptor(fd,文件描述符).而对一个socket的读写也会有相应的描述符,称为socketfd(socket描述符).描述符就是一个数字,指向内核中一个结构体(文件路径,数据