每个 Java 开发人员都应该知道的关于线程、Runnable和线程池的知识

3dbd34395852f4693b8c87778b50011f.gif

新钛云服已为您服务1472

bf4a60353d450f0a8ca88c1412778386.gif

多线程是Java 中最复杂和最强大的部分

多线程章节是 Java 中最难理解和使用的章节。不幸的是,没有多少资源可以让您获得所有答案。同时,并发知识至关重要。在本文中,我解释了每个 Java 开发人员都必须了解的多线程的核心方面。在这一部分中,我们从 Thread 和 Runnable 主题开始。

为什么并发知识如此重要?

如果没有良好的多线程知识,您将无法获得高级 Java 工作

几乎可以肯定,多线程知识是 Java 高级职位面试的主题。如果没有对多线程的清晰理解,无论是否有实践经验,你很可能会失败。

4f25ceca67d92d2d77b739ce9acda236.png

几乎每个生产应用程序都使用多线程范式

在实际项目的实践中,您将使用应用程序服务器或其替代品。它们都基于线程池等多线程解决方案。任何在其之上的适当实现都需要并发一致性。 

77cbebad663f2457b25ae5cb486ef573.png

线程和可运行定义

多线程基于 Thread 和 Runnable。Thread 是一个启动新的独立活动并执行 Runnable 提供的指令的类。

544a38bfdc25ae18234ab707e41d225a.png

线程是一个附加到操作系统的实体,所以这就是它是一个重类的原因。同时 Runnable 只是一组指令——所以这就是为什么它是轻量级的。

b39aa173d9428b4f792bede3807c4e1c.png

如何执行新线程

线程可以通过使用Run()方法在当前运行的线程内部执行指令。为了在新活动中运行指令,Thread 提供了Start()方法。

c1c1aaf8161cea1c0ac42a1ba4cac9df.png

5238fef681daf0a47e6fea5020f88da6.png

如何重用线程

线程可以在其中执行许多可运行的任务。这是一篇更详细的文章。在这里,您可以看到一个非常简短的示例,其中许多可运行对象(任务)在一个线程中运行:

0455f34f3e3f0ddf046a965534132b23.png

96f998cb2a1275af5be5977843c21d93.png

如何停止线程

你不能只是stop()suspend()线程。这些方法已弃用。您必须注意使用isAlive()或的中断设计isInterrupted()

818413ebbbe30acb58d33b5728faa064.png

a0ece00850f3429fa76d23ab86215186.png

线程守护进程

线程可以是守护进程。即使最后一部分不会执行,守护线程也会立即中断。所以这样的线程可以附加到资源上。否则,它们可能是资源或/和内存泄漏的原因。

4781397897d41461f484734d8ba7ece7.png

ab6726b1b96b7cc664afca4f6f8e4afb.png

如何使用线程池

只要 Thread 实例很重,使用 ThreadPool 类重用相同的 Thread 是有意义的。您可以根据线程使用不同的 ThreadPool 实现。 


· 固定线程池

FixedThreadPool 是一个具有预定义线程数的简单池。期间线程数不会改变。使用它是有意义的:

31657c13c7f25691c798ace40b09f247.png


· 缓存线程池

与Fixed Thread Pool相反,这个可以在添加更多任务时动态增加线程数。每个新创建的线程在使用时都将处于活动状态,否则将在空闲 60 秒后将其删除。

82c4da30b8040eaa7637c88e20adfb7b.png


如何定义线程池中的线程数

为了为您的应用程序使用最好的线程池,您需要了解以下内容:

  • 如果您的线程执行大量计算,例如视频渲染、加密等,那么它会吃掉运行该线程的进程。

  • 如果您的线程运行与 CPU 活动(如网络调用、内存调用等)无关,则它不会消耗运行其线程的 CPU。

e1bc02d8411c9b3fee5704363a6fc3f9.png

依靠这些知识,您可能会得出以下结论:

  • 拥有高 CPU 消耗任务的任务分配的线程数不会超过 CPU 内核数。

aae02294177eea77e9bef9fb3eb2581d.png

  • 对于 CPU 消耗较低的任务,您可以拥有比 CPU 内核更多的线程(但比例取决于具体情况)。

88529cd13095ff9afabb9f4445e81e72.png


结论:

本文仅重点介绍有关线程、可运行和线程池概念的主要内容,但并未完全涵盖。仍有许多方面可能发挥重要作用。我希望你喜欢我使用的信息图表。如果您认为我遗漏了与此主题相关的重要内容,请留下您的反馈。谢谢阅读!

*原文链接:https://dzone.com/articles/what-every-java-dev-should-know-thread-runnable-thread-pool

*本文部分图片源于网络,如有侵权请联系删除

了解新钛云服

新钛云服荣膺第四届FMCG零售消费品行业CIO年会「年度数字化服务最值得信赖品牌奖」

新钛云服三周岁,公司月营收超600万元,定下百年新钛的发展目标

当IPFS遇见云服务|新钛云服与冰河分布式实验室达成战略协议

新钛云服正式获批工信部ISP/IDC(含互联网资源协作)牌照

深耕专业,矗立鳌头,新钛云服获千万Pre-A轮融资

新钛云服,打造最专业的Cloud MSP+,做企业业务和云之间的桥梁

新钛云服一周年,完成两轮融资,服务五十多家客户

上海某仓储物流电子商务公司混合云解决方案

往期技术干货

Kubernetes扩容到7,500节点的历程

低代码开发,全民开发,淘汰职业程序员!

国内主流公有云VPC使用对比及总结

万字长文:云架构设计原则|附PDF下载

刚刚,OpenStack 第 19 个版本来了,附28项特性详细解读!

Ceph OSD故障排除|万字经验总结

七个用于Docker和Kubernetes防护的安全工具

运维人的终身成长,从清单管理开始|万字长文!

OpenStack与ZStack深度对比:架构、部署、计算存储与网络、运维监控等

什么是云原生?

IT混合云战略:是什么、为什么,如何构建?

bd8c090aebca85c166c8b992b8536168.gif

点👇分享

9dd7c14425a8dd52b5073b14241cad90.gif

戳👇在看

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值