Java学习笔记(23)
多线程
并发
并行
多线程实现方式
1.继承Thread类
自己创建一个类extends thread类
Start方法开启线程,自动执行重写之后的run方法
2.实现runable接口
自己创建一个类implements runnable
Myrun不能直接使用getname方法,因为这个方法是thread类的方法
所以需要得到当前线程的thread对象,再用getname方法
3.用callable接口和future接口方法
抽象方法run没有返回值,获取不了运行结果
实现callable接口
重写call方法
Future接口不能直接用,要用他的实现类futuretask管理线程运行结果
Thread的方法
Getname
没有起名,有默认名字:Thread-0,Thread-1.。。
Setname
设置线程名字,可以用set,也可以用构造方法,但是构造方法不能继承,要自己重新写个构造方法,通过super继承父类的构造方法
CurrentThread
Sleep 静态方法 用Thread.sleep调用
抢占式调度
随机
优先级最高10,最小1,默认5
Setpriority(int)
Getpriority
守护线程
SetDaemon(true)
非守护和守护默认没有优先级之分
非守护结束,守护慢慢就也会结束
出让线程
Thread.yield()
让结果每一个线程尽可能均匀运行
插入线程
线程的生命周期
有执行资格:有资格去抢CPU的执行权
没有执行权:还没抢到执行权,不能执行代码
线程安全
Ticket要用static修饰,这样所有这个类的对象就可以共享ticket
为什么会出现这个问题?
执行代码时,线程随时都会被其他线程抢夺执行权
如何解决?
同步代码块
让一个线程执行完完整的一次同步代码块里的代码,才可以重新抢夺执行权
Synchronized(锁对象){}
锁对象:是任意的,但是一定是唯一的,前面用static修饰
锁对象可以是本类的字节码文件
同步方法
如果想把一个方法里面所有的代码都锁起来,就不需要同步代码块
直接将synchronized加在方法上
用runable的时候,由于只需要创建一次,所以里面的ticket就可以不用static修饰
Stringbuffer用于多线程环境,里面的方法和stringbuilder一样的
Lock锁
是一个接口,创建对象要用实现类reentrantlock
以上代码可能出现的问题:
- 如果lock没有用static修饰
则会所有的线程都会创建一个lock,重复ticket,超出范围的问题又会出现,所以要加static修饰,即所有线程共享一个lock,就能解决
2.程序不停止?
没有执行lock.unlock()方法,有线程一直停留在lock.lock()方法,所以程序没有停止
如何避免?
把unlock写到finally中,保证unlock一定会执行
死锁
不要让两个锁嵌套起来写,这样程序就运行不下去
生产者和消费者
等待唤醒机制
生产者:生产数据
消费者:消费数据
消费者等待
生产者等待
完整机制
方法
Wait
一般用notifyall
这几个方法要通过锁对象来进行调用
重写run方法的套路
Desk
Foodie
Cookie
测试类
第二种实现方式:阻塞队列方式
- 数组,有界
- 链表,无界
生产者和消费者要使用同一个阻塞队列
不需要在写锁对象,因为put和take方法的底层就已经有锁了
Take有返回值,类型和put进去的数据一样
线程的状态
Java没有定义运行状态,只有剩下的六种状态
为什么没有?
因为线程抢到CPU的执行权之后,当前线程就会交给操作系统管理,虚拟机就不会再管这个线程了
package exericise;public class exercise1 {public static void main(String[] args) {window t1 = new window();window t2 = new window();t1.setName("窗口1");t2.setName("窗口2");t1.start();t2.start();}
}package exericise;public class window extends Thread{static int ticket =1000;@Overridepublic void run() {while (true) {synchronized (exercise1.class){if (ticket != 0){ticket--;try {Thread.sleep(3000);} catch (InterruptedException e) {throw new RuntimeException(e);}System.out.println(getName() + "还有"+ticket+"张票");}else {break;}}}}
}
package exericise;public class exercise2 {public static void main(String[] args) {Person t1 = new Person();Person t2 = new Person();t1.setName("Person1");t2.setName("Person2");t1.start();t2.start();}
}package exericise;import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;public class Person extends Thread {static int gift = 1000;static Lock lock = new ReentrantLock();@Overridepublic void run() {while (true) {lock.lock();try {if (!(gift < 10)) {System.out.println(getName() + "送出第" + gift + "个礼物");gift--;} else {break;}} catch (Exception e) {throw new RuntimeException(e);} finally {lock.unlock();}}}
}
package exericise;public class exercise3 {public static void main(String[] args) {Number t1 = new Number();Number t2 = new Number();t1.setName("线程1");t2.setName("线程2");t1.start();t2.start();}
}package exericise;import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;public class Number extends Thread{static int start = 1;static int end = 100;static Lock lock = new ReentrantLock();@Overridepublic void run() {while (true) {lock.lock();try {if (start <= end) {//判断是不是奇数if (start %2 == 1) {//是就打印System.out.println(getName() + ":" + start);}start++;}else {//超过范围break;}} catch (Exception e) {throw new RuntimeException(e);} finally {lock.unlock();}}}
}
package exericise;import java.util.Arrays;
import java.util.Random;public class exercise4 {public static void main(String[] args) {//随机分成3个红包Random r = new Random();for (int i = 0; i < redBao.arr.length; i++) {if (i == redBao.arr.length - 1) {redBao.arr[i] = redBao.redPocket;}else {redBao.arr[i] = r.nextDouble(0.01,redBao.redPocket);redBao.redPocket -= redBao.arr[i];}}System.out.println(Arrays.toString(redBao.arr));redBao rb1 = new redBao();redBao rb2 = new redBao();redBao rb3 = new redBao();redBao rb4 = new redBao();redBao rb5 = new redBao();rb1.setName("No.1");rb2.setName("No.2");rb3.setName("No.3");rb4.setName("No.4");rb5.setName("No.5");rb1.start();rb2.start();rb3.start();rb4.start();rb5.start();}
}
package exericise;import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;public class redBao extends Thread{static double redPocket = 100;//标记是否已经抢到过boolean flag = false;static double[] arr = new double[3];static Lock lock = new ReentrantLock();static int index = 0;static int end = 1;@Overridepublic void run() {lock.lock();try {if (!flag && index <= 2){//还没抢到过红包System.out.println(getName() + "抢到了" + arr[index] + "块钱");index++;flag = true;}if (end >3) {System.out.println(getName() + "没抢到");}end++;} catch (Exception e) {throw new RuntimeException(e);} finally {lock.unlock();}}
}
在run方法中定义一个集合,则所有的进程都会在自己的栈中的run方法里创建出自己的集合,这个集合在不同的进程中独立,互不影响
注意:其实每一个线程都会有自己独立的栈,包括main,里面创建的元素互不影响(除非是static)
线程池
创建线程浪费时间
用完直接丢弃,浪费资源
原理
一般不会关闭线程池:因为服务器24小时都会运行,所以随时都会新任务进来,所以一般不会关闭线程池
Submit:提交任务
Shutdown:销毁线程池
0
自定义线程池
什么时候创建临时线程?
核心线程已被占用,而且排队队伍已满,这是才创建临时线程
先提交的任务,不一定先执行
如图,任务4 5 6在排队,临时线程处理任务7 8
当提交的任务数量大于核心线程数+临时线程数+队伍长度,剩下的任务10就会触发任务拒绝策略
自定义线程池,设置七个参数
ThreadPoolExecutor
到底怎么设置才合适?
最大并行数
系统处理器的线程数,4核8线程,8就是最大并行数
CPU密集型运算:读取文件较少,计算数据较多
为什么+1:如果前面的线程出问题,则多出来的线程就可以顶上,不浪费cpu的时钟周期不被浪费
IO密集性运算:现在的项目大多都是IO密集性的,读取服务器文件操作多
怎么得到计算时间?
通过thread dump的工具来测试计算时间
相关文章:
![](https://img-blog.csdnimg.cn/direct/c3b4b5974c214f26acac448bed3ec08c.png)
Java学习笔记(23)
多线程 并发 并行 多线程实现方式 1.继承Thread类 自己创建一个类extends thread类 Start方法开启线程,自动执行重写之后的run方法 2.实现runable接口 自己创建一个类implements runnable Myrun不能直接使用getname方法,因为这个方法是thread类的方法…...
![](https://img-blog.csdnimg.cn/direct/d9cac52cf14244a096440c4ea301065b.png)
nodejs下载安装以及npm、yarn安装及配置教程
1、nodejs下载安装 1.1、使用nodejs版本管理工具下载安装,可一键安装、切换不同nodejs版本, nvm-setup.zip:安装版,推荐使用 本次演示的是安装版。 1、双击安装文件 nvm-setup.exe 选择nvm安装路径 例如:E:\Soft…...
![](https://www.ngui.cc/images/no-images.jpg)
Playwright库page.evaluate()方法执行JavaScript 表达式
page.evaluate() 方法是 Playwright 中常用的方法之一,用于在页面上下文中执行 JavaScript 代码。它允许在浏览器环境中执行各种操作,如操作 DOM 元素、获取页面数据、执行复杂的计算等,并将结果返回到 Node.js 或 Python 代码中。 在 Playw…...
![](https://img-blog.csdnimg.cn/img_convert/1ba120e0b8da6f61183767be446b1566.png)
【微服务】OpenFeign+Sentinel集中处理远程调用异常
文章目录 1.微服务基本环境调整1.对10004模块的application.yml调整2.启动nacos以及一个消费者两个提供者3.测试1.输入http://localhost:8848/nacos/index.html 来查看注册情况2.浏览器访问 http://localhost:81/member/nacos/consumer/get/13.结果 2.使用OpenFeign实现微服务模…...
![](https://img-blog.csdnimg.cn/img_convert/5b4d314f672491ebe10dc0c66bc72f40.png)
集合嵌套,Collections,斗地主案例,日志框架
文章目录 集合嵌套List嵌套ListList嵌套MapMap嵌套Map Collections类方法排序 sort 乱序 shuffle 斗地主案例需求思路代码 日志框架介绍优势体系结构Logback概述快速入门配置详解 集合嵌套 List嵌套List public static void main(String[] args){//一个年级有许多班级…...
![](https://www.ngui.cc/images/no-images.jpg)
maven pom relativePath属性的作用
maven pom relativePath属性的作用 文章目录 maven pom relativePath属性的作用一、relativePath出现的地方二、relativePath默认值三、四、<relativePath>一个pom路径 一、relativePath出现的地方 搭建maven项目,子模块指定父模块试,经常会在par…...
![](https://img-blog.csdnimg.cn/direct/e3ce972a91424791a4c9d7cb79e091b2.png)
【STM32 HAL库SPI/QSPI协议学习,基于外部Flash读取。】
1、SPI协议 简介 SPI 协议是由摩托罗拉公司提出的通讯协议 (Serial Peripheral Interface),即串行外围设备接口,是 一种高速全双工的通信总线。它被广泛地使用在 ADC、LCD 等设备与 MCU 间,要求通讯速率 较高的场合。 SPI 物理层 SPI 通讯…...
![](https://www.ngui.cc/images/no-images.jpg)
Nginx入门--初识Nginx的架构
一、概述 Nginx的架构设计旨在高效处理并发的网络请求。它采用了事件驱动的、非阻塞的IO模型,可以同时处理成千上万个并发连接,而不会消耗太多的系统资源。 二、主要组件 Nginx的主要组件包括: Master Process(主进程…...
![](https://img-blog.csdnimg.cn/direct/82240ffbd69a4ab2a54c82941aa9fa4e.png#pic_center)
网络性能提升10%,ZStack Edge 云原生超融合基于第四代英特尔®至强®可扩展处理器解决方案发布
随着业务模式的逐渐转变、业务架构逐渐变得复杂,同时容器技术的兴起和逐渐成熟,使得Kubernetes、微服务等新潮技术逐步应用于业务应用系统上。 为了充分释放性能、为业务系统提供更高效的运行环境,ZStack Edge 云原生超融合采用了第四代英特尔…...
![](https://img-blog.csdnimg.cn/img_convert/10e64f99a29431c549a8f02cb2f82d6c.webp?x-oss-process=image/format,png)
双非计算机考研目标211,选11408还是22408更稳?
求稳得话,11408比22408要稳! 很多同学只知道,11408和22408在考察的科目上有区别,比如: 11408考的是考研数学一和英语一,22408考察的是考研数学二和英语二: 考研数学一和考研数学二的区别大吗…...
![](https://img-blog.csdnimg.cn/img_convert/5800f5b3b6fdeb61457c3a2c8816919a.png)
简单了解策略模式
什么是策略模式? 策略模式提供生成某一种产品的不同方式 Strategy策略类定义了某个各种算法的公共方法,不同的算法类通过继承Strategy策略类,实现自己的算法 Context的作用是减少客户端和Strategy策略类之间的耦合,客户端只需要…...
![](https://www.ngui.cc/images/no-images.jpg)
算法——运动模型
智能驾驶中常用的速度计算算法包括基于GPS的速度计算、惯性测量单元(IMU)的速度计算、雷达测距的速度计算、视觉测距的速度计算等。这些算法可以单独使用或者结合使用,以提高速度计算的准确性和稳定性。 智能驾驶中常用的加速度计算算法包括…...
![](https://csdnimg.cn/release/blog_editor_html/release2.3.6/ckeditor/plugins/CsdnLink/icons/icon-default.png?t=N7T8)
基于R语言lavaan结构方程模型(SEM)技术应用
结构方程模型(Sructural Equation Modeling,SEM)是分析系统内变量间的相互关系的利器,可通过图形化方式清晰展示系统中多变量因果关系网,具有强大的数据分析功能和广泛的适用性,是近年来生态、进化、环境、…...
![](https://img-blog.csdnimg.cn/direct/912eba1c4e2f45929772563040360d80.png)
本地虚拟机服务器修改站点根目录并使用域名访问的简单示例
说明:本文提及效果是使用vmware虚拟机,镜像文件是Rocky8.6 一、配置文件路径 1. /etc/httpd/conf/httpd.conf #主配置文件 2. /etc/httpd/conf.d/*.conf #调用配置文件 调用配置文件的使用: vim /etc/httpd/conf.d/webpage.conf 因为在主配…...
![](https://img-blog.csdnimg.cn/direct/69271d721c9e473485e5dc02c005d47c.png)
生信数据分析——GO+KEGG富集分析
生信数据分析——GOKEGG富集分析 目录 生信数据分析——GOKEGG富集分析1. 富集分析基础知识2. GO富集分析(Rstudio)3. KEGG富集分析(Rstudio) 1. 富集分析基础知识 1.1 为什么要做功能富集分析? 转录组学数据得到的基…...
![](https://img-blog.csdnimg.cn/direct/256c6ed08e3d4e29bd19335acd64261c.png)
微服务(基础篇-007-RabbitMQ)
目录 初识MQ(1) 同步通讯(1.1) 异步通讯(1.2) MQ常见框架(1.3) RabbitMQ快速入门(2) RabbitMQ概述和安装(2.1) 常见消息模型(2.2) 快速入门ÿ…...
![](https://img-blog.csdnimg.cn/direct/e9bdd01563e7481c852379d89e11368f.png)
汇总:五个开源的Three.js项目
Three.js 是一个基于 WebGL 的 JavaScript 库,它提供了一套易于使用的 API 用来在浏览器中创建和显示 3D 图形。通过抽象和简化 WebGL 的复杂性,Three.js 使开发者无需深入了解 WebGL 的详细技术就能够轻松构建和渲染3D场景、模型、动画、粒子系统等。 T…...
![](https://img-blog.csdnimg.cn/direct/9137b586cd1c449cbb2a01ed80b5f737.png)
JavaScript(一)---【js的两种导入方式、全局作用域、函数作用域、块作用域】
一.JavaScript介绍 1.1什么是JavaScript JavaScript简称“js”,js与java没有任何关系。 js是一种“轻量级、解释型、面向对象的脚本语言”。 二.JavaScript的两种导入方式 2.1内联式 在HTML文档中使用<script>标签直接引用。 <script>console.log…...
![](https://img-blog.csdnimg.cn/direct/de6cb4b0027e4cff98628a6c0f0bd873.png)
部署云原生边缘计算平台kubeedge
文章目录 1、kubeedge架构2、基础服务提供 负载均衡器 metallb2.1、开启ipvc模式中的strictARP2.2、部署metalb2.2.1、创建IP地址池2.2.2、开启二层转发,实现在k8s集群节点外访问2.2.3、测试 3、部署cloudcore3.1、部署cloudcore3.2、修改cloudcore的网络类型 4、部…...
![](https://www.ngui.cc/images/no-images.jpg)
Java设计模式:单例模式详解
设计模式:单例详解 文章目录 设计模式:单例详解一、单例模式的原理二、单例模式的实现推荐1、饿汉模式2、静态内部类 三、单例模式的案例四、单例模式的使用场景推荐总结 一、单例模式的原理 单例模式听起来很高大上,但其实它的核心思想很简…...
![](https://www.ngui.cc/images/no-images.jpg)
Qt5.14.2 定时器黑魔法,一键唤醒延时任务
在图形界面程序的世界里,有这么一个需求无处不在:在特定的时间间隔后,执行一段特殊的代码。比如说30秒后自动保存文档、500毫秒后更新UI界面等等。作为资深Qt程序员,我相信各位一定也曾为实现这种"延时任务"而绞尽脑汁。今天&#…...
![](https://img-blog.csdnimg.cn/direct/21d5dad33cef48f4a5109bc7cf7c1034.png)
C++项目——集群聊天服务器项目(九)客户端异常退出业务
服务器端应检测到客户端是否异常退出,因此本节来实现客户端异常退出,项目流程见后文 一、客户端异常退出业务流程 (1)在业务模块定义处理客户端异常退出的函数 (2)集群聊天服务器项目(八)提到…...
![](https://img-blog.csdnimg.cn/direct/19653c2da0364c91bb49e31b055194dc.png#pic_center)
STM32CubeIDE基础学习-HC05蓝牙模块和手机通信
STM32CubeIDE基础学习-HC05蓝牙模块和手机通信 文章目录 STM32CubeIDE基础学习-HC05蓝牙模块和手机通信前言第1章 硬件连接第2章 工程配置第3章 代码编写3.1 手机指令控制LED 第4章 实验现象总结 前言 前面的文章学习了串口通过轮询和中断的简单使用方法,现在就来用…...
![](https://img-blog.csdnimg.cn/direct/1cda611311354a4281a1b5c32c9ec802.png)
npm mongoose包下载冲突解决之道
我在新电脑下载完项目代码后,运行 npm install --registryhttps://registry.npm.taobao.org 1运行就报错: npm ERR! code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree npm ERR! npm ERR! While resolving: lowcode-form-backend1.0.0 npm …...
![](https://img-blog.csdnimg.cn/direct/d0f438b75e3b4695a91c79d659381bfa.png)
26. UE5 RPG同步面板属性(二)
在上一篇,我们解析了UI属性面板的实现步骤: 首先我们需要通过c去实现创建GameplayTag,这样可以在c和UE里同时获取到Tag创建一个DataAsset类,用于设置tag对应的属性和显示内容创建AttributeMenuWidgetController实现对应逻辑 并且…...
![](https://img-blog.csdnimg.cn/direct/9df46c9418f246cd99e54d940414eff4.png#pic_center)
五、postman基础使用案例
postman基础使用 相关案例【传递查询参数】【提交表单数据】【提交JSON数据】 注:postman⼀款⽀持调试和测试的⼯具,开发、测试⼯程师都可以使⽤。方法一般统一为:方法→请求头→请求体→断言 相关案例 【传递查询参数】 访问TPshop搜索商品的…...
![](https://img-blog.csdnimg.cn/img_convert/79ae3764cc6a8af6624d93731f197dc9.png)
Git合并利器:Vimdiff使用指南
使用 vimdiff 作为 Git 的合并工具确实可能会让新手感到困惑,但它是一个功能强大的工具,一旦掌握了它,就可以非常高效地进行代码合并和比较。以下是一个简短的教程,旨在帮助理解 vimdiff 的基本用法以及如何利用它来进行 Git 合并…...
![](https://img-blog.csdnimg.cn/img_convert/bdb31b5a146ebea628294fc9764821b6.jpeg)
阿里云2核4G服务器租用价格_30元3个月_165元一年_199元
阿里云2核4G服务器租用优惠价格,轻量2核4G服务器165元一年、u1服务器2核4G5M带宽199元一年、云服务器e实例30元3个月,活动链接 aliyunfuwuqi.com/go/aliyun 活动链接如下图: 阿里云2核4G服务器优惠价格 轻量应用服务器2核2G4M带宽、60GB高效…...
![](https://img-blog.csdnimg.cn/direct/fd07d6f3cc8e449eb79e2e7ad927378c.png)
<QT基础(2)>QScrollArea使用笔记
项目需要设置单个检查的序列图像预览窗口,采用QScrollArea中加入QWidget窗口,每个窗口里面用Qlabel实现图像预览。 过程涉及两部分内容 引入QWidget 引入label插入图像(resize) 引入布局 组织 scrollArea内部自带Qwidget&#…...
![](https://img-blog.csdnimg.cn/direct/e8da4874282a4237a38ea60a032cfb2e.png)
springboot企业级抽奖项目业务四 (缓存预热)
缓存预热 为什么要做预热: 当活动真正开始时,需要超高的并发访问活动相关信息 必须把必要的数据提前加载进redis 预热的策略: 在msg中写一个定时任务 每分钟扫描一遍card_game表 把(开始时间 > 当前时间)&& (开始时间 < 当前时间1分钟)的活动及相…...
![](https://www.oschina.net/img/hot3.png)
wordpress图片下载主题/北京口碑最好的教育机构
2019独角兽企业重金招聘Python工程师标准>>> 相信作为一个开发人员应该对XML与JSON 非常熟悉。关于两者的介绍与区别网上已经有很多资料,java对于XML的解析也有很多工具包,主要解析的方式有三种: 1.DOM解析方式:适用于…...
![](https://img2018.cnblogs.com/blog/1222443/201901/1222443-20190119112123130-1744326230.png)
有什么网站做任务换q币吗/游戏推广赚佣金
此教程是博主亲自帮朋友管理服务器所操作的完整步骤,当然此步骤适合所有的linux-centos系统,不管centos怎么变,linux怎么变,它的这些命令可以说是基本不变的;先说一下博主此教程所用的服务器的环境: 操作系…...
![](/images/no-images.jpg)
网站效果图尺寸/常用的seo工具的是有哪些
php 7.1 中将mcrypt扩展标记为过期,虽然可以通过pecl安装,不过考虑到libmcrypt很久很久没更新过了,还是将aes加解密代码变更为openssl方式比较合适,测试代码如下:error_reporting(E_WARNING);class CryptAES {/* AES加…...
![](/images/no-images.jpg)
网站动图banner怎么做/如何优化网络环境
一、H3C 交换机密码配置一、CONSOLE口登陆在AUX用户接口视图下,可以设置CONSOLE用户登陆的口令认证。有如下三种认证方式None:不需要口令认证Password:需要简单的本地口令认证,包含明文(simple)和密文(cipher)Scheme&a…...
![](/images/no-images.jpg)
黄村做网站哪家好/有没有免费的seo网站
什么是红色表示用户需要输入或定制的生产线将在红色在本教程! 其余的应该主要是复制和粘贴。关于MySQLMySQL是一个开源数据库管理软件,可帮助用户存储,组织和以后检索数据。 它有多种选项来授予特定用户在表和数据库中的细微的权限 - 本教程将…...
![](/images/no-images.jpg)
各大网站黑白几天/腾讯广告推广怎么做
创建一个存储过程create procedure porc () #存储过程名称porc begin select user from mysql.user; #sql语句 end;调用存储过程call porc();删除存储过程DROP PROCEDURE IF EXISTS porc;转载于:https://blog.51cto.com/quliren/1984097...