资讯专栏INFORMATION COLUMN

《Java并发编程实战》读书笔记-第1章 简介

zhoutk / 2300人阅读

摘要:线程允许同一个进程中同时存在多个程序控制流。线程也被称为轻量级进程。现代操作系统中,都是以线程为基本的调度单位,而不是进程。

并发简史

在早期的计算机中不包含操作系统,从头至尾都只执行一个程序,并且这个程序能访问计算机所有资源。操作系统的出现使得计算机每次能运行多个程序,并且不同的程序都在多带带的进程中运行:操作系统为各个独立执行的进程分配内存、文件句柄、安全证书等。不同进程之间通过一些粗粒度的通信机制交换数据,包括:套接字、信号处理器、共享内存、信号量以及文件等。
之所以在计算机中加入操作系统来实现多个程序同时执行,主要基于以下原因:

资源利用率:在某些情况下,程序如果在等待某个外部操作执行完成的同时,可以运行另一个程序,那无疑将提高资源的利用率。
公平性:通过粗粒度的时间分片运行方式,使得不同的用户和程序对于计算机上的资源有着共同的使用权。
便利性:计算多个任务时,编写多个程序,每个程序执行一个任务并在必要时相互通信,比之编写一个程序来计算所有任务更容易实现。

这些促使进程出现的因素同样也促使着线程的出现。线程允许同一个进程中同时存在多个程序控制流。线程会共享进程范围内的资源(内存、文件句柄),但每个线程都有各自的程序计数器、栈、局部变量等。一个程序中的多个线程也可以同时被调度到多个CPU上运行。

线程也被称为轻量级进程。现代操作系统中,都是以线程为基本的调度单位,而不是进程。

线程的优势
发挥多处理器的强大能力
建模的简单性
异步事件的简化处理
响应更灵敏的用户界面
线程带来的风险

安全性问题
多个线程同时访问和修改相同的变量时,会发生无法预料的数据变化,导致线程出现错误

活跃性问题
当某个操作无法继续执行下去时:死锁、饥饿、活锁

性能问题
多线程程序中不仅存在于单线程程序相同的性能问题(服务时间过长、响应不灵敏、吞吐率过低、资源消耗过高、可伸缩行较低等),而且还存在由于使用线程而引入的其他性能问题:

在多线程程序中,当线程调度器临时挂起活跃线程并转而运行另一个线程时,会频繁的出现上下文切换操作(Context
Switch),这种操作将带来极大的开销:保存和恢复执行上下文,丢失局部性,CPU花更多的时间在线程调度而不是线程运行上。
使用同步机制操作共享数据时,会抑制编译器优化,是内存缓存区中的数据无效,以及增加共享内存总线的同步流量

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/77892.html

相关文章

  • Java并发编程的艺术】读书笔记

    摘要:前言并发编程的目的是让程序跑的更快,但并不是启动更多的线程,这个程序就跑的更快。尽可能降低上下文切换的次数,有助于提高并发效率。死锁并发编程中的另一挑战是死锁,会造成系统功能不可用。 前言 并发编程的目的是让程序跑的更快,但并不是启动更多的线程,这个程序就跑的更快。有以下几种挑战。 挑战及方案 上下文切换 单核CPU上执行多线程任务,通过给每个线程分配CPU时间片的方式来实现这个机制。...

    马忠志 评论0 收藏0
  • Java8实战》-读书笔记(用流收集数据-01

    摘要:收集器用作高级归约刚刚的结论又引出了优秀的函数式设计的另一个好处更易复合和重用。更具体地说,对流调用方法将对流中的元素触发一个归约操作由来参数化。另一个常见的返回单个值的归约操作是对流中对象的一个数值字段求和。 用流收集数据 我们在前一章中学到,流可以用类似于数据库的操作帮助你处理集合。你可以把Java 8的流看作花哨又懒惰的数据集迭代器。它们支持两种类型的操作:中间操作(如 filt...

    EscapedDog 评论0 收藏0
  • 《Spring实战读书笔记——Spring简介

    摘要:如何降低开发的复杂性最小侵入编程通过面向接口和依赖注入实现松耦合基于编程惯例和切面进行声明式编程通过模板减少样板式代码容器在应用中,不再由对象自行创建或管理它们之间的依赖关系容器负责创建对象装配对象配置它们并管理它们的整个生命周期。 欢迎大家关注我的微信公众号,一起探讨Java相关技术 showImg(https://segmentfault.com/img/bVboaBO?w=129...

    CKJOKER 评论0 收藏0
  • Java学习路线总结,搬砖工逆袭Java架构师(全网最强)

    摘要:哪吒社区技能树打卡打卡贴函数式接口简介领域优质创作者哪吒公众号作者架构师奋斗者扫描主页左侧二维码,加入群聊,一起学习一起进步欢迎点赞收藏留言前情提要无意间听到领导们的谈话,现在公司的现状是码农太多,但能独立带队的人太少,简而言之,不缺干 ? 哪吒社区Java技能树打卡 【打卡贴 day2...

    Scorpion 评论0 收藏0
  • Java 8 函数式编程读书笔记——数据并行化

    摘要:限制编写并行流,存在一些与非并行流不一样的约定。底层框架并行流在底层沿用的框架,递归式的分解问题,然后每段并行执行,最终由合并结果,返回最后的值。 本书第六章的读书笔记,也是我这个系列的最后一篇读书笔记。后面7、8、9章分别讲的测试、调试与重构、设计和架构的原则以及使用Lambda表达式编写并发程序,因为笔记不好整理,就不写了,感兴趣的同学自己买书来看吧。 并行化流操作 关于并行与并发...

    leone 评论0 收藏0

发表评论

0条评论

zhoutk

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<