当前位置: 首页 > news >正文

网站静态生成目录 名称 建议互联网全媒体广告代理

网站静态生成目录 名称 建议,互联网全媒体广告代理,传奇手游网页版,建网站教学视频这章我们讲回调,英文名:Beyond callbacks 一、章节覆盖: 回调函数及其限制,如网关/边缘服务示例所示 未来和承诺——链接异步操作的简单模型 响应式扩展——一个更强大的模型,特别适合组合异步事件流 Kotlin协程——…

这章我们讲回调,英文名:Beyond callbacks

一、章节覆盖:

回调函数及其限制,如网关/边缘服务示例所示
未来和承诺——链接异步操作的简单模型
响应式扩展——一个更强大的模型,特别适合组合异步事件流
Kotlin协程——对异步代码执行流的语言级支持

二、Vert.x中的回调函数是一种非阻塞的异步编程模式,用于处理异步操作的结果。在Vert.x中,回调函数通常用于处理事件,如HTTP请求和数据库查询等,其限制包括:

  1. 回调函数是非阻塞的,不能使用同步代码块或阻塞I/O操作。

  2. 回调函数的执行顺序不可预测,因为它们是异步执行的。

  3. 回调函数需要明确处理错误,不能简单地忽略异常或错误。

  4. 回调函数应该尽量轻量级,避免太复杂的逻辑和操作,以免影响整个应用程序的性能。

  5. 回调函数应该采用良好的编程约定,如命名规范和注释,以便于维护和管理。

回调地狱是指使用嵌套回调来链接异步操作,由于嵌套很深,导致代码更难以理解。对于嵌套回调,错误处理尤其困难。
虽然这是真的,但是可以很容易地为每个异步操作回调使用一个方法来缓解回调地狱,就像我们使用handleRequest、sendToSnapshot和sendResponse方法一样。每个方法只做一件事,我们避免嵌套回调。

二、Futures and promises in Vert.x

类似于:

package furtueAndprimise;import io.vertx.core.AbstractVerticle;
import io.vertx.core.Promise;public class Test extends AbstractVerticle {@Overridepublic void start(Promise<Void> startPromise) throws Exception {Promise<String> promise=Promise.promise();vertx.setTimer(5000,id->{if (System.currentTimeMillis()%2L==0L)promise.complete("ok");elsepromise.fail(new RuntimeException("Bad luck...."));});}
}

这里的异步操作是一个5秒的计时器,之后承诺就完成了。根据当前时间是奇数还是偶数,承诺以一个值完成或以一个异常失败。这很好,但我们如何从承诺中获得价值呢?
想要在结果可用时做出反应的代码需要一个future对象。

完整代码:

package furtueAndprimise;import io.vertx.core.AbstractVerticle;
import io.vertx.core.Future;
import io.vertx.core.Promise;
import io.vertx.core.Vertx;public class Test extends AbstractVerticle {@Overridepublic void start(Promise<Void> startPromise) throws Exception {Promise<String> promise=Promise.promise();vertx.setTimer(5000,id->{if (System.currentTimeMillis()%2L==0L)promise.complete("ok");elsepromise.fail(new RuntimeException("Bad luck...."));});Future<String> future = promise.future();future.onSuccess(System.out::println).onFailure(err -> System.out.println(err.getMessage()));}public static void main(String[] args) {Vertx vertx1=Vertx.vertx();vertx1.deployVerticle(new Test());}
}

用未来的方法启动HTTP服务器:

package furtueAndprimise;import io.vertx.core.AbstractVerticle;
import io.vertx.core.Handler;
import io.vertx.core.Promise;
import io.vertx.core.Vertx;
import io.vertx.core.http.HttpServerRequest;
import io.vertx.core.http.impl.Http1xServerRequestHandler;public class Test001 extends AbstractVerticle {@Overridepublic void start(Promise<Void> promise) {vertx.createHttpServer().requestHandler(requestHandler()).listen(8080).onFailure(fail->{promise.fail("失败");}).onSuccess(ok -> {System.out.println("http://localhost:8080/");promise.complete();});}Handler<HttpServerRequest> requestHandler(){return request -> {// 处理HTTP请求的逻辑// ...};}public static void main(String[] args) {Vertx vertx1 = Vertx.vertx();vertx1.deployVerticle(new Test001());}
}

与CompletionStage api的互操作性:

package furtueAndprimise;import io.vertx.core.AbstractVerticle;
import io.vertx.core.Promise;import java.util.concurrent.CompletionStage;public class Test002 extends AbstractVerticle {@Overridepublic void start() throws Exception {Promise<String> promise=Promise.promise();CompletionStage<String> cs = promise.future().toCompletionStage();cs.thenApply(String::toUpperCase).thenApply(str -> "~~~ " + str).whenComplete((str, err) -> {if (err == null) {System.out.println(str);} else {System.out.println("Oh... " + err.getMessage());}});}
}

CompositeFuture 是一种特殊的 Future,它可以包装一个 Future 列表,从而让一组异步操作并行执行;然后协调这一组操作的结果,作为 CompositeFuture 的结果

三、接下来讲响应式的扩展:

ReactiveX计划为后端和前端项目提供了一个通用的API和多种语言的实现(http://reactivex.io/)。RxJS项目为浏览器中的JavaScript应用程序提供响应式扩展,而像RxJava这样的项目则为Java生态系统提供通用的响应式扩展实现。
vertx提供了RxJava版本1和2的绑定。建议使用版本2,因为它支持背压,而版本1不支持。

单纯讲rxjava,rxjava的五种观察源:

你有时可能会读到热源和冷源。热点源是无论是否存在订阅者都要发出事件的源。冷源是在第一次订阅后才开始发出事件的源。周期计时器是热源,而要读取的文件是冷源。使用冷源,您可以获得所有事件,但使用热源,您只能获得订阅后发出的事件

四、rxjava在vertx里面集成

    1.引入依赖

      implementation("io.vertx:vertx-rx-java2:version")

    

package furtueAndprimise;import io.reactivex.Completable;
import io.reactivex.Observable;
import io.vertx.reactivex.core.AbstractVerticle;
import io.vertx.reactivex.core.RxHelper;import java.util.concurrent.TimeUnit;public class Test003 extends AbstractVerticle {@Overridepublic Completable rxStart() {Observable.interval(1, TimeUnit.SECONDS, RxHelper.scheduler(vertx)).subscribe(n -> System.out.println("tick"));return vertx.createHttpServer().requestHandler(r -> r.response().end("Ok")).rxListen(8080).ignoreElement();}
}

rxStart使用Completable而不是Future来通知部署成功。通过 ignoreElement()方法 返回一个Completable。这个例子打开一个经典的HTTP服务器,对任何请求都回复Ok。有趣的部分是AbstractVerticle的RxJava变体具有通知部署成功的rxStart(和rxStop)方法。在我们的示例中,当HTTP服务器启动时,垂直已经成功部署,因此我们返回一个Completable对象。
您可以检查前缀为rx的方法是否与为支持RxJava而生成的方法相对应。如果您检查RxJava api,您将注意到原始方法(包括回调)仍然存在。

这个例子中另一个有趣的部分是每秒发出事件的可观察对象。它本质上表现为一个Vert.X定时器可以。RxJava api中有几个操作符方法接受调度器对象,因为它们需要延迟异步任务。默认情况下,它们从自己管理的内部工作线程池回调,这就打破了vertx线程模型假设。我们总是可以经过vertx调度器,以确保事件仍在原始上下文事件循环中被回调。

五、Kotlin coroutines

引入依赖

plugins {
kotlin("jvm") version "kotlinVersion"
}
dependencies {
// (...)
implementation("io.vertx:vertx-lang-kotlin:${vertxVersion}")
implementation("io.vertx:vertx-lang-kotlin-coroutines:${vertxVersion}")
implementation(kotlin("stdlib-jdk8"))
}

一直都在讲vertx,所以Kotlin coroutines没有怎么讲,算了,我还是搞一个例子吧

import kotlin.coroutines.*;
suspend fun hello():String{delay(1000)return "Hello!"
}fun main(){runBlocking{println(hello())    //这个runBlocking  会一直等协程完成
}   

注:这个系列的截图一直都是vertx in Action 那本英文书里面的。。

http://www.dinnco.com/news/67090.html

相关文章:

  • 域名第二年续费价格青岛seo计费
  • wordpress打开图片预览代码南宁seo收费
  • 帮客户做网站域名注册流程和费用
  • 怎么做图片网站源码流量购买网站
  • 做杀人任务的网站网站推广策略
  • 用于做网站的软件营销软件商城
  • 王也个人资料重庆seo技术教程
  • 建设银行网站是什么网络平台推广运营有哪些平台
  • 注册网站显示lp或设备超限怎么办百度广告
  • 制作网站怎么做导航栏百度推广手机登录
  • 个人备案网站名称怎么写怎么可以在百度发布信息
  • 做网站怎么每天更新内容排名sem优化软件
  • 湖北手机版建站系统哪家好怎么弄属于自己的网站
  • 外贸网站 自建2021小说排行榜百度风云榜
  • 交做网站视频百度云兰州seo优化公司
  • 网站建设管理人员德州seo优化
  • 自己怎么做彩票网站吗整站优化价格
  • 网站什么情况要更新网页开发教程
  • 建设集团和建设公司有什么区别么太原seo排名优化软件
  • 做网站需要什么网站分析报告
  • 东莞营销网站建设哪家好网站做优化一开始怎么做
  • 网站特色分析图怎么做关键词优化排名怎么做
  • 网站改版影响排名好用搜索引擎排名
  • 网站设计思路厨师培训学校
  • 网站做伪静态网络营销方案的范文
  • qwins是哪个网站做的网络推广费用预算表
  • jsp租房网站开发关键词自动生成器
  • 网站建设信息科技公司深圳网站搜索优化
  • 各大网站开发的区块链推广软件的app
  • 网站分析怎么写泉州百度seo