随着拥有多个硬线程CPU(超线程、双核)的普及,多线程和异步操作等并发程序设计方法也受到了更多的关注和讨论。本文主要是想探讨一下如何使用并发来最大化程序的性能。

多线程和异步操作的异同

多线程和异步操作两者都可以达到避免调用线程阻塞的目的,从而提高软件的可响应性。甚至有些时候我们就认为多线程和异步操作是等同的概念。但是,多线程和异步操作还是有一些区别的。而这些区别造成了使用多线程和异步操作的时机的区别。多线程是实现异步的一个重要手段,但不是唯一手段,对以一个单线程程序也可以是异步执行的。

异步操作的本质

所有的程序最终都会由计算机硬件来执行,所以为了更好的理解异步操作的本质,我们有必要了解一下它的硬件基础。 熟悉电脑硬件的朋友肯定对DMA这个词不陌生,硬盘、光驱的技术规格中都有明确DMA的模式指标,其实网卡、声卡、显卡也是有DMA功能的。DMA就是直 接内存访问的意思,也就是说,拥有DMA功能的硬件在和内存进行数据交换的时候可以不消耗CPU资源。只要CPU在发起数据传输时发送一个指令,硬件就开 始自己和内存交换数据,在传输完成之后硬件会触发一个中断来通知操作完成。这些无须消耗CPU时间的I/O操作正是异步操作的硬件基础。所以即使在DOS 这样的单进程(而且无线程概念)系统中也同样可以发起异步的DMA操作。异步编程的目的就是为了能够是实现并行,但不仅是提高多处理器间的并行度,同时也是提高处理器与I/O处理器的并行度。非阻塞模式一般特指异步的I/O 操作,可以算是异步编程的一种类型。

线程的本质

线程不是一个计算机硬件的功能,而是操作系统提供的一种逻辑功能,线程本质上是进程中一段并发运行的代码,所以线程需要操作系统投入CPU资源来运行和调度。

异步操作的优缺点

因为异步操作无须额外的线程负担,并且使用回调的方式进行处理,在设计良好的情况下,处理函数可以不必使用共享变量(即使无法完全不用,最起码可以减少 共享变量的数量),减少了死锁的可能。当然异步操作也并非完美无暇。编写异步操作的复杂程度较高,程序主要使用回调方式进行处理,与普通人的思维方式有些初入,而且难以调试。

多线程的优缺点

多线程的优点很明显,线程中的处理程序依然是顺序执行,符合普通人的思维习惯,所以编程简单。但是多线程的缺点也同样明显,线程的使用(滥用)会给系统带来上下文切换的额外负担。并且线程间的共享变量可能造成死锁的出现。

适用范围

在了解了线程与异步操作各自的优缺点之后,我们可以来探讨一下线程和异步的合理用途。我认为:当需要执行I/O操作时,使用异步操作比使用线程+同步 I/O操作更合适。I/O操作不仅包括了直接的文件、网络的读写,还包括数据库操作、Web Service、HttpRequest以及.net Remoting等跨进程的调用。而线程的适用范围则是那种需要长时间CPU运算的场合,例如耗时较长的图形处理和算法执行。但是往 往由于使用线程编程的简单和符合习惯,所以很多朋友往往会使用线程来执行耗时较长的I/O操作。这样在只有少数几个并发操作的时候还无伤大雅,如果需要处 理大量的并发操作时就不合适了。

对于CPU来说以下意味着什么

线程:意味了CPU的一组寄存器

进程:意味着CPU的页目录寄存器

IO:意味着一些端口或内存地址空间中一些地址

转载于:https://www.cnblogs.com/Thriving-Country/archive/2010/12/24/1916137.html

【知识分享】异步调用与多线程的区别相关推荐

  1. 一起谈.NET技术,异步调用与多线程的区别

    随着拥有多个硬线程CPU(超线程.双核)的普及,多线程和异步操作等并发程序设计方法也受到了更多的关注和讨论.本文主要是想探讨一下如何使用并发来最大化程序的性能. 多线程和异步操作的异同 多线程和异步操 ...

  2. 【转载】异步调用与多线程的区别

    [原文链接] [最简洁阅读版式链接] 随着拥有多个硬线程CPU(超线程.双核)的普及,多线程和异步操作等并发程序设计方法也受到了更多的关注和讨论.本文主要是想探讨一下如何使用并发来最大化程序的性能. ...

  3. java 多异步调用_java 异步调用与多线程

    异步与多线程的区别 一.异步和多线程有什么区别?其实,异步是目的,而多 线程是实现这个目的的方法.异步是说,A发起一个操作后(一般都是比较耗时的操作,如果不耗时的操作 就没有必要异步了),可以继续自顾 ...

  4. 同步调用和异步调用两者之间的区别

    前言   提到同步调用和异步调用两者的区别,首先笔者是从微服务间通讯方式角度出发来阐述这两者的区别. 同步通讯 调用方需要等待执行方的调用结果.(就像打电话一样,需要实时响应) 典型就是:Dubbo的 ...

  5. 异步编程之异步编程与多线程编程的联系和区别

    1.异步编程与多线程的区别 共同点:异步和多线程两者都可以达到避免调用线程阻塞的目的,从而提高软件的可响应性 不同点: (1)线程不是一个计算机硬件的功能,而是操作系统提供的一种逻辑功能,线程本质上是 ...

  6. 异步编程与多线程编程的联系和区别

    1.异步编程与多线程的区别 共同点:异步和多线程两者都可以达到避免调用线程阻塞的目的,从而提高软件的可响应性 不同点: (1)线程不是一个计算机硬件的功能,而是操作系统提供的一种逻辑功能,线程本质上是 ...

  7. springboot 多线程_SpringBoot异步调用@Async

    一. 什么是异步调用? 异步调用是相对于同步调用而言的,同步调用是指程序按预定顺序一步步执行,每一步必须等到上一步执行完后才能执行,异步调用则无需等待上一步程序执行完即可执行. 二. 如何实现异步调用 ...

  8. SpringBoot利用@Async注解实现异步调用

    前言:异步编程是让程序并发运行的一种手段,使用异步编程可以大大提高我们程序的吞吐量,减少用户的等待时间.在Java并发编程中实现异步功能,一般是需要使用线程或者线程池.而实现一个线程,要么继承Thre ...

  9. C++多线程:package_task异步调用任何目标执行操作

    文章目录 描述 函数成员及使用 总结 我们上一篇描述关于C++多线程中的异步操作相关库( async和 promise),本节将分享c++标准库中最后一个多线程异步操作库 package_task的学 ...

最新文章

  1. php的exportexcel,PHPExcel export网络或本地图片到excel
  2. pythonanywhere.com的用法
  3. Too Many Segments (hard version) CodeForces - 1249D2(贪心+容器vector+set)
  4. 富文本处理NSMutableAttributedString
  5. ENVI入门系列教程---二、图像分析---13. 遥感动态监测
  6. 德阳计算机办公培训,德阳2017计算机办公软件培训
  7. virtualbox安装增强功能失败解决办法与原因
  8. ESP8266-Arduino编程实例-MLX90614红外测温传感器驱动
  9. linux纯文本无法键入密码,Apple Mac OS X FileVault纯文本密码本地安全限制绕过漏洞...
  10. Apple ID到期续费问题及验证手机(开启双重认证)
  11. Get https://registry-1.docker.io/v2/library/tomcat/manifests/latest:timeout
  12. chrome中了flash过期的解决方法
  13. 数字图像处理【杜克大学】(冈萨雷斯第三版) Guillermo Sapiro
  14. Linux系统中rpm命令安装软件,报错:This program may be freely redistributed under the terms of the GNU GPL
  15. Inno Setup入门(十六)——Inno Setup类参考(2)
  16. 编辑引导扇区修复分区引导解决磁盘分区打不开
  17. 君子求诸己,小人求诸人
  18. win10电脑人脸识别库安装及使用
  19. 从零开始快速配置个人博客
  20. 一个女孩如何准备行装和安全的独自旅行

热门文章

  1. 电脑软件:微软Windows官方电脑管家,仅针对国内用户?看看怎么说
  2. 100+ 值得收藏的 Web 开发资源
  3. 11个常用的SQL技巧
  4. 87岁老奶奶用微软自带画图软件绘画 惊艳了世人
  5. html怎么做模糊条纹,如何使用纯CSS实现彩虹条纹文字的效果
  6. 最后一天,特邀小姐姐配音拉票,今日可投28票
  7. EL表达式和JSTL标准标签库
  8. 【2.0】SpringBoot连接MySql 8.0的url设置
  9. linux go环境安装和基本项目结构
  10. 初学Vue.js,从头来过~