事件驱动程序设计

✍ dations ◷ 2025-12-09 21:11:34 #计算机编程,事件 (计算机)

事件驱动程序设计(英语:Event-driven programming)是一种电脑程序设计模型。这种模型的程序运行流程是由用户的动作(如鼠标的按键,键盘的按键动作)或者是由其他程序的消息来决定的。相对于批处理程序设计(batch programming)而言,程序运行的流程是由程序员来决定。批处理(batch)的程序设计在初级程序设计教学课程上是一种方式。然而,事件驱动程序设计这种设计模型是在交互程序(Interactive program)的情况下孕育而生的。

事件驱动程序可以由任何编程语言来实现,然而使用某些语言来撰写会比其他的语言来的简单。有些集成开发环境(简称IDE)也会影响实现事件驱动程序设计的难易程度。有的 IDE 会使的开发工作变的很简单,有的则否。

取代传统上一次等待一个完整的指令然后再做运行的方式,事件驱动程序模型下的系统,基本上的架构是预先设计一个事件循环所形成的程序,这个事件循环程序不断地检查目前要处理的信息,根据要处理的信息运行一个触发函数进行必要的处理。其中这个外部信息可能来自一个目录夹中的文件,可能来自键盘或鼠标的动作,或者是一个时间事件。

对一个事件驱动(event driven)系统进行程序设计,因此可以视为改写系统默认触发函数的行为,来符合自己需要的一种动作。输入的事件可以放进事件循环或者是经由已经注册的中断处理器来与硬件事件交互;而许多的软件系统使用了混和这两种技术的处理。预先设计好的算法确定了一件事,那就是当他们被需要的时候,就会在适当的时机被触发。也因此提供了一个模拟中断驱动环境(interrupt driven environment)的软件抽象架构。事件驱动程序设计基本上包含了许多小程序片段,这些小程序片段被称为事件处理器(英语:event handler)并且被用来回应外部的事件与分发事件。通常尚未被事件处理器处理的事件,都会被系统放在一个称为事件队列的数据结构中,等待被处理。

许多情况下,事件处理器可以自己触发事件,因此也可能形成一个事件串(英语:event cascade)。事件驱动程序设计的着重于弹性以及异步化上面,并且企图尽可能的modeless。 图形用户界面这类程序就是典型的事件驱动设计方式。

计算机操作系统是事件驱动程序的典型示例。在操作系统的最底层,中断处理器的动作就像是硬件事件的直接处理器,搭配着 CPU 运行分配事件规则动作。对软件进程而言,基本上操作系统可视为一个事件分配器,发送数据和软件中断给用户自己写的软件进程。

下面是两个数相加的示例,分别用批量版本与事件驱动版本来撰写


相关

  • 塞尔柱帝国大塞尔柱帝国(现代土耳其语:Büyük Selçuklu İmparatorluğu;波斯语:دولت سلجوقیان‎),又称塞尔柱帝国、塞尔柱土耳其帝国,是中世纪时期的突厥-波斯、逊尼派伊斯兰
  • 台湾省政府卫生处卫生福利部附属医疗及社会福利机构管理会(简称医管会或医福会)是中华民国卫生福利部为整合部立医院之效能而成立的任务编组单位。医疗机构社会福利机构卫生福利部双和医院卫生
  • 珍妮纺纱机珍妮纺纱机(Spinning Jenny),是英国布莱克本织工詹姆斯·哈格里夫斯在1764年左右发明的现代机械纺纱机,是工业革命的早期成果之一,被弗里德里希·恩格斯誉为“使英国工人的状况发
  • 前436年曾子
  • 2019年世界游泳锦标赛2019年世界游泳锦标赛是第18届世界游泳锦标赛,于2019年7月12日至28日在韩国光州广域市举行,该城市曾举办过2015年夏季世界大学生运动会。国际游泳联合会于2013年7月19日在西班
  • 妮娜·威廉斯妮娜‧威廉斯(Nina Williams,日文写作ニーナ・ウィリアムズ)是铁拳系列的主要核心人物之一,同时也是专属游戏“战栗杀机”的女主角。剧场版(铁拳:血之复仇)配音员是田中敦子。出身
  • 非洲各国人类发展指数列表人类发展指数是联合国开发计划署为衡量各国社会经济发展程度而制定的标准,该指数为根据国家人民出生时预期寿命、受教育年限、人均国民总收入计算出。各国家(大多为联合国会员
  • 赛车女郎赛车女郎,又常译为赛车女王、赛车皇后(英语:Race queen,在日本常被缩写为“RQ”)或赛车宝贝,是一个源自日本的职业,指在赛车活动(例如一级方程式赛车)中进行形象宣传活动的女性模特儿
  • 天山舰上攻击机天山舰上攻击机为日本海军为了取代九七式舰上攻击机下令中岛飞机公司开发的舰载鱼雷轰炸机,为第二次世界大战中期后日军主力舰载攻击机。主开发者为松村健一,于1943年(昭和18
  • 最优化二叉搜索树计算机科学中, 一个最佳二叉搜索树(Optimal BST),有时也被叫做重量平衡二叉树, 是有可能在已知的一串序列中得到最短搜索时间的一棵二叉搜索树(或期望的搜索时间)。 最优化二叉