Why is reflection called reflection instead of introspection?

Language AgnosticReflection

Language Agnostic Problem Overview


What is the origin of the term reflection? It seems more like introspection. Why isn't it called that?

Introspection: A looking inward; specifically, the act or process of self-examination.

Reflection:

  1. the act of reflecting or the state of being reflected.
  2. an image; representation; counterpart
  3. a fixing of the thoughts on something; careful consideration
  4. a thought occurring in consideration or meditation.

Language Agnostic Solutions


Solution 1 - Language Agnostic

There is an interesting answer on the french wikipedia article for Reflection (here)

Reflection can be decomposed in two parts:

  • introspection: a program can examine itself.
  • intercession: a program can modify its state/meaning.

So reflection is a 'stronger' property than introspection. That's why you say type introspection for the ability to know types at runtime (and changing them is another action: conversion/casting).

EDIT: actually I just realized the first answer was saying exactly that ^^. Time to unplug myself...

Solution 2 - Language Agnostic

Reflection comes from the idea of "self-examination, self-modification, and self-replication", reflecting on one's self for the purpose of change. In programming you use reflection to examine the structure of the program itself in the context of using it instead of just examining it. What you get back is a representation of the program that you can use to modify it, rather than the data on which it operates.

More information can be found at the wikipedia article..

Solution 3 - Language Agnostic

The term reflection comes from Brian Cantwell Smith's 1982 PHD dissertation which can be found at http://publications.csail.mit.edu/lcs/pubs/pdf/MIT-LCS-TR-272.pdf

What has come to be called reflection is often merely introspection, i.e., access to metadata. Smith's requirements for reflection included a causal connection from metadata back, and this is usually the missing component. One way to imagine reflection is access to implementation, and not merely the implementation of some new instance of a computation, but a computation's access to it's own implementation. Certainly Java's original reflection api was misnamed as it was not reflective in this sense.

Solution 4 - Language Agnostic

There is another concept called type introspection that refers to the ability to determine the type of an object at runtime.

edit: I realize your question was intended to be language-agnostic, but in Java, reflection is used to identify what members an object has, whereas introspection allows you to identify which JavaBeans properties an object has, which is why the introspection class is in the java.beans package. I'm not sure what the exact difference between the terms would be in other languages, though,

Solution 5 - Language Agnostic

In .Net I think the term Reflection is very appropriate because it is not the type itself that is examined, it is the manifest of the code, which is only a description.

Solution 6 - Language Agnostic

Reflection, in the sense of definitions 3 and 4, can be introspective. That is, introspection is reflection on one's self. I think that introspection is the better word to use for the act of code analyzing itself because the word is more specific, but I don't think reflection is entirely inappropriate.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestiontvanfossonView Question on Stackoverflow
Solution 1 - Language AgnosticPiotr LesnickiView Answer on Stackoverflow
Solution 2 - Language AgnostictvanfossonView Answer on Stackoverflow
Solution 3 - Language AgnosticEd PuckettView Answer on Stackoverflow
Solution 4 - Language AgnosticdancavallaroView Answer on Stackoverflow
Solution 5 - Language AgnosticGugeView Answer on Stackoverflow
Solution 6 - Language AgnosticGreg GrahamView Answer on Stackoverflow