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

响应式编程Reactor API大全(下)

Reactor 是一个基于响应式编程的库,主要用于构建异步和事件驱动的应用程序。Reactor 提供了丰富的 API,包括创建、转换、过滤、组合等操作符,用于处理异步数据流。以下是一些 Reactor 的主要 API 示例:

pom依赖

   <dependencyManagement><dependencies><dependency><groupId>io.projectreactor</groupId><artifactId>reactor-bom</artifactId><version>2023.0.0</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><dependencies><dependency><groupId>io.projectreactor</groupId><artifactId>reactor-core</artifactId></dependency><dependency><groupId>io.projectreactor</groupId><artifactId>reactor-test</artifactId><scope>test</scope></dependency><dependency><groupId>org.junit.jupiter</groupId><artifactId>junit-jupiter</artifactId><version>5.7.2</version><scope>test</scope></dependency></dependencies>

61. 使用 Reactor 的 then 方法进行后续操作

then 方法用于在当前数据流完成后执行后续操作。

import reactor.core.publisher.Flux;public class ReactorThenExample {public static void main(String[] args) {Flux<Integer> source = Flux.just(1, 2, 3);// 在当前数据流完成后执行后续操作source.then(Mono.fromRunnable(() -> System.out.println("Done"))).subscribe();}
}

62. 使用 Reactor 的 publishOn 方法进行线程切换

publishOn 方法用于切换数据流的发布线程,从而改变元素处理的线程。

import reactor.core.publisher.Flux;
import reactor.core.scheduler.Schedulers;public class ReactorPublishOnExample {public static void main(String[] args) {Flux<Integer> source = Flux.range(1, 3);// 将数据流的发布线程切换到另一个线程池source.publishOn(Schedulers.elastic()).map(value -> value * 2).subscribe(System.out::println);}
}

63. 使用 Reactor 的 subscribeOn 方法进行订阅线程切换

subscribeOn 方法用于切换数据流的订阅线程,影响整个数据流的执行线程。

import reactor.core.publisher.Flux;
import reactor.core.scheduler.Schedulers;public class ReactorSubscribeOnExample {public static void main(String[] args) throws InterruptedException {Flux<Integer> source = Flux.range(1, 3).log();// 将数据流的订阅线程切换到另一个线程池 另一个线程:parallel-1source.subscribeOn(Schedulers.parallel()).map(value -> value * 2).subscribe(System.out::println);Thread.sleep(23333);}
}

64. 使用 Reactor 的 delayElements 方法进行元素延迟

delayElements 方法用于延迟数据流中元素的发送。

import reactor.core.publisher.Flux;
import java.time.Duration;public class ReactorDelayElementsExample {public static void main(String[] args) throws InterruptedException {Flux<Integer> source = Flux.range(1, 3);// 延迟每个元素的发送source.delayElements(Duration.ofSeconds(1)).subscribe(System.out::println);Thread.sleep(23333);}
}

65. 使用 Reactor 的 concatWith 方法进行数据流连接

concatWith 方法用于将两个数据流连接在一起,保持顺序

import reactor.core.publisher.Flux;public class ReactorConcatWithExample {public static void main(String[] args) {Flux<Integer> source1 = Flux.just(1, 2, 3);Flux<Integer> source2 = Flux.just(4, 5, 6);// 将两个数据流连接在一起,保持顺序source1.concatWith(source2).subscribe(System.out::println);}
}

66. 使用 Reactor 的 merge 方法进行多数据流合并

merge 方法用于将多个数据流合并成一个数据流,并发执行

import reactor.core.publisher.Flux;public class ReactorMergeExample {public static void main(String[] args) {Flux<Integer> source1 = Flux.just(1, 2, 3);Flux<Integer> source2 = Flux.just(4, 5, 6);// 将两个数据流合并成一个数据流Flux<Integer> mergedFlux = Flux.merge(source1, source2);mergedFlux.subscribe(System.out::println);}
}

67. concatWithmerge的比较

  1. 执行顺序:
    • concatWith 这个方法会按照合并的顺序执行 Flux。它会等待第一个 Flux 完成(包括完成信号或错误信号),然后再开始下一个 Flux
    • merge 这个方法会并发执行所有的 Flux,它不会等待前一个 Flux 完成。因此,元素的顺序可能是交错的。
  2. 参数类型:
    • concatWith 它接受一个单独的 Flux 作为参数,将这个 Flux 追加到当前 Flux 的末尾。
    • merge 它接受可变参数,可以传入多个 Flux,并同时合并它们。
public class FluxConcatWithMergeExample {public static void main(String[] args) throws InterruptedException {Flux<Integer> flux1 = Flux.just(1, 2, 3).delayElements(Duration.ofMillis(100));Flux<Integer> flux2 = Flux.just(4, 5, 6).delayElements(Duration.ofMillis(50));Flux<Integer> flux3 = Flux.just(7, 8, 9).delayElements(Duration.ofMillis(75));// 使用 concatWith 方法,按顺序执行flux1.concatWith(flux2).concatWith(flux3).subscribe(v ->{System.out.println("concatWith = " + v);});// 使用 merge 方法,并发执行Flux.merge(flux1, flux2, flux3).subscribe(v ->{System.out.println("merge = " + v);});Thread.sleep(22333);}
}

68. 使用 Reactor 的 mergeSequential 方法进行多数据流合并

mergeSequential 方法用于按顺序合并多个数据流,保持各个数据流的元素顺序。

import reactor.core.publisher.Flux;public class ReactorMergeSequentialExample {public static void main(String[] args) {Flux<Integer> source1 = Flux.just(1, 2, 3);Flux<Integer> source2 = Flux.just(4, 5, 6);// 按顺序合并两个数据流Flux<Integer> mergedFlux = Flux.mergeSequential(source1, source2);mergedFlux.subscribe(System.out::println);}
}

69. 使用 Reactor 的 combineLatest 方法进行多数据流合并

combineLatest 方法用于合并多个数据流的最新元素。

import reactor.core.publisher.Flux;public class ReactorCombineLatestExample {public static void main(String[] args) {Flux<Integer> source1 = Flux.just(1, 2, 3);Flux<Integer> source2 = Flux.just(4, 5, 6);// 合并两个数据流的最新元素Flux<Integer> combinedFlux = Flux.combineLatest(source1, source2, (a, b) -> a + b);combinedFlux.subscribe(System.out::println);}
}

71. 使用 Reactor 的 doOnNext 方法进行每个元素的附加操作

doOnNext 方法用于在每个元素发出时执行附加操作,例如日志记录、统计等。

import reactor.core.publisher.Flux;public class ReactorDoOnNextExample {public static void main(String[] args) {Flux<Integer> source = Flux.range(1, 3);// 在每个元素发出时执行附加操作source.doOnNext(value -> System.out.println("Processing: " + value)).subscribe(System.out::println);}
}

79. 使用 Reactor 的 fromCallable 方法创建带有返回值的 Mono

fromCallable 方法用于创建一个 Mono,其值由提供的 Callable 对象返回。

import reactor.core.publisher.Mono;import java.util.concurrent.Callable;public class ReactorFromCallableExample {public static void main(String[] args) {// 创建带有返回值的 MonoMono<String> resultMono = Mono.fromCallable(() -> {// 执行一些计算return "Result";});resultMono.subscribe(System.out::println);}
}

80. 使用 Reactor 的 using 方法进行资源管理

using 方法用于在数据流的生命周期内管理资源,例如打开和关闭文件、网络连接等。

import reactor.core.publisher.Flux;
import reactor.core.publisher.Mono;public class ReactorUsingExample {public static void main(String[] args) {// 使用 using 方法管理资源Flux<String> resultFlux = Flux.using(() -> getResource(), // 打开资源resource -> getData(resource), // 使用资源获取数据流resource -> releaseResource(resource) // 关闭资源);resultFlux.subscribe(System.out::println);}private static Mono<String> getResource() {System.out.println("Opening resource");return Mono.just("Resource");}private static Flux<String> getData(Mono resource) {System.out.println("Getting data from resource: " + resource);return Flux.just("Data1", "Data2", "Data3");}private static Mono<Void> releaseResource(Mono resource) {System.out.println("Releasing resource: " + resource);return Mono.empty();}
}

82. 使用 Reactor 的 scan 方法进行累积操作

scan 方法用于对数据流中的元素进行累积操作,并生成一个新的数据流。

import reactor.core.publisher.Flux;public class ReactorScanExample {public static void main(String[] args) {Flux<Integer> source = Flux.just(1, 2, 3, 4, 5);// 对数据流中的元素进行累积操作source.scan(0, (acc, value) -> acc + value).subscribe(System.out::println);}
}

83. 使用 Reactor 的 takeWhile 方法进行条件性的元素获取

takeWhile 方法用于根据指定的条件获取数据流中的元素,直到条件不满足。

import reactor.core.publisher.Flux;public class ReactorTakeWhileExample {public static void main(String[] args) {Flux<Integer> source = Flux.just(1, 2, 3, 4, 5);// 根据条件获取元素,直到条件不满足source.takeWhile(value -> value < 4).subscribe(System.out::println);}
}

84. 使用 Reactor 的 thenMany 方法进行串联操作

thenMany 方法用于在当前数据流完成后执行另一个数据流,将它们串联起来。

import reactor.core.publisher.Flux;public class ReactorThenManyExample {public static void main(String[] args) {Flux<Integer> source1 = Flux.just(1, 2, 3);Flux<Integer> source2 = Flux.just(4, 5, 6);// 在当前数据流完成后执行另一个数据流source1.thenMany(source2).subscribe(System.out::println);}
}

85. 使用 Reactor 的 ignoreElements 方法忽略所有元素

ignoreElements 方法用于忽略数据流中的所有元素,只关注完成信号或错误信号。

import reactor.core.publisher.Flux;public class ReactorIgnoreElementsExample {public static void main(String[] args) {Flux<Integer> source = Flux.just(1, 2, 3);// 忽略所有元素,只关注完成信号source.ignoreElements().doOnTerminate(() -> System.out.println("Completed")).subscribe();}
}

在 Reactor 中,Sink 是一个用于手动推送元素(signals)到 Subscriber 的接口。它允许你在创建 Flux 或 Mono 的过程中手动控制元素的生成。Reactor 提供了两种 SinkFluxSink 用于创建 Flux,MonoSink 用于创建 Mono。

98. 使用 FluxSink 发送元素和完成信号

import reactor.core.publisher.Flux;public class FluxSinkExample {public static void main(String[] args) {Flux.create(fluxSink -> {for (int i = 0; i < 5; i++) {fluxSink.next(i); // 发送元素}fluxSink.complete(); // 发送完成信号}).subscribe(System.out::println);}
}

99. 使用 FluxSink 发送元素和错误信号

import reactor.core.publisher.Flux;public class FluxSinkErrorExample {public static void main(String[] args) {Flux.create(fluxSink -> {for (int i = 0; i < 5; i++) {fluxSink.next(i); // 发送元素}fluxSink.error(new RuntimeException("Simulated error")); // 发送错误信号}).subscribe(System.out::println,error -> System.err.println("Error: " + error.getMessage()));}
}

100. 使用 MonoSink 发送元素和完成信号

import reactor.core.publisher.Mono;public class MonoSinkExample {public static void main(String[] args) {Mono.create(monoSink -> {monoSink.success("Hello, Mono!"); // 发送元素}).subscribe(System.out::println);}
}

101. 使用 MonoSink 发送错误信号

import reactor.core.publisher.Mono;public class MonoSinkErrorExample {public static void main(String[] args) {Mono.create(monoSink -> {monoSink.error(new RuntimeException("Simulated error")); // 发送错误信号}).subscribe(System.out::println,error -> System.err.println("Error: " + error.getMessage()));}
}

102. 使用 FluxSink 进行背压控制

在 Reactor 中,FluxSink 也提供了一些方法用于实现背压控制,以避免在高速生产者和低速消费者之间的元素溢出。

import reactor.core.publisher.Flux;
import reactor.core.publisher.FluxSink;public class FluxSinkBackpressureExample {public static void main(String[] args) {Flux.create(fluxSink -> {for (int i = 0; i < 1000; i++) {fluxSink.next(i);}}, FluxSink.OverflowStrategy.BUFFER) // 指定背压策略.onBackpressureBuffer(10, buffer -> System.err.println("Buffer overflow! Discarding: " + buffer)).subscribe(value -> {// 模拟慢速消费者try {Thread.sleep(10);} catch (InterruptedException e) {e.printStackTrace();}System.out.println(value);});}
}

在上述例子中,通过指定 FluxSink.OverflowStrategy.BUFFER 背压策略,当消费者无法跟上生产者的速度时,缓冲区将被用来存储元素。使用 onBackpressureBuffer 方法可以在溢出时执行自定义的操作。

103. 使用 FluxSink 进行手动请求

FluxSink 也提供了 request 方法,允许消费者手动请求元素。

import reactor.core.publisher.Flux;
import reactor.core.publisher.FluxSink;public class FluxSinkManualRequestExample {public static void main(String[] args) {Flux.create(fluxSink -> {for (int i = 0; i < 100; i++) {fluxSink.next(i);if (i % 10 == 0 && fluxSink.requestedFromDownstream() == 0) {// 当请求的元素达到 0 时,等待下游再次请求while (fluxSink.requestedFromDownstream() == 0) {// 等待下游请求try {Thread.sleep(10);} catch (InterruptedException e) {e.printStackTrace();}}}}fluxSink.complete();}).subscribe(System.out::println);}
}

在这个例子中,当消费者请求的元素达到 0 时,生产者会等待下游再次请求。这种手动控制请求的方式可以更灵活地处理背压。

107. 使用 Reactor 的 Hooks 进行全局错误处理

Hooks 是 Reactor 提供的一组钩子,可以用于全局错误处理,捕获整个流的错误。

import reactor.core.publisher.Flux;
import reactor.core.publisher.Hooks;public class ReactorHooksErrorHandlingExample {public static void main(String[] args) {// 使用 Hooks 进行全局错误处理Hooks.onOperatorError((error, reference) -> {System.err.println("Global Error Handling: " + error.getMessage());return error;});Flux<Integer> source = Flux.just(1, 2, 0, 4, 5);// 流中的错误将被全局处理source.map(x -> 10 / x).subscribe(data -> System.out.println("Received: " + data),error -> System.err.println("Subscriber Error: " + error.getMessage()));}
}

在这个例子中,我们使用 Hooks.onOperatorError 来设置全局错误处理,当流中发生错误时,会调用全局错误处理的回调方法。这可以用于捕获整个流的错误,而不是每个 subscribe 中单独处理。

109. 使用 Reactor 的 ConnectableFlux 进行热序列

ConnectableFlux 是 Reactor 提供的一种特殊类型的 Flux,它允许在订阅之前预热(开始生成元素),并在多个订阅者之间共享相同的序列。

import reactor.core.publisher.ConnectableFlux;
import reactor.core.publisher.Flux;import java.time.Duration;public class ReactorConnectableFluxExample {public static void main(String[] args) {ConnectableFlux<Integer> connectableFlux = Flux.range(1, 3).delayElements(Duration.ofSeconds(1)).publish(); // 将普通的 Flux 转换为 ConnectableFluxconnectableFlux.connect(); // 开始生成元素// 第一个订阅者connectableFlux.subscribe(data -> System.out.println("Subscriber 1: " + data));try {Thread.sleep(2000);} catch (InterruptedException e) {e.printStackTrace();}// 第二个订阅者,共享相同的序列connectableFlux.subscribe(data -> System.out.println("Subscriber 2: " + data));// 结果:// Subscriber 1: 1// Subscriber 1: 2// Subscriber 2: 2// Subscriber 1: 3// Subscriber 2: 3}
}

在这个例子中,我们使用 publish 方法将普通的 Flux 转换为 ConnectableFlux,通过 connect 方法开始生成元素。第一个订阅者在元素生成过程中订阅,然后等待了 2 秒后,第二个订阅者也开始订阅,两者共享相同的序列。这种方式可以用于创建热序列,使得订阅者能够共享相同的元素序列。

110. 使用 Reactor 的 Flux.defer 实现延迟订阅

Flux.defer 允许你在每次订阅时创建一个新的 Flux,从而实现延迟订阅。这对于需要在每次订阅时执行一些逻辑的场景非常有用。

import reactor.core.publisher.Flux;public class ReactorFluxDeferExample {public static void main(String[] args) {Flux<Integer> deferredFlux = Flux.defer(() -> {// 在每次订阅时创建新的 FluxSystem.out.println("Creating new Flux");return Flux.just(1, 2, 3);});// 第一个订阅deferredFlux.subscribe(data -> System.out.println("Subscriber 1: " + data));// 第二个订阅deferredFlux.subscribe(data -> System.out.println("Subscriber 2: " + data));// 结果:// Creating new Flux// Subscriber 1: 1// Subscriber 1: 2// Subscriber 1: 3// Creating new Flux// Subscriber 2: 1// Subscriber 2: 2// Subscriber 2: 3}
}

在这个例子中,Flux.defer 中的 lambda 表达式将在每次订阅时执行,因此每个订阅都会创建一个新的 Flux。这对于那些需要在每次订阅时重新生成数据的情况非常有用。

119. 使用 Reactor 的 Flux.handle 处理元素和错误

Flux.handle 方法用于处理元素和错误,通过提供一个 BiConsumer 处理每个元素,并通过提供一个 BiConsumer 处理错误。

import reactor.core.publisher.Flux;public class ReactorFluxHandleExample {public static void main(String[] args) {Flux<Integer> source = Flux.just(1, 2, 0, 4, 5);// 处理元素和错误Flux<Integer> handledFlux = source.handle((value, sink) -> {if (value != 0) {sink.next(value); // 处理元素} else {sink.error(new RuntimeException("Cannot divide by zero")); // 处理错误}});handledFlux.subscribe(System.out::println,error -> System.err.println("Error: " + error.getMessage()));}
}

在这个例子中,我们使用 Flux.handle 处理每个元素,如果元素不为零,则将其发送到下游;如果元素为零,则通过 sink.error 处理错误。这可以用于处理元素和错误的场景。

120. 使用 Reactor 的 Mono.handle 处理元素和错误

Mono.handle 方法与 Flux.handle 类似,用于处理单个元素和错误。

import reactor.core.publisher.Mono;public class ReactorMonoHandleExample {public static void main(String[] args) {Mono<Integer> source = Mono.just(10);// 处理元素和错误Mono<Integer> handledMono = source.handle((value, sink) -> {if (value > 0) {sink.next(value); // 处理元素} else {sink.error(new RuntimeException("Invalid value")); // 处理错误}});handledMono.subscribe(System.out::println,error -> System.err.println("Error: " + error.getMessage()));}
}

在这个例子中,我们使用 Mono.handle 处理单个元素,如果元素为正数,则发送到下游;如果元素不为正数,则通过 sink.error 处理错误。这可以用于处理单个元素和错误的场景。

太太太多了,到此为止吧~~~~

学习打卡day08:响应式编程Reactor API大全(下)

相关文章:

响应式编程Reactor API大全(下)

Reactor 是一个基于响应式编程的库&#xff0c;主要用于构建异步和事件驱动的应用程序。Reactor 提供了丰富的 API&#xff0c;包括创建、转换、过滤、组合等操作符&#xff0c;用于处理异步数据流。以下是一些 Reactor 的主要 API 示例&#xff1a; pom依赖 <dependencyMan…...

【STM32】HAL库的STOP低功耗模式UART串口唤醒,解决首字节出错的问题(全网第一解决方案)

【STM32】HAL库的STOP低功耗模式UART串口唤醒&#xff0c;解决首字节出错的问题&#xff08;全网第一解决方案&#xff09; 前文&#xff1a; 【STM32】HAL库的STOP低功耗模式UART串口唤醒&#xff0c;第一个接收字节出错的问题&#xff08;疑难杂症&#xff09; 目前已解决 …...

Python 语法糖

一、基本概念 语法糖&#xff0c;可以理解为&#xff1a;“甜蜜” 的便捷语法。 它是编程语言为程序提供的更简洁、更易读的语法实现的语法结构&#xff0c;它并不影响语言的功能&#xff0c;仅仅是一种更便捷的书写方式。 这就像你制作蛋糕时&#xff0c;使用现代烤箱而不是…...

一个小程序跳转到另一个小程序中如何实现

小程序 保证两个小程序是一样的主体才可以跳转。怎么知道是不是同样的主体呢&#xff1f; 小程序的后台管理-设置-基本设置-基本信息。查看主体信息。 跳转 <button clicktoOtherMini()>跳转到另一个小程序</button> function toOtherMini(){wx.navigateToMini…...

STM32+HAL库驱动ADXL345传感器(SPI协议)

STM32HAL库驱动ADXL345传感器&#xff08;SPI协议&#xff09; ADXL345传感器简介实物STM32CubeMX配置SPI配置片选引脚配置串口配置 特别注意&#xff08;重点部分&#xff09;核心代码效果展示 ADXL345传感器简介 ADXL345 是 ADI 公司推出的基于 iMEMS 技术的 3 轴、数字输出加…...

Redis实现全局唯一Id

一、全局唯一ID 每个店铺都可以发布优惠券&#xff1a; 当用户抢购时&#xff0c;就会生成订单并保存到tb_voucher_order这张表中&#xff0c;而订单表如果使用数据库自增ID就存在一些问题&#xff1a; id的规律性太明显 受单表数据量的限制 场景分析&#xff1a;如果我们的…...

【J-Flash基本使用总结】

【J-Flash基本使用总结】 VX&#xff1a;hao541022348 ■ 烧录文件■ 创建新的工程■ 烧录模式-SWD模式■ J-Flash下载程序到单片机 ■ J-Flash拼接多个hex或bin文件■ J-Flash读单片机的option byte■ J-Flash读单片机Flash数据■ 将读出来的文件用jflash烧录到其他的芯片■ 设…...

宝塔发布网站问题汇总和记录

1、添加网站站点后打不开 解决办法&#xff0c;关闭防跨站攻击2 2、laravel项目部署到linux的时候出现The stream or file "/home/www/storage/logs/laravel.log" could not be opened in append mode 给目录加权限 chmod -R 777 storage 3、Class "Redis"…...

决战排序之巅(二)

决战排序之巅&#xff08;二&#xff09; 排序测试函数 void verify(int* arr, int n) 归并排序递归方案代码可行性测试 非递归方案代码可行性测试 特点分析 计数排序代码实现代码可行性测试 特点分析 归并排序 VS 计数排序&#xff08;Release版本&#xff09;说明1w rand( ) …...

自动化网络监控:每分钟自动检测网站可用性

&#x1f9d9;‍♂️ 诸位好&#xff0c;吾乃诸葛妙计&#xff0c;编程界之翘楚&#xff0c;代码之大师。算法如流水&#xff0c;逻辑如棋局。 &#x1f4dc; 吾之笔记&#xff0c;内含诸般技术之秘诀。吾欲以此笔记&#xff0c;传授编程之道&#xff0c;助汝解技术难题。 &…...

Asp .Net Core 系列:集成 Ocelot+Consul实现网关、服务注册、服务发现

什么是Ocelot? Ocelot是一个开源的ASP.NET Core微服务网关&#xff0c;它提供了API网关所需的所有功能&#xff0c;如路由、认证、限流、监控等。 Ocelot是一个简单、灵活且功能强大的API网关&#xff0c;它可以与现有的服务集成&#xff0c;并帮助您保护、监控和扩展您的微…...

MSSQL行转列、列转行

行转列 SELECT * FROM student PIVOT ( SUM(score) FOR subject IN (语文, 数学, 英语) ) AS PivotedData; 列转行 SELECT * FROM student1 UNPIVOT ( score FOR subject IN ("语文","数学","英语") )AS PivotedData;...

【MySQL】创建和管理表

文章目录 前置 标识符命名规则一、MySQL数据类型二、创建和管理数据库2.1 创建数据库2.2 使用数据库2.3 修改数据库2.4 删除数据库 三、创建表3.1 创建方式一3.2 创建方式二3.3 查看数据表结构 四、修改表4.1 增加一个列4.2 修改一个列4.3 重命名一个列4.4 删除一个列 五、重命…...

缓存和数据库一致性

前言&#xff1a; 项目的难点是如何保证缓存和数据库的一致性。无论我们是先更新数据库&#xff0c;后更新缓存还是先更新数据库&#xff0c;然后删除缓存&#xff0c;在并发场景之下&#xff0c;仍然会存在数据不一致的情况&#xff08;也存在删除失败的情况&#xff0c;删除…...

iOS UI掉帧和卡顿优化解决方案记录

UI卡顿原理 在 VSync 信号到来后&#xff0c;系统图形服务会通过 CADisplayLink 等机制通知 App&#xff0c;App 主线程开始在 CPU 中计算显示内容&#xff0c;比如视图的创建、布局计算、图片解码、文本绘制等。随后 CPU 会将计算好的内容提交到 GPU 去&#xff0c;由 GPU 进行…...

transbigdata 笔记: 轨迹密集化/稀疏化 轨迹平滑

1 密集化 transbigdata.traj_densify(data, col[Vehicleid, Time, Lng, Lat], timegap15) 轨迹致密化&#xff0c;保证至多每隔timegap秒都有一个轨迹点 这边插补使用的是pandas的interpolate&#xff0c;method设置的是index 1.1 举例 transbigdata 笔记&#xff1a; 官方…...

反向代理的本质是什么?

反向代理是一种网络架构模式&#xff0c;通常用于提供静态内容、处理安全、负载均衡和缓存等任务。在这种架构中&#xff0c;客户端发送的请求首先到达反向代理服务器&#xff0c;然后由反向代理服务器将请求转发给后端的实际服务器。反向代理服务器可以处理和修改请求和响应&a…...

Kali Linux保姆级教程|零基础从入门到精通,看完这一篇就够了!(附工具包)

作为一名从事网络安全的技术人员&#xff0c;不懂Kali Linux的话&#xff0c;连脚本小子都算不上。 Kali Linux预装了数百种享誉盛名的渗透工具&#xff0c;使你可以更轻松地测试、破解以及进行与数字取证相关的任何其他工作。 今天给大家分享一套Kali Linux资料合集&#xf…...

UML-用例图

提示&#xff1a;用例图是软件建模的开始&#xff0c;软件建模中的其他图形都将以用例图为依据。用例图列举了系统所需要实现的所有功能&#xff0c;除了用于软件开发的需求分析阶段&#xff0c;也可用于软件的系统测试阶段。 UML-用例图 一、用例图的基础知识1.用例图的构成元…...

jmeter--8.加密传输

目录 1. Base64加密 2. MD5加密 3. SHA加密&#xff08;sha1\sha\sha224\sha256\sha384\sha512&#xff09; 4. RSA加密-公钥加密&#xff0c;私钥解密 1. Base64加密 1.1 在需要加密传输的接口下新增BeanShell 预处理程序&#xff0c;${username}可替换成value值&#xff…...

stm32G473的flash模式是单bank还是双bank?

今天突然有人stm32G473的flash模式是单bank还是双bank&#xff1f;由于时间太久&#xff0c;我真忘记了。搜搜发现&#xff0c;还真有人和我一样。见下面的链接&#xff1a;https://shequ.stmicroelectronics.cn/forum.php?modviewthread&tid644563 根据STM32G4系列参考手…...

docker详细操作--未完待续

docker介绍 docker官网: Docker&#xff1a;加速容器应用程序开发 harbor官网&#xff1a;Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台&#xff0c;用于将应用程序及其依赖项&#xff08;如库、运行时环…...

大数据零基础学习day1之环境准备和大数据初步理解

学习大数据会使用到多台Linux服务器。 一、环境准备 1、VMware 基于VMware构建Linux虚拟机 是大数据从业者或者IT从业者的必备技能之一也是成本低廉的方案 所以VMware虚拟机方案是必须要学习的。 &#xff08;1&#xff09;设置网关 打开VMware虚拟机&#xff0c;点击编辑…...

相机从app启动流程

一、流程框架图 二、具体流程分析 1、得到cameralist和对应的静态信息 目录如下: 重点代码分析: 启动相机前,先要通过getCameraIdList获取camera的个数以及id,然后可以通过getCameraCharacteristics获取对应id camera的capabilities(静态信息)进行一些openCamera前的…...

CSS设置元素的宽度根据其内容自动调整

width: fit-content 是 CSS 中的一个属性值&#xff0c;用于设置元素的宽度根据其内容自动调整&#xff0c;确保宽度刚好容纳内容而不会超出。 效果对比 默认情况&#xff08;width: auto&#xff09;&#xff1a; 块级元素&#xff08;如 <div>&#xff09;会占满父容器…...

视频行为标注工具BehaviLabel(源码+使用介绍+Windows.Exe版本)

前言&#xff1a; 最近在做行为检测相关的模型&#xff0c;用的是时空图卷积网络&#xff08;STGCN&#xff09;&#xff0c;但原有kinetic-400数据集数据质量较低&#xff0c;需要进行细粒度的标注&#xff0c;同时粗略搜了下已有开源工具基本都集中于图像分割这块&#xff0c…...

Linux 内存管理实战精讲:核心原理与面试常考点全解析

Linux 内存管理实战精讲&#xff1a;核心原理与面试常考点全解析 Linux 内核内存管理是系统设计中最复杂但也最核心的模块之一。它不仅支撑着虚拟内存机制、物理内存分配、进程隔离与资源复用&#xff0c;还直接决定系统运行的性能与稳定性。无论你是嵌入式开发者、内核调试工…...

【电力电子】基于STM32F103C8T6单片机双极性SPWM逆变(硬件篇)

本项目是基于 STM32F103C8T6 微控制器的 SPWM(正弦脉宽调制)电源模块,能够生成可调频率和幅值的正弦波交流电源输出。该项目适用于逆变器、UPS电源、变频器等应用场景。 供电电源 输入电压采集 上图为本设计的电源电路,图中 D1 为二极管, 其目的是防止正负极电源反接, …...

【JavaSE】多线程基础学习笔记

多线程基础 -线程相关概念 程序&#xff08;Program&#xff09; 是为完成特定任务、用某种语言编写的一组指令的集合简单的说:就是我们写的代码 进程 进程是指运行中的程序&#xff0c;比如我们使用QQ&#xff0c;就启动了一个进程&#xff0c;操作系统就会为该进程分配内存…...

TSN交换机正在重构工业网络,PROFINET和EtherCAT会被取代吗?

在工业自动化持续演进的今天&#xff0c;通信网络的角色正变得愈发关键。 2025年6月6日&#xff0c;为期三天的华南国际工业博览会在深圳国际会展中心&#xff08;宝安&#xff09;圆满落幕。作为国内工业通信领域的技术型企业&#xff0c;光路科技&#xff08;Fiberroad&…...