反射 (计算机科学)

✍ dations ◷ 2025-11-23 14:58:50 #编程典范

在计算机学中,反射(英语: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的一个组成部分。

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

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

相关

  • 台风战斗机台风战斗机(英语:Eurofighter Typhoon,又常被称为EF-2000)是一款双发动机,采前翼加上三角翼(鸭式布局)设计的多用途战机。参与设计与生产的欧洲战机公司(Eurofighter GmbH)是由数家欧
  • 中亚运动会中亚运动会(英文:Central Asian Games),是中亚地区综合性运动会,两年一度,后改为四年一度。首届中亚运动会于1995年于乌兹别克斯坦的塔什干举行。Lua错误 在模块:Location_map/mul
  • 灌木灌木是没有明显主干的木本植物,植株一般比较矮小,不会超过6米。从近地面的地方就开始丛生出横生的枝干。都是多年生。一般为阔叶植物,也有一些针叶植物是灌木,如刺柏。如果越冬
  • 相空间表述相空间表述是量子力学的一种表述。在这一表述中,系统的状态是在相空间中描述的,位置与动量被放在同等重要的位置。在量子力学常用的薛定谔绘景中则只会采用动量表象或是位置表
  • amphiesma腹链蛇属(学名:Amphiesma)是蛇亚目游蛇科下的一个蛇属,其品种均为无毒蛇类,多分布在亚洲地区,包括中国、西伯利亚、韩国、印度次大陆、中南半岛、东南亚、日本及印尼。其拉丁学名
  • 横斑林鸮横斑林鸮(学名:Strix varia)是一种大型猫头鹰。横斑林鸮长44-46厘米,翼展101-115厘米。它们的面部淡色,眼睛周围有深色的环。喙呈黄色,眼睛褐色。它们是美国东部唯一拥有褐色的眼
  • 面具杰森魔杰森·沃尔希斯(Jason Voorhees)是由Victor Miller所创造出来的虚构连续杀人魔。杰森·沃尔希斯首次出现于1980年的恐怖片《13号星期五》,然而他不是这部影片中的杀手,而是他
  • 村上义雄村上 义雄(むらかみ よしお;1845年6月18日-1919年6月12日),旧姓平冢,日本九州熊本藩人(今熊本县),为日本明治至大正时代的内务省官员。村上义雄于1898年(明治31年)5月3日接替桥口文藏,于
  • 多赫南伊·埃尔诺多赫南伊·埃尔诺(匈牙利语:Dohnányi Ernő,德语:Ernst von Dohnányi,1877年6月27日-1960年2月9日),匈牙利作曲家,钢琴家,指挥家。其孙克里斯托夫·冯·多赫南伊是著名的当代指挥家
  • 朝鲜王室仪轨《朝鲜王室仪轨》是李氏朝鲜时代,王室主要行事,如婚、丧、喜、庆、册封、筑城等文字及图画记录的总汇。于2007年被列入联合国教科文组织的世界记忆项目。日本宫内厅所藏之古籍