Java异步编程
Java异步编程
- 1、什么是java异步编程
- 2、异步编程有什么作用
- 3、异步编程常用于哪些业务
- 4、异步编程的方式
- 5、@Async异步调用
- @Async简介
1、什么是java异步编程
- Java异步编程是一种处理并发问题的技术,它可以在执行耗时操作的同时,不阻塞主线程,从而提高程序的性能和响应速度。
- 在传统的同步编程中,程序需要等待一个操作完成后才能继续执行下一个操作,这样可能会导致程序阻塞,降低程序的性能和响应速度。
- 而异步编程则可以让程序在执行一个耗时操作的同时,继续执行其他操作,从而提高程序的并发能力和响应速度。
2、异步编程有什么作用
Java异步编程可以带来以下几个方面的作用:
-
提高程序性能和响应速度:异步编程可以让程序在执行一个耗时操作的同时,继续执行其他操作,从而提高程序的并发能力和响应速度。
-
改善用户体验:异步编程可以让程序在执行一些耗时操作时,不会导致界面卡死,从而改善用户的使用体验。
-
提高资源利用率:异步编程可以让程序在等待一个操作完成时,可以继续执行其他操作,从而提高资源的利用率。
-
实现多任务并行处理:异步编程可以让程序同时处理多个任务,从而提高程序的并行处理能力。
-
简化程序逻辑:异步编程可以让程序的代码更加简洁,避免使用繁琐的回调函数和线程管理代码,提高程序的可读性和可维护性。
Java异步编程可以提高程序的性能和响应速度,改善用户的使用体验,提高资源的利用率,实现多任务并行处理,并简化程序的逻辑。
3、异步编程常用于哪些业务
Java异步编程通常应用于以下几个业务场景:
-
网络通信:网络通信是一个比较耗时的操作,使用异步编程可以在等待网络通信结果的同时,继续执行其他操作,提高程序的响应速度。
-
数据库操作:数据库操作也是一个比较耗时的操作,使用异步编程可以在等待数据库操作结果的同时,继续执行其他操作,提高程序的并发能力和响应速度。
-
文件操作:文件读写操作也是一个比较耗时的操作,使用异步编程可以在等待文件读写结果的同时,继续执行其他操作,提高程序的并发能力和响应速度。
-
图像处理:图像处理通常需要大量的计算和I/O操作,使用异步编程可以将这些操作异步处理,提高程序的性能和响应速度。
-
音视频处理:音视频处理也是一个比较耗时的操作,使用异步编程可以在等待音视频处理结果的同时,继续执行其他操作,提高程序的并发能力和响应速度。
Java异步编程可以应用于各种需要耗时操作的业务场景,通过异步处理可以提高程序的并发能力和响应速度,从而提升用户的使用体验。
4、异步编程的方式
Java异步编程的方式有以下几种:
-
回调函数:回调函数是一种基于接口的编程方式,可以在异步操作完成后调用回调函数来处理异步操作的结果。
-
Future/Promise
:Future/Promise是一种将异步操作的结果封装到Future对象中,可以通过Future对象来获取异步操作的结果。 -
CompletableFuture
:CompletableFuture是Java 8中引入的一种基于Future的异步编程方式,支持链式调用和组合异步操作,使得异步编程更加简单和灵活。 -
RxJava
:RxJava是一个基于响应式编程的Java库,支持异步和并发编程,可以简化异步编程的复杂性。 -
Actor
模型:Actor模型是一种基于消息传递的并发编程模型,每个Actor都是一个独立的执行单元,通过消息传递来实现异步操作。
Java异步编程可以使用多种方式来实现,每种方式都有其优点和适用场景,根据具体的业务需求选择合适的异步编程方式可以提高程序的性能和响应速度。
5、@Async异步调用
这里详细说明以下使用spring
中@Async
的异步调用。
@Async简介
@Async
是Spring框架中提供的一种注解,用于将方法标记为异步执行,让方法在新的线程中执行,从而实现异步调用。
使用@Async注解需要满足以下条件:
-
必须在
Spring
应用程序上下文中使用。 -
必须在异步方法所在的类上添加
@EnableAsync
注解。 -
异步方法必须是
public
方法。 -
异步方法必须返回void或者
Future
对象。 -
如果返回Future对象,则必须确保
Future
对象在异步方法执行完成后能够正确返回异步方法的结果。
简单示例: 如下定义了一个异步执行配置类,主要是通过Spring提供的 @EnableAsync
注解开启异步执行的支持,同时使用 @Bean
注解注册了一个线程池 getAsyncExecutor
,该线程池可以用于异步执行任务,包括一些比较耗时的操作,例如发送邮件、处理图片等,从而避免在主线程中执行这些任务导致系统响应变慢。
@Configuration
@EnableAsync
public class AppConfig implements AsyncConfigurer {// 配置相关Bean@Overridepublic Executor getAsyncExecutor() {ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();executor.setCorePoolSize(3);executor.setMaxPoolSize(10);executor.setQueueCapacity(30);executor.setThreadNamePrefix("MyExecutor-");executor.initialize();return executor;}
}
在上述配置中,定义了一个核心线程数为3,最大线程数为10的线程池,并且设置了线程池名称前缀、缓冲队列大小等参数。
通过 initialize()
方法初始化线程池,并通过 @Bean
注解将该线程池注册到Spring容器中,其他的组件可以直接使用该线程池进行异步任务的执行。
具体参数说明:
ThreadPoolTaskExecutor
是Spring提供的一个线程池实现,通过配置corePoolSize 、 maxPoolSize 、 queueCapacity
等参数,可以灵活地控制线程池的大小和执行效率。corePoolSize
表示线程池的核心线程数,即在没有任务执行时线程池的大小- 而
maxPoolSize
表示线程池最大的线程数,即当任务数量达到queueCapacity
时,线程池会扩展到该大小。
下面是一个简单的示例,演示了如何使用@Async
注解实现异步调用,使用@Async
注解标记了一个名为doSomething()
的方法,这个方法会在新的线程中异步执行。在调用这个方法时,方法会立即返回,不会阻塞当前线程,从而实现了异步调用。
@Service
@EnableAsync
public class MyService {@Asyncpublic void doSomething() {// 执行一些耗时的操作// ...}
}
相关文章:
Java异步编程
Java异步编程 1、什么是java异步编程2、异步编程有什么作用3、异步编程常用于哪些业务4、异步编程的方式5、Async异步调用Async简介 1、什么是java异步编程 Java异步编程是一种处理并发问题的技术,它可以在执行耗时操作的同时,不阻塞主线程,…...

C++类与对象(二)——构造函数与析构函数
文章目录 一.类的默认6个成员函数二.构造函数1.引例2.构造函数的概念及特性 三.析构函数😋析构函数的特性 前言: 上篇文章初步认识了类以及类的相关知识,本篇将继续深入学习类与对象——类的默认6个成员函数: 一.类的默认6个成员函…...

c++标准模板(STL)(std::array)(四)
定义于头文件 <array> template< class T, std::size_t N > struct array;(C11 起) std::array 是封装固定大小数组的容器。 此容器是一个聚合类型,其语义等同于保有一个 C 风格数组 T[N] 作为其唯一非静态数据成员的结构体。不同于 C 风格数…...

vue3计算属性
计算属性 模板中的表达式虽然方便,但也只能用来做简单的操作。如果在模板中写太多逻辑,会让模板变得臃肿,难以维护。推荐使用计算属性来描述依赖响应式状态的复杂逻辑 基础示例 不够好的示例 模板中使用了表达式,不够直观&…...
Java 中的访问修饰符有哪些(九)
Java 中的访问修饰符用于限制类、接口、字段和方法的访问范围,它们分别表示不同的访问控制级别。Java 中共有四种访问修饰符:public、protected、default 和 private。 public public 是最开放的访问修饰符,用于指定公共访问级别。被 publi…...

HR员工管理的三重境界:管事、管人、管心
在一个公司里,员工来来往往是常态,虽说我们不能替他们决定,但是一定是与公司的管理者有一定的关系。马云曾经说过:“一个员工离职,不外乎两种原因,一是钱没给到位;二是心里委屈了”。一句话就是…...

延迟队列与SpringBoot实战
延迟队列与SpringBoot实战 概念 延时队列,队列内部是有序的,最重要的特性就体现在它的延时属性上,延时队列中的元素是希望在指定时间到了以后或之前取出和处理,简单来说,延时队列就是用来存放需要在指定时间被处理的元素的队列 …...
【算法】九键输入法
题目: 输入数字字符串, 输出这串字符对应的九键输入法有可能出现的所有情况 算法: 定义了一个全局变量 g_numStr,其中存储了每个数字对应的字母。定义了一个递归函数 str_combine,用于将每个数字对应的字母进行组合。str_combin…...

jvm之类加载器
写在前面 当我们通过javac命令将java源代码编译为Java字节码后,必须通过类加载器将其加载到jvm中才能运行,所以类加载器是jvm中非常重要的一个组成部分,本文我们就一起来看下吧! 1:类的生命周期 类的生命周期如下图…...

Chapter4:频率响应法(上)
第四章:频率响应法 Exercise4.1 已知微分网络和积分网络电路图如下图所示,求网络的频率特性。 解: 【图 ( a ) ({\rm a}) (a)微分网络】 由微分网络电路图可得:...

【6. 激光雷达接入ROS】
欢迎大家阅读2345VOR的博客【6. 激光雷达接入ROS】🥳🥳🥳 2345VOR鹏鹏主页: 已获得CSDN《嵌入式领域优质创作者》称号👻👻👻,座右铭:脚踏实地,仰望星空&#…...

Java 基础进阶篇(三)—— 面向对象的三大特征之二:继承
文章目录 一、继承概述二、内存运行原理 ★三、继承的特点四、继承后:成员变量和方法的访问特点五、继承后:方法重写六、继承后:子类构造器的特点七、继承后:子类构造器访问父类有参构造器八、this、super 总结 一、继承概述 Jav…...
[angstromctf 2023] 部分
这个比赛打了个开头就放弃了,最近放弃的比较多,国外的网太慢,国内的题太难。 Crypto ranch 这题直接给出密文这提示 rtkw{cf0bj_czbv_nvcc_y4mv_kf_kip_re0kyvi_uivjj1ex_5vw89s3r44901831} Caesar dressing is so 44 BC... 然后是加密程序…...

死信队列
死信队列 死信的概念 先从概念解释上搞清楚这个定义,死信,顾名思义就是无法被消费的消息,字面意思可以这样理解,一般来说,producer 将消息投递到 broker 或者直接到queue 里了,consumer 从 queue 取出消息…...

基于YOLOv5的目标检测系统详解(附MATLAB GUI版代码)
摘要:本文重点介绍了基于YOLOv5目标检测系统的MATLAB实现,用于智能检测物体种类并记录和保存结果,对各种物体检测结果可视化,提高目标识别的便捷性和准确性。本文详细阐述了目标检测系统的原理,并给出MATLAB的实现代码…...

使用ChatGPT工具阅读文献的实战教程
大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…...
实训笔记1
实训笔记 第一天 1.安装tomcat或者其他大数据开发的路径不含中文及空格 2.和同开发 [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-FoApp1oX-1683039421826)(C:\Users\18249\AppData\Roaming\Typora\typora-user-images\image-20230422110823748…...

CCD视觉检测设备如何选择光源
CCD视觉检测设备的机器视觉系统对光源的要求很高,光源是决定图像质量的一个重要因素。那么,我们就来看看CCD图像加网设备和机器视觉系统光源的选择点——CCD图像加网设备。 CCD视觉检测设备机器视觉系统光源选择要点: 1. 对比度:…...

基于协同过滤的旅游推荐系统设计与实现(论文+源码)_kaic
1 绪论 1.1 研究背景及意义 1.2 国内外研究现状 1.3 研究目标与意义 1.4 主要研究工作 2 相关理论介绍 2.1HTML与JavaScript 2.2 MySQL数据库 2.3 协同过滤算法简介 3 系统分析与设计 3.1 系统需求分析 3.1.1 功能性需求 3.1.2 安全性需求 3.2 系统总体架构 3.3 功能模块设计 3…...
代码随想录补打卡 746 使用最小花费爬楼梯
代码如下 func minCostClimbingStairs(cost []int) int { dp : make([]int,len(cost)1) //思路:设置一个花费数组dp,dp数组的长度等于之前的cost在加上1(1为楼顶元素) dp[0] 0 dp[1] 0 for i : 2 ; i < len(c…...
vscode里如何用git
打开vs终端执行如下: 1 初始化 Git 仓库(如果尚未初始化) git init 2 添加文件到 Git 仓库 git add . 3 使用 git commit 命令来提交你的更改。确保在提交时加上一个有用的消息。 git commit -m "备注信息" 4 …...

Flask RESTful 示例
目录 1. 环境准备2. 安装依赖3. 修改main.py4. 运行应用5. API使用示例获取所有任务获取单个任务创建新任务更新任务删除任务 中文乱码问题: 下面创建一个简单的Flask RESTful API示例。首先,我们需要创建环境,安装必要的依赖,然后…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)
服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

ESP32读取DHT11温湿度数据
芯片:ESP32 环境:Arduino 一、安装DHT11传感器库 红框的库,别安装错了 二、代码 注意,DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...
服务器硬防的应用场景都有哪些?
服务器硬防是指一种通过硬件设备层面的安全措施来防御服务器系统受到网络攻击的方式,避免服务器受到各种恶意攻击和网络威胁,那么,服务器硬防通常都会应用在哪些场景当中呢? 硬防服务器中一般会配备入侵检测系统和预防系统&#x…...

Springcloud:Eureka 高可用集群搭建实战(服务注册与发现的底层原理与避坑指南)
引言:为什么 Eureka 依然是存量系统的核心? 尽管 Nacos 等新注册中心崛起,但金融、电力等保守行业仍有大量系统运行在 Eureka 上。理解其高可用设计与自我保护机制,是保障分布式系统稳定的必修课。本文将手把手带你搭建生产级 Eur…...
力扣-35.搜索插入位置
题目描述 给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。 请必须使用时间复杂度为 O(log n) 的算法。 class Solution {public int searchInsert(int[] nums, …...
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...
Fabric V2.5 通用溯源系统——增加图片上传与下载功能
fabric-trace项目在发布一年后,部署量已突破1000次,为支持更多场景,现新增支持图片信息上链,本文对图片上传、下载功能代码进行梳理,包含智能合约、后端、前端部分。 一、智能合约修改 为了增加图片信息上链溯源,需要对底层数据结构进行修改,在此对智能合约中的农产品数…...

视频行为标注工具BehaviLabel(源码+使用介绍+Windows.Exe版本)
前言: 最近在做行为检测相关的模型,用的是时空图卷积网络(STGCN),但原有kinetic-400数据集数据质量较低,需要进行细粒度的标注,同时粗略搜了下已有开源工具基本都集中于图像分割这块,…...