监听异步方法执行操时直接返回错误信息

监听一个方法 执行规定时间后没返回,强制超时返回错误信息
    public String methodRuntimeTest() {
        AtomicReference<String> str= new AtomicReference<>("00000");
        CompletableFuture<String> stringCompletableFuture = CompletableFuture.supplyAsync(this::doAnyThing).whenComplete((a,b)->{
            System.out.println("执行结束");
            str.set(a);
        });
        try {
            stringCompletableFuture.get(3, TimeUnit.SECONDS);
        }catch (Exception e){
            System.out.println("执行操时");
            return str.get();
        }
        return str.get();
    }

    public String doAnyThing(){
        try {
            Thread.sleep(1000);
        }catch (Exception e){
            return "33333";
        }
        return "33333";
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 异步返回结果给前端通常可以通过以下几种方式: 1. AJAX 请求:可以使用 AJAX 技术,通过 JavaScript 发送异步请求到服务器获取数据,然后在请求完成后将结果返回前端页面。在浏览器端,可以使用原生的 XMLHttpRequest 对象或者 jQuery 提供的 AJAX 函数等库来发送请求。 2. WebSocket:WebSocket 是一种在单个 TCP 连接上进行双向通信的协议,可以用来实现异步通信。在客户端,可以使用 JavaScript 创建 WebSocket 实例,向服务器发送请求并接收服务器端的推送消息。 3. Server-Sent Events(SSE):SSE 是一种基于 HTTP 的协议,可以实现服务器向客户端推送事件流。在客户端,可以使用 JavaScript 创建 EventSource 对象,监听服务器端的事件流并在接收到事件时更新页面。 4. Promise 和异步函数:在 JavaScript 中,可以使用 Promise 和异步函数来处理异步操作。通过 Promise,可以在异步操作完成后返回一个结果对象,然后在回调函数中处理结果。而使用异步函数,则可以在函数前加上 async 关键字,将函数转化为异步函数,并使用 await 关键字等待异步操作的结果,然后将结果返回前端。 在实际开发中,具体选择哪种方式取决于应用场景和需求。 ### 回答2: 在前端与服务器之间进行通信时,一个常见的需求是异步返回结果给前端。下面是一种典型的方法: 1. 使用AJAX进行异步请求:在前端,可以使用AJAX技术向服务器发送异步请求,该请求可以是GET或者POST方式。可以使用原生的JavaScript编写AJAX请求,也可以使用各种流行的JavaScript库(如jQuery、axios等)来简化操作。 2. 服务器处理请求:服务器接收到前端异步请求后,可以根据实际业务需求进行处理,并生成需要的结果。 3. 后端返回结果:在服务器处理完请求之后,通过HTTP协议将结果返回前端。可以使用JSON进行数据交换,将结果封装成JSON对象返回前端。 4. 前端处理返回结果:前端接收到后端返回的结果后,可以通过回调函数或者Promise等方式处理返回数据,并更新前端页面的显示。 需要注意的是,在异步请求过程中可能会出现延迟和错误,因此在前端和后端都需要进行错误处理。在前端,可以通过使用try-catch块来捕获异常,并进行相关的处理。在后端,可以在服务器端日志中记录错误信息,并返回相关的错误码给前端。 总结起来,异步返回结果给前端的过程包括发送异步请求、服务器处理请求、返回结果给前端以及前端处理返回结果的过程。通过合理的使用AJAX技术,可以实现高效的异步通信,提升用户体验。 ### 回答3: 在前端开发中,异步返回结果是十分常见的需求,可以通过以下几种方式来实现: 1. 使用回调函数:在进行异步操作后,将结果通过回调函数传递给前端前端在接收到结果后执行相应的处理逻辑。这种方式需要在异步操作完成后手动调用回调函数进行结果传递。 2. 使用 Promise:Promise 是一种用于处理异步操作的对象。在进行异步操作后,可以通过返回 Promise 对象将结果传递给前端前端可以通过 then 方法来获取结果,并定义处理逻辑。Promise 提供了链式调用的方式,可以更方便地处理多个异步操作。 3. 使用 async/await:async/await 是 ES2017 中新增的一种处理异步操作的语法。在异步函数中,可以使用 await 关键字等待异步操作的结果,然后将结果返回前端。在前端代码中可以使用 async 关键字声明异步函数,然后使用 await 等待结果的返回。 总结起来,异步返回结果给前端可以使用回调函数、Promise 或者 async/await 这些方式。具体使用哪种方式取决于开发者的喜好和项目需求。无论选择哪种方式,都需要保证异步操作完成后能够及时将结果传递给前端,并正确处理返回的结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值