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

javalock(六)CyclicBarrier

注意:CyclicBarrier不是AQS的派生类,而是CyclicBarrier内部使用了ReentrantLock.Condition

和CountDownLatch一样,都是计数减为0就可以成功获取锁

和CountDownLatch不同的是:

  1:CountDownLatch的await和countdown操作是分开的即锁获取和锁释放是两个不同的操作,即一个线程先countdown,把计数-1,然后再await等待计数降为0,而CyclicBarrier中则合二为一了,就是说直接await,await一个函数做完两件事:countdown 扣减资源,然后await等待计数为02:CyclicBarrier是可充用的,也就是说唤醒一次后CyclicBarrier会重置状态,需要重新扣减计数,直到计数再次为0才会放行,而CountDownLatch则只其作用一次,一旦计数为0,则此后则不再恢复计数,也就是说此后任何请求都会直接放行

CyclicBarrier可重用的意思是内部有一个Generation变量,记录当前是第几代,如果计数为0就表示本轮计数完成了,然后通知所有阻塞的线程,通知完后再创建一个新的generation对象,就表示已经进入下一轮迭代了,其他线程被唤醒后如果检测到当前他休眠时记录的generation和当前的generation不是同一个,就表明generation已经进入下一轮了,所以自己可以成功唤醒了


import java.util.concurrent.BrokenBarrierException;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.TimeoutException;
import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.ReentrantLock;public class CyclicBarrier {private static class Generation {boolean broken = false;}//CyclicBarrier是基于ReentrantLock的条件变量的private final ReentrantLock lock = new ReentrantLock();//条件变量private final Condition trip = lock.newCondition();//记录初始限额,进入下一轮的时候会把计数恢复到初始限额private final int parties;//当计数降到0的时候执行指定的函数,由用户指定private final Runnable barrierCommand;//记录当前是第几轮,进入新的一轮计数时会创建一个新的generationprivate Generation generation = new Generation();//计数,每当count降为0就表明本轮结束了,可以唤醒所有等待的线程了//进入下一轮后会把count恢复到partiesprivate int count;//进入下一轮:通知上一轮所有等待的线程,通知完后会再更新状态以进入下一轮//这个函数在持有锁的情况下才会被调用private void nextGeneration() {//signalAll就是把trip这个condition对应的condition list中的所有node丢到sync list//丢完以后signalAll就结束了,但是其他线程只是丢到了sync list,并没有获取锁//所以其他被唤醒的线程需要重新竞争锁,但是nextGeneration是在有锁的情况下调用的//所以这里signalAll后就可以直接更新generation和count因为其他线程此时没有锁,//是做不了任何事的,所以这里更新generation不会造成并发错误trip.signalAll();count = parties;generation = new Generation();}//打破栅栏,也就是终止等待,强制唤醒所有等待的线程private void breakBarrier() {generation.broken = true;count = parties;//唤醒所有等待的线程,这些线程被唤醒后会检测到generation.broker=true//就明白了是被强制打断了本次计数,所以被唤醒的线程就会直接抛异常trip.signalAll();}//这是CyclicBarrier await的核心,做两件事:1:扣减计数;2:await计数归0private int dowait(boolean timed, long nanos)throws InterruptedException, BrokenBarrierException,TimeoutException {final ReentrantLock lock = this.lock;//先获取锁lock.lock();try {//记录本线程刚开始doawait时的generation变量//当线程再次唤醒时如果检测到CyclicBarrier对象的generation变量//和它记录的不是同一个generation变量,那么线程就知道他所在的轮次已经结束了//可能是因为计数归零从而被唤醒、超时、中断异常、被break强制中断等待final Generation g = generation;//在本线程还没开始doawait时就有其他线程执行了breakBarrier强制提前结束了本轮计数if (g.broken)//那么就直接抛异常throw new BrokenBarrierException();//如果本线程已经被中断if (Thread.interrupted()) {//就调用breakBarrier强制唤醒所有等待的线程,强制结束本轮计数breakBarrier();//然后再抛中断异常throw new InterruptedException();}//1:扣减计数int index = --count;//如果计数归零,就表明本轮计数已结束,可以唤醒所有线程if (index == 0) {  boolean ranAction = false;try {//当计数结束时,执行预定义的操作final Runnable command = barrierCommand;if (command != null)command.run();ranAction = true;//唤醒所有阻塞的线程,然后更新generation以进入下一轮迭代nextGeneration();return 0;} finally {//如果command不为null并且command.run抛异常了//就表明本轮计数失败,打上broken标记,然后强制唤醒所有线程//而这些被唤醒的线程会检测到broken,然后就抛异常了if (!ranAction)breakBarrier();}}//2:死循环等待被唤醒for (;;) {try {//如果没有开启超时if (!timed)//则直接condition.await,直到被其他线程signaltrip.await();else if (nanos > 0L)//否则awaitNanos,至多await这么多秒nanos = trip.awaitNanos(nanos);//如果await过程中抛出了中断异常} catch (InterruptedException ie) {//如果检测到被唤醒后时的generation和await之前的generation是同一个//则表明还是统一伦次//如果此事没有检测到被其他线程已经抛出broken//即其他人还在正常await,但是本线程已经检测到中断异常了//所以本线程就抛出broken并强制唤醒所有阻塞的线程//也就是说同一轮中只要有任意一个线程抛出了异常,// 就强制结束本轮,所有被唤醒的线程都会检测到broken然后抛异常if (g == generation && ! g.broken) {breakBarrier();throw ie;} else {//否则说明已经进入下一轮了或者已经有人抛出broken了//所以这里就简单标记一下中断Thread.currentThread().interrupt();}}//检查是否是因为broken被唤醒if (g.broken)//如果是则抛异常throw new BrokenBarrierException();//检查是否已经进入下一轮了,如果是的话则说明本轮正常结束了//说明本线程是被正常signal的,也就是说本线程成功结束了本次await//可以继续往下执行了,所以此时就返回本次线程的indexif (g != generation)return index;//如果还是同一轮,则说明还没有结束,因为一个线程只能扣减一次index//如果他在await前扣减完index后index不为0//则说明他不是最后一个到达的,还需要等待其他线程到达//所以这里检测是不是因为超时被唤醒的if (timed && nanos <= 0L) {//如果超时,则表示本轮计数失败//所以这里就强制broken并唤醒所有阻塞的线程//其他线程唤醒后就会检测到broken,然后就会抛出异常了breakBarrier();//抛出超时异常throw new TimeoutException();}}} finally {//释放锁//备注:当线程发现自己到达时index刚好为0即本线程是最后一个到达的,//所以本线程需要唤醒其他线程并更新generation和count//也就是执行nextGeneration()函数,此时还没有释放lock,所以此时是安全的//因为lock.unlock会等到执行完nextGeneration后才会在finally中执行lock.unlock();}}public CyclicBarrier(int parties, Runnable barrierAction) {if (parties <= 0) throw new IllegalArgumentException();this.parties = parties;this.count = parties;this.barrierCommand = barrierAction;}public CyclicBarrier(int parties) {this(parties, null);}public int getParties() {return parties;}public int await() throws InterruptedException, BrokenBarrierException {try {return dowait(false, 0L);} catch (TimeoutException toe) {throw new Error(toe); }}public int await(long timeout, TimeUnit unit)throws InterruptedException,BrokenBarrierException,TimeoutException {return dowait(true, unit.toNanos(timeout));}public boolean isBroken() {final ReentrantLock lock = this.lock;lock.lock();try {return generation.broken;} finally {lock.unlock();}}//重置barrierpublic void reset() {final ReentrantLock lock = this.lock;//先获取锁lock.lock();try {//然后强制broken并唤醒所有等待的线程//这些线程被唤醒后会检测到broken,然后就会抛异常breakBarrier();//唤醒其他线程后就更新generation表示进入下一轮nextGeneration(); } finally {//释放锁lock.unlock();}}//表示有多少个线程在等待public int getNumberWaiting() {final ReentrantLock lock = this.lock;lock.lock();try {//parties表示初始限额,count表示还剩几个线程没有到return parties - count;} finally {lock.unlock();}}
}

相关文章:

javalock(六)CyclicBarrier

注意&#xff1a;CyclicBarrier不是AQS的派生类&#xff0c;而是CyclicBarrier内部使用了ReentrantLock.Condition 和CountDownLatch一样&#xff0c;都是计数减为0就可以成功获取锁 和CountDownLatch不同的是&#xff1a; 1&#xff1a;CountDownLatch的await和countdown操作…...

React 19有哪些新特性?

写在前面 2024.12.5&#xff0c;React 团队在 react.dev/blog 上发表了帖子 react.dev/blog/2024/1… React 19 正式进入了 stable 状态 React 团队介绍了一些新的特性和 Breaking Changes&#xff0c;并提供了升级指南&#xff0c; React 19: 新更新、新特性和新Hooks Reac…...

大数据治理:构建数据驱动的智慧教学体系

随着大数据技术在教育领域的逐渐渗透&#xff0c;大数据治理在教学中的应用日益广泛&#xff0c;它为提升教学质量、优化教学资源配置以及实现个性化教学提供了有力支持。 一、大数据治理在教学数据管理中的应用 在教学过程中&#xff0c;会产生海量的数据&#xff0c;如学生的…...

梳理你的思路(从OOP到架构设计)_浅尝架构师的滋味03

目录 1、分与合&#xff1a; 强龙与地头蛇的分工 分工 & 合作 分工的时间点 客人来之前做「分」&#xff0c;客人来之后做「合」 2、结语 肯德基餐厅 火锅店 汽车 从分工到外包模式 1、分与合&#xff1a; 强龙与地头蛇的分工 EIT造形用来表达架构师的先「分」与买…...

ChatGPT与领域特定语言的集成

用ChatGPT做软件测试 领域特定语言&#xff08;Domain-Specific Language&#xff0c;DSL&#xff09;是一种编程语言&#xff0c;专门设计用于满足特定领域或问题领域的需求。它是一种定制的语言&#xff0c;通常包括特定领域的专业术语以及相应的语法规则。DSL的设计旨在让领…...

sql server msdb数据库备份恢复

备份 BACKUP DATABASE [msdb] TO DISK ND:\liyuanshuai\test\sqlserver_bakfile\msdb20241219.bak WITH NOFORMAT, NOINIT, NAME Nlys-完整 数据库 备份, SKIP, NOREWIND, NOUNLOAD, COMPRESSION, STATS 10 GO然后删除2个测试的job&#xff0c;停止 SQL Server 代理…...

MyBatis(二)

一、MyBatis 和 JDBC 有什么区别&#xff1f; JDBC 是 Java 访问数据库的基础 API&#xff0c;它需要大量的样板代码。比如&#xff0c;使用 JDBC 进行查询时&#xff0c;需要加载驱动、建立连接、创建语句、执行查询、处理结果集和关闭资源等操作。代码比较繁琐且容易出错。M…...

Docker:Dockerfile(补充四)

这里写目录标题 1. Dockerfile常见指令1.1 DockerFile例子 2. 一些其他命令 1. Dockerfile常见指令 简单的dockerFile文件 FROM openjdk:17LABEL authorleifengyangCOPY app.jar /app.jarEXPOSE 8080ENTRYPOINT ["java","-jar","/app.jar"]# 使…...

Hexo博客生成标签和分类页

个人博客地址&#xff1a;Hexo博客生成标签和分类页 | 一张假钞的真实世界。 标签页 默认情况下&#xff0c;Hexo站点创建后&#xff0c;需手动生成标签页。如不生成&#xff0c;在点击“标签”菜单时会出现以下错误&#xff1a; Cannot GET /tags/ 执行以下命令创建标签页…...

Linux基础 -- 使用Linux Shell通过TCP发送消息

使用Linux Shell通过TCP发送消息 本文档介绍如何使用Linux Shell命令&#xff0c;通过TCP协议向服务器发送消息&#xff0c;示例中的目标服务器地址为 192.168.1.32&#xff0c;端口为 15000。 示例代码 使用 printf 和 netcat&#xff08;简称 nc&#xff09;工具实现&…...

联表查询相关语法

1.查询sql语句的执行顺序 sql:语法 select distinct * from 左表名 (left/inner/right)join 右表名 on 连接条件 where 筛选条件 group by 分组的列表(按什么字段分组) having 分组条件 order by 排序的字段 limit 分页 以上为语法结构&#xff0c;顺序不能乱执行顺序&#x…...

upload-labs(1-19关)通关攻略

Pass-01 本关思路&#xff1a;删除前端js校验 进入第一关环境 桌面新建一个php文件&#xff0c;命名为1.php <?php eval($_POST[a]);?> 我们上传此文件&#xff0c;发现不允许上传&#xff0c;且页面没有变化&#xff0c;说明前端进行了拦截 这时我们打开 F12 &…...

C语言小练习-求数组的最大子数组

#include <stdio.h>/***暴力求解最大子数组&#xff0c;使用两重循环&#xff0c;把所有情况全部遍历一遍。*/ int subArr1(int *arr,int size) {int sum 0, max arr[0];int i,j;for(i 0;i < size; i){for(j i; j < size; j){sum arr[j];if(sum > max){max…...

初识C语言之二维数组(中)

一.二维数组练习 ①题目描述:打印多个字符从两端移动&#xff0c;向中间汇聚。 eg. ################ H###############! He##############!! Hel#############!!! Hell############!!!! Hello##########t!!!! ................................................. He…...

Ubuntu下迁移Conda环境

Ubuntu下快速迁移Conda环境到其他电脑 安装conda-pack pip install conda-packOr conda install conda-pack压缩conda环境 解压到目标电脑或者目标文件下 conda pack -n your_envs_name -o your_envs_name.tar.gz解压conda环境 mkdir your_new_envs_name tar -zxvf your_e…...

数据可视化-1. 折线图

目录 1. 折线图适用场景分析 1. 1 时间序列数据展示 1.2 趋势分析 1.3 多变量比较 1.4 数据异常检测 1.5 简洁易读的数据可视化 1.6 特定领域的应用 2. 折线图局限性 3. 折线图代码实现 3.1 Python 源代码 3.2 折线图效果&#xff08;网页显示&#xff09; 1. 折线图…...

MATLAB绘图基础12:地理信息可视化

参考书&#xff1a;《 M A T L A B {\rm MATLAB} MATLAB与学术图表绘制》(关东升)。 12.地理信息可视化 12.1 地理散点图 地理散点图用于可视化地理坐标点分布的图形&#xff0c;适用于在地图上显示离散地理坐标点&#xff0c;每个点可以代表不同的实体、地点或其他类型的观测…...

C语言与C++

文件概念 在C语言中&#xff0c;文件是一个重要的概念&#xff0c;用于组织和存储数据。文件主要分为两类&#xff1a; 程序文件 &#xff1a;包含源代码、目标文件和可执行文件。 数据文件 &#xff1a;存储程序运行时读写的各类数据。 文件名通常由三部分组成&#xff1a;…...

C# 中的闭包

文章目录 前言一、闭包的基本概念二、匿名函数中的闭包1、定义和使用匿名函数2、匿名函数捕获外部变量3、闭包的生命周期 三、Lambda 表达式中的闭包1、定义和使用 Lambda 表达式2、Lambda 表达式捕获外部变量3、闭包的作用域 四、闭包的应用场景1、事件处理2、异步编程3、迭代…...

基于DockerCompose搭建Redis主从哨兵模式

linux目录结构 内网配置 哨兵配置文件如下&#xff0c;创建3个哨兵配置文件 # sentinel26379.conf sentinel26380.conf sentinel26381.conf 内容如下 protected-mode no sentinel monitor mymaster redis-master 6379 2 sentinel down-after-milliseconds mymaster 60000 s…...

UIP协议栈 TCP通信客户端 服务端,UDP单播 广播通信 example

文章目录 1. TCP通信 客户端&#xff08;关键配置&#xff09;2. TCP 服务端配置3. UDP 点播通信4. UDP 广播通信5. UIP_UDP_APPCALL 里边的处理example6. TCP数据处理 &#xff0c;UIP_APPCALL调用的函数 UIP_APPCALL TCP的数据都在这个宏定义的函数里进行数据处理的 UDP 数据…...

LeetCode:226.翻转二叉树

跟着carl学算法&#xff0c;本系列博客仅做个人记录&#xff0c;建议大家都去看carl本人的博客&#xff0c;写的真的很好的&#xff01; 代码随想录 LeetCode&#xff1a;226.翻转二叉树 给你一棵二叉树的根节点 root &#xff0c;翻转这棵二叉树&#xff0c;并返回其根节点。 …...

Visual Studio 使用 GitHub Copilot 扩展

&#x1f380;&#x1f380;&#x1f380;【AI辅助编程系列】&#x1f380;&#x1f380;&#x1f380; Visual Studio 使用 GitHub Copilot 与 IntelliCode 辅助编码Visual Studio 安装和管理 GitHub CopilotVisual Studio 使用 GitHub Copilot 扩展Visual Studio 使用 GitHu…...

Unity实现Root Motion动画的Navigation自动导航

Root motion动画可以将角色的根节点&#xff08;通常是角色的骨盆或脚部&#xff09;的运动直接应用到游戏对象上&#xff0c;从而实现角色的自然移动和旋转&#xff0c;避免出现脚底打滑的现象。采用Root motion动画的游戏对象&#xff0c;通常是重载了onAnimatorMove函数&…...

vulnhub靶场【DriftingBlues】之9 final

前言 靶机&#xff1a;DriftingBlues-6&#xff0c;IP地址192.168.1.66 攻击&#xff1a;kali&#xff0c;IP地址192.168.1.16 都采用虚拟机&#xff0c;网卡为桥接模式 主机发现 使用arp-scan -l或netdiscover -r 192.168.1.1/24 信息收集 使用nmap扫描端口 网站探测 访…...

Python连接和操作Elasticsearch详细指南

Python连接和操作Elasticsearch详细指南 一、服务器端配置1. 修改 Elasticsearch 配置文件2. 开放防火墙端口 二、本地 Python 连接 Elasticsearch1. 连接 Elasticsearch2. 索引操作3. 文档操作4. 搜索内容5. 聚合查询6. 批量操作 三、注意事项四、故障排除结论 Elasticsearch …...

JMeter 使用详解

JMeter 使用详解 Apache JMeter 是一款开源的性能测试工具&#xff0c;可用于对静态和动态资源&#xff08;如 Web 应用、数据库、REST API 等&#xff09;进行负载测试和性能测试。以下是 JMeter 的详细使用指南&#xff1a; 1. JMeter 安装 下载 JMeter&#xff1a; 从 Apac…...

[SZ901]程序固化工具速度对比

SZ901高速下载器提供程序固化工具&#xff0c;能够快速将bin文件烧写到FLASH中。 相对传统方式有以下优点 1&#xff0c;固化时间是传统方式的1/2 到1/5&#xff0c;flash&#xff0c;程序越大&#xff0c;&#xff0c;效果越明显 2&#xff0c;操作简单&#xff0c;自动脚本…...

类OCSP靶场-Kioptrix系列-Kioptrix Level 4

一、前情提要 二、实战打靶 1. 信息收集 1.1. 主机发现 1.2. 端口扫描 1.3.目录遍历 1.4. 敏感信息 2.漏洞发现 2.1.登录框万能密码 2.2.系统用户密码-ssh链接 2.3.mysql-udf提权 一、前情提要 kali黑客-利用searchsploit搜索exp一键化攻击-CSDN博客 一篇文章带你理…...

C++ ——— 类的 6 个默认成员函数之 取地址函数 以及 const取地址操作符重载函数

目录 前言 取地址函数 const 取地址操作符重载函数 前言 在前几章学习了类的 6 个默认成员函数中的 4 个函数&#xff0c;也是最重要的 4 个 C ——— 类的 6 个默认成员函数之 构造函数-CSDN博客 C ——— 类的 6 个默认成员函数之 析构函数_结构体构析函数-CSDN博客 C…...

【C语言】头文件”“和<>的详解

前言 作者在刚开始学C语言的时候&#xff0c;都是用的< >去引用头文件&#xff0c;但在学习STM32的时候发现&#xff0c;程序中大量使用" "去引用双引号。 那么二者有什么区别呢? 无论使用哪种方式&#xff0c;头文件的目的都是为了引用你需要的文件供你编程使…...

sql server 字符集和排序

英文&#xff1a; Latin1_General_CI_AS 中文&#xff1a;Chinese_PRC_CI_AS 影响字符存储&#xff0c;解释用户存在单字节字符类型&#xff08;char&#xff0c;varchar等&#xff09;里面的数据 字符排序规则&#xff08;是否区分大小写等&#xff09; 中国的用户一定要注意…...

【linux】shell(39)-定时任务

在 Linux 和 Unix 系统中&#xff0c;定时任务是通过 cron 服务 和 crontab 工具 实现的&#xff0c;它允许用户在指定的时间自动执行命令或脚本。本教程将深入介绍 crontab 的工作原理、配置、常见用法和注意事项&#xff0c;帮助你高效地管理自动化任务。 1. cron 和 crontab…...

C# 基本信息介绍

总目录 前言 对 C# 做一个基本信息介绍&#xff0c;让我们对 C# 有个基本的认识。 在进行本文的阅读之前&#xff0c;可以瞧瞧 编程基础知识简述 简单的入个门儿。 一、C# 1. C# 概述 C#是由微软公司发布的一种由C和C衍生出来的面向对象的编程语言。 2. C# 详细介绍 C#&am…...

告别机器人味:如何让ChatGPT写出有灵魂的内容

目录 ChatGPT的一些AI味道小问题 1.提供编辑指南 2.提供样本 3.思维链大纲 4.融入自己的想法 5.去除重复增加多样性 6.删除废话 ChatGPT的一些AI味道小问题 大多数宝子们再使用ChatGPT进行写作时&#xff0c;发现我们的老朋友ChatGPT在各类写作上还有点“机器人味”太重…...

ECharts柱状图-柱图38,附视频讲解与代码下载

引言&#xff1a; 在数据可视化的世界里&#xff0c;ECharts凭借其丰富的图表类型和强大的配置能力&#xff0c;成为了众多开发者的首选。今天&#xff0c;我将带大家一起实现一个柱状图图表&#xff0c;通过该图表我们可以直观地展示和分析数据。此外&#xff0c;我还将提供…...

SAP ALV选择列排序时弹出定义排序顺序窗口问题

需求场景 使用REUSE_ALV_GRID_DISPLAY_LVC生成ALV&#xff0c;发现一个问题&#xff1a;使用it_events的时候选择列排序时会弹出定义排序顺序窗口&#xff0c;如下图所示。&#xff08;正常选择某一列再使用排序功能时会直接排序&#xff0c;不用再选择列&#xff09; CLASS l…...

HTML零基础入门教学

目录 一. HTML语言 二. HTML结构 三. HTML文件基本结构 四. 准备开发环境 五. 快速生成代码框架 六. HTML常见标签 6.1 注释标签 6.2 标题标签&#xff1a;h1-h6 6.3 段落标签&#xff1a;p 6.4 换行标签&#xff1a;br 6.5 格式化标签 6.6 图片标签&a…...

AI-PR曲线

PR曲线 人工智能里面的一个小概念。 2.3 性能度量&#xff08;查全率&#xff0c;查准率&#xff0c;F1&#xff0c;PR曲线与ROC曲线&#xff09; 预测出来的是一个概率&#xff0c;不能根据概率来说它是正类还是负类&#xff0c;要有一个阈值。 查准率&#xff08;Precision&…...

[创业之路-199]:《华为战略管理法-DSTE实战体系》- 3 - 价值转移理论与利润区理论

目录 一、价值转移理论 1.1. 什么是价值&#xff1f; 1.2. 什么价值创造 &#xff08;1&#xff09;、定义 &#xff08;2&#xff09;、影响价值创造的因素 &#xff08;3&#xff09;、价值创造的三个过程 &#xff08;4&#xff09;、价值创造的实践 &#xff08;5&…...

问题解决: python 调用存储过程获取不到返回值

python 调用存储过程获取不到返回值 1. 检查存储过程是否有副作用&#xff08;例如关闭结果集&#xff09;2. 在 Python 代码中&#xff0c;确保在执行存储过程时按正确的顺序操作&#xff1a;3. 使用游标检查结果集 1. 检查存储过程是否有副作用&#xff08;例如关闭结果集&am…...

AI前沿分析:Github Copilot 推出免费版本,AI + 编程更高效!

名人说&#xff1a;莫听穿林打叶声&#xff0c;何妨吟啸且徐行。—— 苏轼 Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 目录 一、GitHub Copilot&#xff1a;AI编程的“革命性”助力二、免费版本上线&#xff1a;AI编程的普及时代&…...

浅谈仓颉语言的优劣

仓颉语言&#xff0c;作为华为自研的新一代编程语言&#xff0c;以其高效、安全、现代化的特点&#xff0c;引起了广泛的关注。 仓颉语言的优势 高效并发 仓颉语言的一大亮点是其轻松并发的能力。它实现了轻量化用户态线程和并发对象库&#xff0c;使得高效并发变得轻松。仓颉…...

AI证件照制作 API 快速生成证件照

本文将介绍一种 AI证件照制作 API 对接说明&#xff0c;它是可以通过输入人像照片URL以及自己喜欢的模板来制作各种风格的证件照。 接下来介绍下 AI证件照制作 API 的对接说明。 申请流程 要使用 API&#xff0c;需要先到 AI证件照制作 API 对应页面申请对应的服务&#xff…...

Java.10--IO流

JavaSE&#xff08;Java Standard Edition&#xff09;中的IO&#xff08;输入输出&#xff09;库提供了用于读写数据的类和接口。 这些功能可以用来处理文件、网络连接、内存中的数据结构等。 一、IO流分类 Java中的IO&#xff08;输入输出&#xff09;库可以按照不同的标准…...

Firewalld 防火墙全面解析与配置指南

在当今网络环境中,网络安全至关重要,而防火墙作为网络安全的关键防线,在Linux系统中扮演着极其重要的角色。本文将深入探讨Firewalld防火墙,涵盖其基础概念,优势特点,配置方法等多面内容,为您提供全面的Firewalld防火墙知识体系 一,Linux防火墙基础 (一) 防火墙内核…...

Javascript-web API-day02

文章目录 01-事件监听02-点击关闭广告03-随机点名案例04-鼠标经过或离开事件05-可点击的轮播图06-小米搜索框07-键盘类型事件08-键盘事件-发布评论案例09-focus选择器10-评论回车发布11-事件对象12-trim方法13-环境对象14-回调函数15-tab栏切换 01-事件监听 <!DOCTYPE html…...

Python爬虫之代理的设置

【1】urllib中使用公开代理 import urllib.requesturl http://www.baidu.com/s?wdipheaders {User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/92.0.4515.159 Safari/537.36 }# 请求对象的定制 request urllib.req…...

Qt:QMetaObject::connectSlotsByName实现信号槽自动关联

简介 在Qt中&#xff0c;QMetaObject::connectSlotsByName 是一个便利的方法&#xff0c;它可以根据对象的对象名&#xff08;objectName&#xff09;自动将信号和槽连接起来。但是&#xff0c;要使用这个方法&#xff0c;必须确保&#xff1a; 1 控件&#xff08;如按钮&…...

芝法酱学习笔记(2.1)——sql性能优化1

一、前言 做程序员这行&#xff0c;相信大家都会接触到性能优化这个概念。并且多数程序员&#xff0c;为自己能参与到性能优化的工作而感到自豪。 在普通应用系统的业务开发中&#xff0c;程序的性能瓶颈往往在数据库查询的IO上&#xff0c;所以优化数据库查询则是重中之重的工…...