JAVA的回调机制、同步/异步调用

这篇具有很好参考价值的文章主要介绍了JAVA的回调机制、同步/异步调用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、同步调用

同步调用是最基本的调用方式。类A的a()方法调用类B的b()方法,类A的方法需要等到B类的方法执行完成才会继续执行。如果B的方法长时间阻塞,就会导致A类方法无法正常执行下去。

JAVA的回调机制、同步/异步调用,Java,java,开发语言,回调

二、异步调用

如果A调用B,B的执行时间比较长,那么就需要考虑进行异步处理,使得B的执行不影响A。通常在A中新起一个线程用来调用B,然后A中的代码继续执行。

异步通常分两种情况:

  • 第一,不需要调用结果,直接调用即可,比如发送通知;
  • 第二,需要异步调用结果,在Java中可使用Future+Callable实现。

JAVA的回调机制、同步/异步调用,Java,java,开发语言,回调

三、回调

JAVA的回调机制、同步/异步调用,Java,java,开发语言,回调

通常回调分为:同步回调和异步回调。

其中同步回调与同步调用类似,代码运行到某一个位置的时候,如果遇到了需要回调的代码,会在这里等待,等待回调结果返回后再继续执行。

异步回调与异步调用类似,代码执行到需要回调的代码的时候,并不会停下来,而是继续执行,当然可能过一会回调的结果会返回回来。

1、同步回调

JAVA的回调机制、同步/异步调用,Java,java,开发语言,回调

制作Callback接口

public interface Callback {
    void CallbackData(String Data);
}

自定义向小明提问的人:

public class CallbackHanler implements Callback{

    Caller caller;


    public CallbackHanler(Caller caller) {
        this.caller = caller;
    }

    @Override
    public void CallbackData(String Data) {
        Log.d("TAG!","你懂了,答案为"+Data);
    }

    public void ask(){
        caller.DoWork(this);
    }
}

大佬小明:

public class Caller {
    public void DoWork(Callback callback){
        Log.d("TAG!","小明进行自己的工作");
        try {
            Thread.sleep(5000);
            Log.d("TAG!","开始解决你的问题");
        } catch (InterruptedException e) {
            throw new RuntimeException(e);
        }

        Log.d("TAG!","问题答案为2");
        //传递问题答案
        callback.CallbackData("2");
    }
}

在Main函数中调用这两个类:

Caller caller = new Caller();
CallbackHanler callbackHanler = new CallbackHanler(caller);
callbackHanler.ask();
Log.d("TAG!","你在等待。。。。");

打印结果如下:

JAVA的回调机制、同步/异步调用,Java,java,开发语言,回调

上面的实例演示了同步回调,很明显在调用的过受到Caller执行时长的影响,需要等到Caller处理完才能继续执行CallbackHanler方法中的后续代码。

2、异步回调

修改CallbackHanler的ask()方法如下:

    public void ask(){
        new Thread(()-> caller.DoWork(this)).start();
    }

打印结果如下:

JAVA的回调机制、同步/异步调用,Java,java,开发语言,回调

通过Main函数的Log.d(“TAG!”,“你在等待。。。。”);可以知道,此时main函数没有等待ask(),而是直接继续执行。文章来源地址https://www.toymoban.com/news/detail-620673.html

到了这里,关于JAVA的回调机制、同步/异步调用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Java中的同步和异步

    在Java中,同步(Synchronous)和异步(Asynchronous)是用来描述程序执行模式的概念。 1. 同步:同步指的是按照程序的顺序依次执行代码,每个操作都会等待前一个操作完成后再执行。同步执行的特点是阻塞,即某个操作的完成会导致后续操作的等待。在多线程编程中,同步可以

    2024年02月07日
    浏览(71)
  • Android JNI复杂用法,回调,C++中调用Java方法

    Android JNI的 普通用法估计很多人都会,但是C++中调用Java方法很多人不熟悉,并且网上很多介绍都是片段的。 虽然C/C++调用Java不常用,但是掌握多一点还是有好处的。 Android JNI的基础知识介绍,之前已经有介绍,不熟悉的可以先看看: Android Jni的介绍和简单Demo实现: https://

    2024年03月26日
    浏览(36)
  • java 如何快速实现异步调用方法

    在实现异步调用之前,我们先了解一下,什么是异步编程?什么场景下适用等等情况。 我们都知道,在传统的同步编程中,当一个操作开始执行时, 程序会阻塞并等待该操作完成,然后才能继续执行后续代码 。这种阻塞等待的方式可能会导致程序响应性能下降,因为在等待

    2024年02月15日
    浏览(29)
  • ZooKeeper Java API 使用教程 - 同步与异步操作示例

    本教程详细介绍了如何使用ZooKeeper Java API进行节点数据的同步和异步获取。通过具体代码示例,展示了如何连接ZooKeeper服务器,获取子节点列表,以及如何处理节点数据变化的事件。

    2024年04月22日
    浏览(26)
  • 【kafka】Java客户端代码demo:自动异步提交、手动同步提交及提交颗粒度、动态负载均衡

    kafka版本为3.6,部署在3台linux上。 maven依赖如下: 生产者、消费者和topic代码如下: 这里先简单解释一下, kafka的topic只是一个逻辑上的概念,实际上的物理存储是依赖分布在broker中的分区partition来完成的 。kafka依赖的zk中有一个 __consumer_offsets [1]话题,存储了所有consumer和g

    2024年01月19日
    浏览(40)
  • kafka生产者异步发送、同步发送、回调异步发送,是什么情况?

    Kafka是一种分布式流处理平台 ,它是一种高吞吐量、可扩展、可持久化的消息队列系统,用于处理和存储实时流式数据。 Kafka基于发布-订阅模式,采用了分布式、多副本、分区的架构。它允许生产者将数据以消息的形式发送到Kafka集群的一个或多个主题(topic)中,而消费者可以

    2024年02月15日
    浏览(26)
  • kafka入门,生产者异步发送、回调函数,同步发送(四)

    引入依赖 回调函数会在producer收到ack时调用,该方法有两个参数,分别是元数据信息(RecordMetadata)和异常信息(Exception),如果Exception为null,说明信息发送失败 注意:消息发送失败会自动重试,不需要我们在回调函数中手动重试。 只需在异步发送的基础上,再调用一下 get(

    2024年02月11日
    浏览(35)
  • Elasticsearch“滚动查询“(Scrolling)的机制的与Java使用ES Client 调用滚动查询

    ES在进行普通的查询时,默认只会查询出来10条数据。我们通过设置es中的size可以将最终的查询结果从10增加到10000。如果需要查询数据量大于es的翻页限制或者需要将es的数据进行导出又当如何? Elasticsearch提供了一种称为 \\\"滚动查询\\\"(Scrolling) 的机制,用于处理大型数据集的

    2024年02月11日
    浏览(33)
  • Java开发 - 深入理解Redis哨兵机制原理

    Redis的主从、哨兵模式、集群模式,在前文中都已经有了详细的搭建流程,可谓是手把手教程,也得到了很多朋友的喜欢。由于前文偏向于应用方面,就导致了理论知识的匮乏,我们可能会用了,但却不明所以,所以今天,博主就通过接下里的几篇博客给大家分别讲解Redis哨兵

    2024年02月17日
    浏览(30)
  • Java开发或调用WebService的几种方式

    1.服务端开发与发布 编写接口 编写接口的实现类 发布服务 访问已发布的WebService服务 打开浏览器输入http://127.0.0.1:8888/JaxWSTest?wsdl访问,如下面内容 截图内容1 浏览器中输入wsdl文档中的 http://127.0.0.1:8888/JaxWSTest?xsd=1可查看绑定的参数等信息看如下图: 截图内容2 jdk自带生成W

    2024年01月17日
    浏览(40)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包