已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
现代操作系统内核的主要工作,就是虚拟许多个同时运行的【线程】,在线程之间通过高速切换实现多任务并行。例如,操作系统允许程序A所在的线程运行1毫秒,然后将这个线程的所有“状态”(所有寄存器的值)缓存起来,再将程序B所在线程的“状态”恢复到操作系统寄存器中,继续运行程序B。这样对于每一个独立的程序来说,其“状态”是稳定的,如同直接运行在独立的CPU上一样。于是我们可以用“同步”的方式编写程序,让操作系统帮我们解决“异步”的问题。


为什么叫“异步”呢?因为从操作系统的角度来看,没有一个用户程序是在CPU上按照指令一路执行到底的,而是根据外部事件(比如上一个例子中的1毫秒定时器)动态切换的。两个程序同时运行,也没有办法确定地指出哪个会先执行完。


其实这是大部分自然过程的本质;自然界里没有什么事情会完美地按照某个确定的顺序发生——同时在过程中不受环境影响——
最后只产生一个确定的结果。所有的事情都以异步的方式进行着,毕竟大自然里不存在像图灵机这样的理想机器。


在操作系统中,每个【线程】的存在都会占用一定的资源。例如某个网络通信程序,它的任务是组织10000个用户聊天,需要创建10000个TCP连接。代码很简单:先接收用户输入,然后根据一定规则转发给其他用户。但如果将这段代码编译成程序,在操作系统中创建10000个线程分别处理用户输入,会占用GB级别的内存空间,而操作系统在10000个线程间来回切换也是一件很痛苦的事情。怎么办呢?


最常见的做法是,放弃操作系统线程带来的便利(同步编程),在应用程序内部实现一个异步的架构:由一个线程监听所有用户发来的聊天数据(用户之间通过数据包头区分),每当数据包到达时根据其中的用户信息,根据一定规则转发给其他用户。如果同时有两个用户发来数据包,则数据包会在网卡的缓冲区内排队等待线程按顺序读取。这种程序设计方法,称为异步编程。通常,在应用程序内部实现异步,比借用操作系统线程,性能上要高得多(没有资源上的额外开销)。因此,许多要求软实时性、大规模并发、高可靠的计算机系统,其软件都采用异步/事件驱动/虚拟机架构。


C语言的众多函数库多是为同步编程设计的。在异步编程技术突飞猛进的今天,我们拥有了越来越多的选择;其中Node.js在短短6年里就成为了高性能网络服务器最重要的开发语言。它拥有接近于C语言的性能,以及闭包特性,最重要的是将异步编程的基础——事件队列——变成了基础设施,而不是仅仅提供一个函数库。


然而异步编程最大的问题在于,没有办法用同步的方式——也是大部分编程爱好者最喜爱的方式——撰写含有异步调用的程序。这成为了许多编程爱好者进步的瓶颈,闻异步而色变。


贴出科创网络发展局 新KC论坛项目的一部分代码。XXXXXXXXXXXXXXXXXX/ctmakro/nkc2


QQ图片20160304213027.png
文号 / 811216

万流景仰
名片发私信
学术分 16
总主题 1270 帖总回复 8407 楼拥有证书:学者 机友 笔友
注册于 2008-03-29 15:34最后登录 2022-01-09 14:09
主体类型:个人
所属领域:无
认证方式:手机号
IP归属地:未同步

个人简介

已走,勿送

文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

插入资源
全部
图片
视频
音频
附件
全部
未使用
已使用
正在上传
空空如也~
上传中..{{f.progress}}%
处理中..
上传失败,点击重试
等待中...
{{f.name}}
空空如也~
(视频){{r.oname}}
{{selectedResourcesId.indexOf(r.rid) + 1}}
处理中..
处理失败
插入表情
我的表情
共享表情
Emoji
上传
注意事项
最大尺寸100px,超过会被压缩。为保证效果,建议上传前自行处理。
建议上传自己DIY的表情,严禁上传侵权内容。
点击重试等待上传{{s.progress}}%处理中...已上传,正在处理中
空空如也~
处理中...
处理失败
加载中...
草稿箱
加载中...
此处只插入正文,如果要使用草稿中的其余内容,请点击继续创作。
{{fromNow(d.toc)}}
{{getDraftInfo(d)}}
标题:{{d.t}}
内容:{{d.c}}
继续创作
删除插入插入
插入公式
评论控制
加载中...
文号:{{pid}}
加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}
ID: {{user.uid}}