Java一棵树之001线程
一、理解浓缩
线程是计算机cpu调度的最小的单位,并且jvm中的线程和机器中的线程是一一对应的,在现代编程中,很多时候为了充分利用机器资源而使用多线程,当然很多时候工作中并未使用线程,还是根据场景来选择,比如遇到有大批量数据处理时,那么就可以大大提高处理效率,说道多线程一般都会说到两个老生常谈的几个概念【并行】,【并发】【串行】,打个比方说明这三个概念,有一个做饼子的炉子,三个烧饼师傅甲乙丙要各做10块
a.【串行】师傅甲做完10块饼子,然后让第二个师傅乙做完10块饼子,最后是第三个师傅丙做,这就是串行,师傅直接互补干扰,觉得不会有并发等问题,但是有利有弊,效率一般比较底下。
b.【并发】师傅甲做完1块饼子,然后让师傅乙做1一块饼子,然后师傅丙(这里次序不是绝对的),这就是并发,对于计算机来说速度非常快,做饼子那个快你都没眨眼就做好了,当然这个炉子也可以多个的,这里重在说明最大限度使用机器资源,不让机器歇着,是不是跟资本家有点像。
c.【并行】对于并行,一个炉子是不行的,比如我们这里加2个炉子,一人一个炉子,这样三个师傅每人一个炉子同时做饼子,注意是绝对的同时(并发是假的同时,幻觉而已),这就是并行,并行更多说的是概念,比如马路双向8车道也是并行的好例子,理解概念就好。
二、使用注意事项
2.1 使用姿势
| 方式 | 特点 | ||||
| a.继承Thread类 | 没啥说的,直接创建实例,然后start即可开启一个异步线程 | ||||
| b.实现Runnable接口 | 工作中用的稍微多点,比如还可以继承点其它类 | ||||
| c.使用FutureTask方式 | 使用上类似b,但是可以拿到执行结果 | ||||
2.2 线程相关常用方法
| 方法名 | 简单说明 | 注意事项 | 常用使用场景 |
| sleep( time) | 让当前线程睡眠一定时间阻塞 | 【Thread类的静态方法】执行此方法后线程只是让出cpu执行时间片阻塞但并未释放锁等资源 | 比如在循环里间隔一段时间执行一次任务(eg.刷接口) |
| wait,wait(time) | 让调用线程阻塞,也有带时间参数的变种方法 | 【Object类实例方法】使用此方法有限制,需要先通过synchronized获得监视器锁然后再调用,调用后释放当前监视器锁,但是占有的其它的监视器锁并不释放 | 典型的生产者消费者 |
| notify,notifyAll | 与wait对应,即唤醒阻塞的线程 | 【Object类实例方法】一般使用notifyAll,因为notify唤醒是不确定的,直接都唤醒就能避免(使用前也得获得监视器锁) | |
| yield | 让出线程的时间片给其它线程 | 【Thread类的静态方法】执行这个方法后并不是100%就不执行了,这个方法只是通知调度器自己分得的时间片可以不用了,此时线程并未阻塞 | 实际工作中使用较少,调试代码有时可以用用 |
| join | 让调用线程阻塞等待,直到线程执行完毕 | 【Thread类的实例方法】阻塞的是调用线程,功能与countdownlatch类似 | 多任务协调时使用 |
| interrupt,isInterrupted, interrupted | 设置中断标志来打断阻塞 | 【Thread类的静态方法】该方法只是设置阻塞中断标志, interrupted是检测当前调用线程的中断状态的并且会清除中断标志 |
Java一棵树之001线程的更多相关文章
- Java一棵树
手里有一枚java种子,刚播下,希望长出一棵参天大树. 一.Java Java线程 二.网络 三.算法 四.中间件 五.性能指标&优化 六.设计模式
- 如何打印一棵树(Java)
1.有一棵多叉树,将它打印出来. import java.util.LinkedList; /** * 需求:按层打印一棵树 * 说明:树是保存在一个链表中 * created by wangjunf ...
- 小希的迷宫(MST单棵树判断法则)
小希的迷宫 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- Java数据结构之树和二叉树(2)
从这里始将要继续进行Java数据结构的相关讲解,Are you ready?Let's go~~ Java中的数据结构模型可以分为一下几部分: 1.线性结构 2.树形结构 3.图形或者网状结构 接下来 ...
- A Simple Problem with Integers(100棵树状数组)
A Simple Problem with Integers Time Limit: 5000/1500 MS (Java/Others) Memory Limit: 32768/32768 K ...
- java数据结构之树
树定义和基本术语定义树(Tree)是n(n≥0)个结点的有限集T,并且当n>0时满足下列条件: (1)有且仅有一个特定的称为根(Root)的结点: (2)当n>1时,其余结 ...
- SDUT 2129 树结构练习——判断给定森林中有多少棵树
树结构练习——判断给定森林中有多少棵树 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 众 ...
- Java并发编程:如何创建线程?
Java并发编程:如何创建线程? 在前面一篇文章中已经讲述了在进程和线程的由来,今天就来讲一下在Java中如何创建线程,让线程去执行一个子任务.下面先讲述一下Java中的应用程序和进程相关的概念知识, ...
- Java并发编程:进程和线程之由来
Java多线程基础:进程和线程之由来 在前面,已经介绍了Java的基础知识,现在我们来讨论一点稍微难一点的问题:Java并发编程.当然,Java并发编程涉及到很多方面的内容,不是一朝一夕就能够融会贯通 ...
随机推荐
- JS 自定义字典对象
<script type="text/javascript" language="javascript"> //自定义字典对象 function D ...
- Autoit安装及启动
1.Autoit下载: 官网下载地址:https://www.autoitscript.com/site/autoit/downloads/ 提供百度网盘下载:https://pan.baidu.co ...
- 第五周课程总结&实验报告(四)
第五周课程总结 本周主要学习了 1.抽象类 抽象类的定义格式 abstract class抽象类名称{ 属性; 访问权限返回值类型方法名称(参数){ //普通方法 [return返回值]; } 访问权 ...
- Oracle数据库弱口令解密
1.首先我们先看下Oracle加密的格式. 接下来我们把他头和尾部删除,中间加: 通过py脚本来进行完成 转换完成后输出成这种格式 之后直接丢进kali里面,用john --w=字典文件 + 转换文件 ...
- Linux下使用 minicom 自动重复发送数据的实现
目录 在minicom中添加脚本路径 编写脚本 执行脚本 一个项目里要用的设备需要用串口来模拟传感器来测试,还是Linux下的. 串口助手cutecom很好用,但是不能定时发送数据. 所以用下面这个脚 ...
- linux内核开源代码地址下载
https://www.kernel.org/pub/linux/kernel/v2.6/
- [转帖]华为Mate20 X 5G版拆解:巴龙5000还配备了3GB独立内存!
华为Mate20 X 5G版拆解:巴龙5000还配备了3GB独立内存! 投递人 itwriter 发布于 2019-07-29 21:35 评论(7) 有1733人阅读 原文链接 [收藏] « » h ...
- kettle转换设置变量,校验输出新变量
背景:有很多小的转换需要串联起来,如果前一个执行成功,后面继续接着执行,如果执行等待中,就让程序等一会再次获取数据分析,如果失败就中止,成功就进行下一个转换,以此类推.... 需求:通过job把参数传 ...
- django form组件 cookies,session
django form组件 渲染标签 就是组件里面的字段在前端展示叫做渲染标签 校验数据 用户输入的数据提交给后端组件叫做校验数据 forms组件中定义的字段都是必须传值的(required=Tr ...
- Phython-守护线程
import threading,time def run(n): print("task is ",n) time.sleep(2) print("task done& ...