多线程多任务是程序开发者与用户都需要的中资产

简介: 多线程多任务是程序开发者与用户都需要的中资产

电脑工业界每有新的技术问世,人们总是不遗余力地去担忧“它是不是够 重要”。公司行号虎视眈眈地注意其竞争对手,直到对方采用并宣扬这技术有 多么重要,才开始急急赶上。不论这技术是不是真的很重要,每一个人都想尽 办法让最终用户感觉“真的很重要”。好啦,于是最终用户真的觉得需要它 了——即使他们完全不了解那是什么东西。


“线程”程序设计正处在这个循环的起点。虽然线程在各式各样的操作系 统上已经存在了不只十年,但它毕竟还是藉着无孔不入的 Windows 95 和 Windows NT,才能够打进家庭软件和商务应用软件中。  

不久的将来,多线程多任务软件将广泛地蔓延开来。线程将成为每一个软 件开发者必须使用的标准程序工具。并不是每一个程序都必须使用线程,然而 多线程多任务——一如多媒体软件或Internet软件所支持的——将使程序的效率得以高度发挥。线程可以改善用户对于软件操作的感受,简化程序的开发, 在同一时间的一台服务器上提供对成百上千用户的支持。用户通常只知晓其结 果,他们不知道背后是什么力量促成了这伟大的改良。  

单线程程序就像超级市场中唯一的一位出纳员。这个出纳员对于小量采购 可以快速结账,但如果有人采买了一大车货品,结账就需要点时间了,其他每 一个人都必须等待。  

多线程程序像是有一群出纳员,每人负责一条线。某些线专门用来为大买 家服务,其他线处理小市民的采买。一条线瘫痪了,并不会影响其他线。  

根据这样的宏观印象,下面是一个简单的定义:  

多线程,使程序得以将其工作分开,独立运作,不互相影响。  

线程并不总是被要求达到这样的目标,不过它们的确使这个目标更容易达 成。为了了解线程在什么地方进入程序设计的大版图中,我们最好稍稍知道, 自从 MS-DOS 问世到现在,程序员的需求有了些什么样的改变。


过去 15 年来,在微软操作系统上工作的程序开发者,花费在程序与程序 的合作上的精力愈来愈少。由于用户的需要以及程序体积的增长,操作系统必 须负担愈来愈多的任务在“多任务”上头,并且让一切顺利。  

7

相关文章
|
3月前
|
缓存 Java 调度
Java并发编程:深入解析线程池与Future任务
【7月更文挑战第9天】线程池和Future任务是Java并发编程中非常重要的概念。线程池通过重用线程减少了线程创建和销毁的开销,提高了资源利用率。而Future接口则提供了检查异步任务状态和获取任务结果的能力,使得异步编程更加灵活和强大。掌握这些概念,将有助于我们编写出更高效、更可靠的并发程序。
|
16天前
|
缓存 负载均衡 Java
c++写高性能的任务流线程池(万字详解!)
本文介绍了一种高性能的任务流线程池设计,涵盖多种优化机制。首先介绍了Work Steal机制,通过任务偷窃提高资源利用率。接着讨论了优先级任务,使不同优先级的任务得到合理调度。然后提出了缓存机制,通过环形缓存队列提升程序负载能力。Local Thread机制则通过预先创建线程减少创建和销毁线程的开销。Lock Free机制进一步减少了锁的竞争。容量动态调整机制根据任务负载动态调整线程数量。批量处理机制提高了任务处理效率。此外,还介绍了负载均衡、避免等待、预测优化、减少复制等策略。最后,任务组的设计便于管理和复用多任务。整体设计旨在提升线程池的性能和稳定性。
|
2月前
|
存储 监控 Java
|
2月前
|
前端开发 JavaScript 大数据
React与Web Workers:开启前端多线程时代的钥匙——深入探索计算密集型任务的优化策略与最佳实践
【8月更文挑战第31天】随着Web应用复杂性的提升,单线程JavaScript已难以胜任高计算量任务。Web Workers通过多线程编程解决了这一问题,使耗时任务独立运行而不阻塞主线程。结合React的组件化与虚拟DOM优势,可将大数据处理等任务交由Web Workers完成,确保UI流畅。最佳实践包括定义清晰接口、加强错误处理及合理评估任务特性。这一结合不仅提升了用户体验,更为前端开发带来多线程时代的全新可能。
41 0
|
2月前
|
Cloud Native Java 调度
项目环境测试问题之线程同步器会造成执行完任务的worker等待的情况如何解决
项目环境测试问题之线程同步器会造成执行完任务的worker等待的情况如何解决
|
3月前
|
Java Linux
Java演进问题之1:1线程模型对于I/O密集型任务如何解决
Java演进问题之1:1线程模型对于I/O密集型任务如何解决
|
2月前
|
Java 测试技术 PHP
父子任务使用不当线程池死锁怎么解决?
在Java多线程编程中,线程池有助于提升性能与资源利用效率,但若父子任务共用同一池,则可能诱发死锁。本文通过一个具体案例剖析此问题:在一个固定大小为2的线程池中,父任务直接调用`outerTask`,而`outerTask`再次使用同一线程池异步调用`innerTask`。理论上,任务应迅速完成,但实际上却超时未完成。经由`jstack`输出的线程调用栈分析发现,线程陷入等待状态,形成“死锁”。原因是子任务需待父任务完成,而父任务则需等待子任务执行完毕以释放线程,从而相互阻塞。此问题在测试环境中不易显现,常在生产环境下高并发时爆发,重启或扩容仅能暂时缓解。
|
3月前
|
设计模式 安全 Java
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
Java面试题:设计模式如单例模式、工厂模式、观察者模式等在多线程环境下线程安全问题,Java内存模型定义了线程如何与内存交互,包括原子性、可见性、有序性,并发框架提供了更高层次的并发任务处理能力
68 1
|
4月前
|
Java
java线程池执行任务(一次任务、固定间隔时间任务等)
java线程池执行任务(一次任务、固定间隔时间任务等)
219 1
|
4月前
|
存储 测试技术
【工作实践(多线程)】十个线程任务生成720w测试数据对系统进行性能测试
【工作实践(多线程)】十个线程任务生成720w测试数据对系统进行性能测试
50 0
【工作实践(多线程)】十个线程任务生成720w测试数据对系统进行性能测试