反射 (计算机科学)

✍ dations ◷ 2025-11-10 22:06:29 #编程典范

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

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

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

相关

  • 世界卫生组织基本药物清单世界卫生组织基本药物标准清单(法语:Listes modèles OMS des médicaments essentiels;英语:WHO Model List of Essential Medicines;简称EML)是世界卫生组织(WHO或称世卫组织)的出
  • 锌镉合金锌镉合金,是由锌与镉融合在一起的合金材料。锌镉合金为银白色,与镁的颜色一样,故俗称为镁锌合金,但其实并没有镁的成分在里面。
  • 5f11 7s22, 8, 18, 32, 29, 8, 2主条目:锿的同位素锿(英语:Einsteinium,台湾称鑀,旧译作䥺)是一种人工合成元素,符号为Es,原子序为99。锿是第7个超铀元素,属于锕系元素。锿是在1952年
  • [Mg(NHsub3/sub)sub6/sub](NOsub3/sub)sub2硝酸六氨合镁是硝酸镁的氨配合物,化学式为(NO3)2。硝酸六氨合镁受热分解,在300~391K失去两个氨分子:在392~496K继续分解,再失去两个氨分子:在496~607K,三种反应同时发生:在608~850K
  • 应用编程接口与因特网相连的端系统提供了一个应用程序接口(英语:Application Programming Interface,缩写:API;又称为应用程序编程接口)是软件系统不同组成部分衔接的约定。API规定了运行在一
  • 瓦斯科·达伽马瓦斯科·达伽马(葡萄牙语:Vasco da Gama,1460年-1524年12月24日)是葡萄牙探险家,初代维迪格拉伯爵,中文译名多简称“达伽马”或“达迦马”,他是历史上第一位从欧洲航海到印度的人(149
  • 丘布特省丘布特省(Chubut)为南美国家阿根廷二十三省之一,位于阿根廷中部(如右图之5位置),该省首府为罗森。1自治市坐标:43°18′S 65°06′W / 43.300°S 65.100°W / -43.300; -65.100
  • 苏腊马都大桥苏腊马都大桥(印尼语:Jembatan Suramadu),又称马都拉海峡大桥、泗水-马都拉海峡大桥,是印度尼西亚政府于马都拉海峡上的一座斜拉桥,为印度尼西亚第一长桥,连通爪哇岛上的巨港苏腊巴
  • 榴弹炮榴弹炮,是一种火炮。这种火炮身管/口径比较大,弹道较弯曲、初速较高、能采用多级变号装药获得不同弹道曲线,并不适合直接射击水平目标。主要用于炮兵部队歼灭、压制在对方较大纵
  • GitLabGitLab 是由 GitLab Inc.开发,一款基于 Git 的完全集成的软件开发平台(fully integrated software development platform)。 另外,GitLab 且具有wiki以及在线编辑、issue跟踪功