反射 (计算机科学)

✍ dations ◷ 2025-07-11 15:58:25 #编程典范

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

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

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

相关

  • 乳房摄影术乳房摄影术(英语:Mammography)是利用低剂量(约为 0.7毫西弗)的X光检查人类(主要是女性)的乳房,它能侦测各种乳房肿瘤、囊肿等病灶,有助于早期发现乳癌,并降低其死亡率。除了影像检查之
  • 被覆金属电弧焊接手工电弧焊是一种非常常见而基本的焊接技术。它利用电弧放电产生热量的原理,将焊条和被焊接的工件(母材)分别接上电源的两极,当两者之间引燃电弧并保持电弧稳定燃烧时金属便会因
  • 1883年
  • 北京大学校长北京大学(简称北大)是中国著名高等学府。北京大学创建于1898年,其历任校长别表如下:
  • 2048 (消歧义)2048可以指:
  • 伊利亚斯·阿巴迪伊利亚斯·阿巴迪(1992年10月21日-)是一名阿尔及利亚拳击运动员,曾代表国家参加2012年伦敦奥运的男子次中量级拳击比赛,但未能获奖。
  • 龙虎少年队 (电影)《龙虎少年队》(英语:)是2012年美国的一部动作喜剧电影,由乔纳·希尔和查宁·塔图姆主演。续集《龙虎少年队2》于2014年6月上映。改编自早期的同名美国喜剧剧集“龙虎少年队”(19
  • 高山俊高山俊(日语:髙山 俊/たかやま しゅん ,1993年4月18日-)是一名出生于日本千叶县船桥市的棒球选手,司职外野手,目前效力于日本职棒阪神虎。71 久慈照嘉 | 73 金村晓 | 74 藤本敦士 |
  • 奥斯曼加齐大桥奥斯曼加齐大桥(土耳其语:Osman Gazi Köprüsü)是一座横越伊兹密特湾的悬索桥,桥梁将湾岸北部的城市盖布泽与南部的亚洛瓦省连接起来,为O-5公路(英语:Otoyol 5)建设的一环,2016年7
  • 奥维尔 (俄亥俄州)奥维尔(英语:Orrville)是一个美国城市,位于俄亥俄州韦恩县。根据2010年的人口普查,当地人口为8,380人。奥维尔位于 40°50′N 81°46′W / 40.833°N 81.767°W / 40.833; -81.76