news 2026/6/15 16:09:03

多线程(2)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
多线程(2)

三、线程状态【理解】

static void sleep(long ms):让当前线程处于休眠状态,休眠的单位是毫秒(ms),处于休眠状态的线程进入有限
期等待状态 。sleep方法会让当前线程释放cpu,但是不释放锁标记。
2. void join() : 让某 线程加入到自身任务中,在哪个线程中调用其他线程join方法,则代表此线程让步其他线程
优先执行,此线程从而进入无限期的等待状态。
例如:在主线程中main函数中: t.join() ; 代表主线程让步于t线程执行
四、线程同步【重点】
1. 临界资源:多线程并发时,被多个线程共享的同一个对象,称为临界资源。
2. 原子操作:不可以分割的多步操作,被视为一个整体,其执行顺序和步骤不能被打破。
3. 线程同步:多线程并发访问时,为了保证临界资源的正确性,从而不破坏操作中的原子操作。
(保护原子操作不能被破坏)
4. 线程同步的两种方式:
(1) 同步代码块:对临界资源对象进行加锁。
a. 定义位置:方法内部
b. 利用 synchronized 对临界资源加锁
c. 语法: synchronized(临界资源对象){
// 原子操作
}
d. 执行的原理:当线程获取临界资源的锁标记时,锁标记空闲,则能获取该对象的锁标记,获取锁标记之
后,可以执行同步代码块{}中的代码,而且只有当{}中所有的内容全部执行完,才释放拥有的锁标
记;但是当线程获取临界资源对象的锁标记时,锁标记被其他线程占用,则此线程进入阻塞状态
(Blocked状态),只有当其他线程释放锁标记,此线程获取锁标记,才结束阻塞状态,同时获取cpu,可以执行{}中 的内容。
2) 同步方法:

a. 用 synchronized修饰 方法:被 synchronized修饰的方法称为同步方法

b. 语法:

修饰符 synchronized 返回值类型 方法名(形参列表)throws 异常{

// 原子操作

}

c. 同步方法等价于 同步代码块:是对当前对象进行加锁

synchronized(this){

// 原子操作

}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 11:47:26

等保测评全流程实操手册:从自查到验收,一步不踩坑

2025年3月20日起,新版《网络安全等级测评报告模板》正式启用,标志着等保测评进入“精准防控”新阶段。对企业而言,合规不再是简单满足条款,而是要应对云原生、物联网等新增场景的防护要求,这让不少运维人员在测评中频频…

作者头像 李华
网站建设 2026/6/15 14:36:02

第十七篇:Day49-51 前端工程化进阶——从“手动”到“自动化”(对标职场“提效降本”需求)

一、前置认知:前端工程化的核心价值与职场痛点 在掌握性能优化和安全防护能力后,我们能打造“快、稳、安”的产品,但当面对“团队10人协作开发”“每日3次版本迭代”“多环境部署”等职场场景时,手动复制文件、人工测试、线下传输…

作者头像 李华
网站建设 2026/6/15 11:50:39

[GFCTF 2021]where_is_shell

第一次打CTF——PWN篇学习笔记16 在ida中看一看,发现可疑地址 int __fastcall main(int argc, const char **argv, const char **envp) {_BYTE buf[16]; // [rsp0h] [rbp-10h] BYREF ​system("echo zltt lost his shell, can you find it?");read(0, …

作者头像 李华
网站建设 2026/6/15 12:54:05

Python大数据基于数据挖掘的高考志愿推荐系统的设计与实现_3ri592gf_论文

文章目录系统截图项目简介大数据系统开发流程主要运用技术介绍爬虫核心代码展示结论源码文档获取定制开发/同行可拿货,招校园代理 :文章底部获取博主联系方式!系统截图 Py 大数据基于数据挖掘的高考志愿推荐系统的设计与实现 项目简介 本次研究将…

作者头像 李华
网站建设 2026/6/14 20:03:44

不被代码包围,你就不知道什么是服务器端信息测试!

本章节主要讲解“软件测试的服务器端信息测试”服务器端信息测试主要是从服务器对客户端开发的信息角度来测试服务器被攻击的可能性,以及被攻击的难易程度。主要需要测试以下几方面的信息:服务器允许运行账号权限测试。Web 服务器端口测试。Web 服务器版…

作者头像 李华