反射 (计算机科学)

✍ dations ◷ 2025-04-02 13:16:59 #编程典范

在计算机学中,反射(英语:reflection)是指计算机程序在运行时(runtime)可以访问、检测和修改它本身状态或行为的一种能力。用比喻来说,反射就是程序在运行的时候能够“观察”并且修改自己的行为。

要注意术语“反射”和“内省”(type introspection)的关系。内省(或称“自省”)机制仅指程序在运行时对自身信息(称为元数据)的检测;反射机制不仅包括要能在运行时对程序自身信息进行检测,还要求程序能进一步根据这些信息改变程序状态或结构。

反射用于观察并修改程序在运行时的行为。一个面向反射的(reflection-oriented)程序组件可以监测一个范围内的代码执行情况,可以根据获取的目标对象信息及与此相关的范围修改自身。这可通过在运行时动态分配程序代码实现。

在类型检测严格的面向对象的编程语言如Java中,一般需要在编译期间对程序中需要调用的对象的具体类型、接口、字段和方法的合法性进行检查。反射技术则允许将对需要调用的对象的信息检查工作从编译期间推迟到运行期间再现场执行。这样一来,可以在编译期间先不明确目标对象的接口名称、字段(fields,即对象的成员变量)、可用方法,然后在运行根据目标对象自身的信息决定如何处理。它还允许根据判断结果进行实例化新对象和相关方法的调用。

反射主要用途就是使给定的程序动态地适应不同的运行情况。利用面向对象建模中的多态性也可以简化编写分别适用于多种不同情形的功能代码,但是反射可以解决多态性并不适用的更普遍情形,从而更大程度地避免硬编码(即把代码的细节“写死”,缺乏灵活性)的代码风格。

反射也是元编程的一个关键策略。

考虑一个面向对象风格的应用程序,它可以分别使用功能类X、功能类Y、功能类Z来执行相似的操作。如果事先创建并传递给它的工具是类A的实例,它就调用类A实例具有的方法完成功能;如果事先创建的是类B的实例,它就调用类B实例具有的方法完成功能,如果事先创建的是类C的实例,它就调用类C实例完成功能。如果它们完成相似功能的方法名称都相同,或方法都继承自同一个父类并实现了多态性,那么只需调用名称唯一的目标方法即可,问题已经解决;如果这些条件并不满足,我们碰到的问题变成要根据情况从不同对象中调用名称上存在区别、功能却相似的方法,此时只能分别判断3种不同情况然后挨个进行硬编码,或者考虑使用更优雅的反射技巧。分别判断并硬编码的做法是:在主程序中对不同的功能类进行差异化对待,在运行主程序的时候判断当前可用的工具是不是类A的实例,如果是就以明确“指名道姓”的方式调用它的特定方法,如果不是就继续判断可用的工具是不是类B的实例,如果是就调用B的特定方法,如果也不是就将其视为类C的实例并调用对应的方法。如果可能的类型更多的话,就需要写更多的条件分支语句。然而,如果使用反射式的编程技术,应用程序可以在只写出主要流程、但不写死具体方法名称的情况下,在运行时期灵活地获取可用的目标对象信息,根据目标方法的大致特征自动识别和调用需要的方法,并自动调用目标对象的对应方法解决问题。

早期计算机的原生汇编语言本质上就具有反射特性。因为它是由定义编程指令作为数据,如动态修改指令或对它们进行分析等等的反射功能是很平常的。编程发展到如C语言等高抽象层次的语言时,这种实践消失了,带有反射特性的高级编程语言要到更晚的时候才出现。

1982年,布莱恩·史密斯(Brian Cantwell Smith)在其博士论文《编程语言中的步骤式反射》("Procedural Reflection in Programming Languages")中介绍了“编程语言的计算反射”概念,并且引入meta-circular解释器的概念用作3-Lisp的一个组成部分。

支持反射的语言提供了一些在早期高级语言中难以实现的运行时特性。

通过深入学习反射的特性和技巧,它的劣势可以尽量避免,但这需要许多时间和经验的积累。

相关

  • 克里米亚-刚果出血热克里米雅–刚果出血热(Crimean–Congo hemorrhagic fever,简称CCHF)是一种病毒导致的传染性疾病。症状包括发热、肌肉痛、头痛、呕吐、腹泻和皮肤瘀点,通常于暴露病原后2周内发
  • 塔斯曼尼亚坐标:42°10′46.88″S 146°38′43.83″E / 42.1796889°S 146.6455083°E / -42.1796889; 146.6455083塔斯马尼亚州(英语:Tasmania,缩写为TAS),简称塔州,是澳大利亚唯一的岛州,原
  • 1-二十烷醇Arachidic alcohol Nonadecylcarbinol1-二十烷醇又名花生醇(Arachidyl alcohol),是一种白色蜡状固体,在化妆品中用作润肤剂。
  • VO(NOsub3/sub)sub3/sub三硝酸氧钒(化学式:VO(NO3)3),是+5价钒的硝酸盐。它可由五氧化二氮和五氧化二钒反应得到。它是硝化试剂,可以和苯、苯酚、氯苯、苯甲醚、乙酰苯胺、苯甲酸、苯甲酸乙酯、甲苯等芳
  • 音为爱《音为爱》(泰语:ซักซี้ด ห่วยขั้นเทพ;英语:SuckSeed),是泰国一部有关爱情与友情的电影,剧中主角成立suckseed乐团的目的仅是为了追求女孩。专辑:OST -SuckSeed
  • 阿波罗7号阿波罗7号(Apollo 7)是阿波罗计划中第一次载人飞行任务。整个任务时间达11天,环绕地球轨道。本次任务是土星1B号运载火箭的首次载人发射,也是美国的第一次三人太空任务。本团队
  • 筑卫城遗址坐标:28°02′10″N 115°36′24″E / 28.03611°N 115.60667°E / 28.03611; 115.60667筑卫城遗址位于中国江西省樟树市大桥街道大姑山北坡土岗上,2001年被列为第五批全国重
  • 纸箱战机角色列表纸箱战机角色列表是介绍《纸箱战机》、《纸箱战机W》及《纸箱战机WARS》的登场人物。八神英二所率领的“黑色部队”的成员,皆戴着隐藏着脸孔的面具,后来跟随八神英二转而投效
  • 阿德里安·卡顿·德·维阿特阿德里安·保罗·吉斯莱恩·卡顿·德·维阿特 VC, KBE, CB, CMG, DSO(英语:Sir Adrian Paul Ghislain Carton de Wiart;1880年5月5日-1963年6月5日),英国陆军中将,参加过第二次布尔战争
  • 小泉正保小泉正保(日语:こいずみ まさやす,1855年4月29日-1917年10月23日)为日本陆军军人。最终阶级陆军中将。水户藩士・小泉正诚的长男。担任过警视厅巡查,1875年(明治8年)12月、陆军士官