Java并发/多线程教程——3多线程的开销

简介: Java并发/多线程教程
本系列译自jakob jenkov的Java并发多线程教程,个人觉得很有收获。由于个人水平有限,不对之处还望矫正!

应用程序由单线程到多线程,不仅仅给我带来了便利,同时也也带来了一些开销。不要因为你会多线程,就把所有的程序都设计成多线程。如果把单线程改成多线程,你获得到的好处要远远超过开销,对于这一点你应该有个清醒的认识。当你犹豫是应该用多线程还是单线程时,你要衡量性能和响应时间,而不是靠猜测。
更复杂的设计

尽管多线程应用程序的某些部分比单线程应用程序更简单,但其他部分会更复杂,访问共享数据的执行代码需要特别注意,线程间的交互并不简单,错误的线程同步产生的问题很不容易检测、重现和修复。
上下文切换的开销

当CPU从一个线程的执行切换到另一个线程,CPU 需要保存当前线程的本地数据,程序指针等。这种切换称之为"上下文切换",CPU从一个线程的上下文,切换到另一个线程的上下文,上下文的切换并不容易,除非必要,不要进行频繁的上下文切换。
增加资源消耗

一个线程的运行需要计算机的资源,除了CPU 的运行时间,还需要一些内存来存他的本地堆栈,它可能也会占用操作系统的资源去管理这个线程,例如,可创建一个程序,开启100个线程除了等待,其他什么都不做,看看当这个程序运行时内存的占用情况。
相关文章
|
21小时前
|
消息中间件 缓存 NoSQL
Java多线程实战-CompletableFuture异步编程优化查询接口响应速度
Java多线程实战-CompletableFuture异步编程优化查询接口响应速度
|
23小时前
|
数据采集 存储 Java
高德地图爬虫实践:Java多线程并发处理策略
高德地图爬虫实践:Java多线程并发处理策略
|
1天前
|
数据采集 前端开发 测试技术
《手把手教你》系列技巧篇(三十一)-java+ selenium自动化测试- Actions的相关操作-番外篇(详解教程)
【4月更文挑战第23天】本文介绍了网页中的滑动验证码的实现原理和自动化测试方法。作者首先提到了网站的反爬虫机制,并表示在本地创建一个没有该机制的网页,然后使用谷歌浏览器进行验证。接着,文章详细讲解了如何使用WebElement的click()方法以及Action类提供的API来模拟鼠标的各种操作,如右击、双击、悬停和拖动。
6 2
|
1天前
|
缓存 Java
【Java基础】简说多线程(上)
【Java基础】简说多线程(上)
5 0
|
2天前
|
Java API 调度
[Java并发基础]多进程编程
[Java并发基础]多进程编程
|
2天前
|
并行计算 算法 安全
Java从入门到精通:2.1.3深入学习Java核心技术——掌握Java多线程编程
Java从入门到精通:2.1.3深入学习Java核心技术——掌握Java多线程编程
|
2天前
|
安全 Java 编译器
是时候来唠一唠synchronized关键字了,Java多线程的必问考点!
本文简要介绍了Java中的`synchronized`关键字,它是用于保证多线程环境下的同步,解决原子性、可见性和顺序性问题。从JDK1.6开始,synchronized进行了优化,性能得到提升,现在仍可在项目中使用。synchronized有三种用法:修饰实例方法、静态方法和代码块。文章还讨论了synchronized修饰代码块的锁对象、静态与非静态方法调用的互斥性,以及构造方法不能被同步修饰。此外,通过反汇编展示了`synchronized`在方法和代码块上的底层实现,涉及ObjectMonitor和monitorenter/monitorexit指令。
15 0
|
8月前
|
Java 容器
Java——使用多线程模拟真实高并发业务并保证安全性(二)
Java——使用多线程模拟真实高并发业务并保证安全性(二)
|
8月前
|
Java 容器
Java——使用多线程模拟真实高并发业务并保证安全性(一)
Java——使用多线程模拟真实高并发业务并保证安全性(一)
|
8月前
|
Java 程序员 开发者
疫情过后,Java开发者如何应对多线程与高并发面试题目?
发某粉丝年前参加某个NB企业的面试题列表: 聊聊synchronized的CPU原语级别实现 有一千万个数,写一个程序进行高效求和 已知2开平方为1.414,如何不用数学库,求开平方的值,精确到小数点儿后面10位 编码实现两个线程,线程A不断打印1-10的数字,要求在打印到第五个数字的时候通知线程B 自定义线程池需要指定哪7个参数,为什么不建议使用JUC内置线程池? 高并发、任务执行时间短的业务怎样使用线程池? 并发不高、任务执行时间长的业务怎样使用线程池? 并发高、业务执行时间长的业务怎样使用线程池? 设计一个12306网站,能够撑住最高百万级别TPS(淘宝最高54万TPS),你该如何实现

热门文章

最新文章