Metaclass

In object-oriented programming, a metaclass is a class whose instances are classes themselves. Unlike ordinary classes, which define the behaviors of objects, metaclasses specify the behaviors of classes and their instances. Not all object-oriented programming languages support the concept of metaclasses. For those that do, the extent of control metaclasses have over class behaviors varies. Metaclasses are often implemented by treating classes as first-class citizens, making a metaclass an object that creates and manages these classes. Each programming language adheres to its own metaobject protocol, which are the rules that determine interactions among objects, classes, and metaclasses.[1] Metaclasses are utilized to automate code generation and to enhance framework development.[2]

Python example

In Python, the builtin class type is a metaclass.[3][4][5] Consider this simple Python class:

class Car:
    def __init__(self, make: str, model: str, year: int, color: str):
        self.make = make
        self.model = model
        self.year = year
        self.color = color

    @property
    def description(self) -> str:
        """Return a description of this car."""
        return f"{self.color} {self.make} {self.model}"

At run time, Car itself is an instance of type. The source code of the Car class, shown above, does not include such details as the size in bytes of Car objects, their binary layout in memory, how they are allocated, that the __init__ method is automatically called each time a Car is created, and so on. These details come into play not only when a new Car object is created, but also each time any attribute of a Car is accessed. In languages without metaclasses, these details are defined by the language specification and can't be overridden. In Python, the metaclass - type - controls these details of Car's behavior. They can be overridden by using a different metaclass instead of type.

The above example contains some redundant code to do with the four attributes make, model, year, and color. It is possible to eliminate some of this redundancy using a custom metaclass. In Python, a metaclass is most easily defined as a subclass of type.

class AttributeInitType(type):
    def __call__(self, *args, **kwargs):
        """Create a new instance."""

        # First, create the object in the normal default way.
        obj = type.__call__(self, *args)

        # Additionally, set attributes on the new object.
        for name, value in kwargs.items():
            setattr(obj, name, value)

        # Return the new object.
        return obj

This metaclass only overrides object creation. All other aspects of class and object behavior are still handled by type.

Now the class Car can be rewritten to use this metaclass. In Python 3 this is done by providing a "keyword argument" metaclass to the class definition:

class Car(object, metaclass=AttributeInitType):
    @property
    def description(self) -> str:
        """Return a description of this car."""
        return " ".join(str(value) for value in self.__dict__.values())

The resulting object Car can be instantiated as usual, but can contain any number of keyword arguments:

new_car = Car(make='Toyota', model='Prius', year=2005, color='Green', engine='Hybrid')

In Smalltalk-80

The Smalltalk-80 metaclass hierarchy as a UML diagram
Diagram of the inheritance and instance relationships between classes and metaclasses in Smalltalk

In Smalltalk, everything is an object. Additionally, Smalltalk is a class based system, which means that every object has a class that defines the structure of that object (i.e. the instance variables the object has) and the messages an object understands. Together this implies that a class in Smalltalk is an object and that, therefore a class needs to be an instance of a class (called metaclass).

As an example, a car object c is an instance of the class Car. In turn, the class Car is again an object and as such an instance of the metaclass of Car called Car class. Note the blank in the name of the metaclass. The name of the metaclass is the Smalltalk expression that, when evaluated, results in the metaclass object. Thus evaluating Car class results in the metaclass object for Car whose name is Car class (one can confirm this by evaluating Car class name which returns the name of the metaclass of Car.)

Class methods actually belong to the metaclass, just as instance methods actually belong to the class. When a message is sent to the object 2, the search for the method starts in Integer. If it is not found it proceeds up the superclass chain, stopping at Object whether it is found or not.

When a message is sent to Integer the search for the method starts in Integer class and proceeds up the superclass chain to Object class. Note that, so far, the metaclass inheritance chain exactly follows that of the class inheritance chain. But the metaclass chain extends further because Object class is the subclass of Class. All metaclasses are subclasses of Class.

In early Smalltalks, there was only one metaclass called Class. This implied that the methods all classes have were the same, in particular the method to create new objects, i.e., new. To allow classes to have their own methods and their own instance variables (called class instance variables and should not be confused with class variables), Smalltalk-80 introduced for each class C their own metaclass C class. This means that each metaclass is effectively a singleton class.

Since there is no requirement that metaclasses behave differently from each other, all metaclasses are instances of only one class called Metaclass. The metaclass of Metaclass is called Metaclass class which again is an instance of class Metaclass.

In Smalltalk-80, every class (except Object) has a superclass. The abstract superclass of all metaclasses is Class, which describes the general nature of classes.

The superclass hierarchy for metaclasses parallels that for classes, except for class Object. ALL metaclasses are subclasses of Class, therefore:

  • Object class superclass == Class.

Like conjoined twins, classes and metaclasses are born together. Metaclass has an instance variable thisClass, which points to its conjoined class. Note that the usual Smalltalk class browser does not show metaclasses as separate classes. Instead the class browser allows to edit the class together with its metaclass at the same time.

The names of classes in the metaclass hierarchy are easily confused with the concepts of the same name. For instance:

  • Object is the base class that provides common methods for all objects; "an object" is an integer, or a widget, or a Car, etc.
  • Class is the base of the metaclasses that provides common methods for all classes (though it is not a metaclass itself); "a class" is something like Integer, or Widget, or Car, etc.
  • Metaclass provides common methods for all metaclasses.

Four classes provide the facilities to describe new classes. Their inheritance hierarchy (from Object), and the main facilities they provide are:

Object - default behavior common to all objects, like class access
Behavior - minimum state for compiling methods and creating/running objects
ClassDescription (abstract class) - class/variable naming, comments
Class - similar, more comprehensive, facilities to superclasses
Metaclass - initializing class variables, instance creation messages

In Ruby

Ruby purifies the Smalltalk-80 concept of metaclasses by introducing eigenclasses, removing the Metaclass class, and (un)redefining the class-of map. The change can be schematized as follows:[6]

Smalltalk-80
Classes
Implicit
metaclasses
  
Terminal
objects
Ruby
Classes
Eigenclasses of
classes
Eigenclasses
of
eigenclasses
Terminal
objects
Eigenclasses of
terminal objects

Note in particular the correspondence between Smalltalk's implicit metaclasses and Ruby's eigenclasses of classes. The Ruby eigenclass model makes the concept of implicit metaclasses fully uniform: every object x has its own meta-object, called the eigenclass of x, which is one meta-level higher than x. The "higher order" eigenclasses usually exist purely conceptually – they do not contain any methods or store any (other) data in most Ruby programs.[7]

The following diagrams show a sample core structure of Smalltalk-80 and Ruby in comparison.[8] In both languages, the structure consists of a built-in part which contains the circular objects (i.e. objects that appear in a cycle formed by a combination of blue or green links) and a user-part which has four explicit objects: classes A and B and terminal objects u and v. Green links show the child→parent relation of inheritance (with the implicit upward direction), blue links show the complementary member→container relation of instantiation (a blue link from x points to the least actual container of x that is the start point for the method lookup when a method is invoked on x). Gray nodes display the eigenclasses (resp. implicit metaclasses in the case of Smalltalk-80).

Smalltalk-80   Ruby
Implicit metaclasses in Smalltalk-80 - A sample structure Eigenclasses in Ruby - A sample structure

The diagram on the right also provides a picture of lazy evaluation of eigenclasses in Ruby. The v object can have its eigenclass evaluated (allocated) as a consequence of adding singleton methods to v.

According to the Ruby's introspection method named class, the class of every class (and of every eigenclass) is constantly the Class class (denoted by c in the diagram). Class, and Struct are the only classes that have classes as instances.[9] [disputeddiscuss] Subclassing of Class is disallowed. Following the standard definition of metaclasses we can conclude that Class and Struct are the only metaclasses in Ruby. This seems to contradict the correspondence between Ruby and Smalltalk, since in Smalltalk-80, every class has its own metaclass. The discrepancy is based on the disagreement between the class introspection method in Ruby and Smalltalk. While the map x ↦ x.class coincides on terminal objects, it differs in the restriction to classes. As already mentioned above, for a class x, the Ruby expression x.class evaluates constantly to Class. In Smalltalk-80, if x is a class then the expression x class corresponds to the Ruby's x.singleton_class – which evaluates to the eigenclass of x.

In Objective-C

Diagram of the inheritance and instance relationships between classes and metaclasses in Objective-C. Note that Objective-C has multiple root classes; each root class would have a separate hierarchy. This diagram only shows the hierarchy for an example root class NSObject. Each other root class would have a similar hierarchy.

Metaclasses in Objective-C are almost the same as those in Smalltalk-80—not surprising since Objective-C borrows a lot from Smalltalk. Like Smalltalk, in Objective-C, the instance variables and methods are defined by an object's class. A class is an object, hence it is an instance of a metaclass.

Like Smalltalk, in Objective-C, class methods are simply methods called on the class object, hence a class's class methods must be defined as instance methods in its metaclass. Because different classes can have different sets of class methods, each class must have its own separate metaclass. Classes and metaclasses are always created as a pair: the runtime has functions objc_allocateClassPair() and objc_registerClassPair() to create and register class-metaclass pairs, respectively.

There are no names for the metaclasses; however, a pointer to any class object can be referred to with the generic type Class (similar to the type id being used for a pointer to any object).

Because class methods are inherited through inheritance, like Smalltalk, metaclasses must follow an inheritance scheme paralleling that of classes (e.g. if class A's parent class is class B, then A's metaclass's parent class is B's metaclass), except that of the root class.

Unlike Smalltalk, the metaclass of the root class inherits from the root class (usually NSObject using the Cocoa framework) itself. This ensures that all class objects are ultimately instances of the root class, so that you can use the instance methods of the root class, usually useful utility methods for objects, on class objects themselves.

Since metaclass objects do not behave differently (you cannot add class methods for a metaclass, so metaclass objects all have the same methods), they are all instances of the same class—the metaclass of the root class (unlike Smalltalk). Thus, the metaclass of the root class is an instance of itself. The reason for this is that all metaclasses inherit from root class; hence, they must inherit the class methods of the root class.[10]

Support in languages and tools

The following are some of the most prominent programming languages that support metaclasses.

Some less widespread languages that support metaclasses include OpenJava, OpenC++, OpenAda, CorbaScript, ObjVLisp, Object-Z, MODEL-K, XOTcl, and MELDC. Several of these languages date from the early 1990s and are of academic interest.[12]

Logtalk, an object-oriented extension of Prolog, also supports metaclasses.

Resource Description Framework (RDF) and Unified Modeling Language (UML) both support metaclasses.

See also

References

  1. ^ Ira R. Forman and Scott Danforth (1999). Putting Metaclasses to Work. Addison-Wesley. ISBN 0-201-43305-2.
  2. ^ AloorRavi, Sulekha (2022). Metaprogramming with Python. Birmingham: Packt Publishing.
  3. ^ IBM Metaclass programming in Python, parts 1 Archived 2008-09-03 at the Wayback Machine, 2 and 3
  4. ^ Artima Forum: Metaclasses in Python 3.0 (part 1 of 2) (part 2 of 2)
  5. ^ David Mertz. "A Primer on Python Metaclass Programming". ONLamp. Archived from the original on April 30, 2003. Retrieved June 28, 2006.
  6. ^ "The Ruby Object Model: Comparison with Smalltalk-80".
  7. ^ Paolo Perrotta (2010). Metaprogramming Ruby. Pragmatic Bookshelf. ISBN 978-1-934356-47-0.
  8. ^ "Object Membership: The Core Structure of Object Technology".
  9. ^ "Struct". Ruby Doc. Retrieved 1 May 2015.
  10. ^ Cocoa with Love: What is a meta-class in Objective-C?
  11. ^ Herb Sutter. "Metaclasses" (PDF).
  12. ^ "An implementation of mixins in Java using metaclasses" (PDF). Archived from the original (PDF) on 2007-10-16. Retrieved 2007-11-27.

Read other articles:

Association football league in England Football leagueMiddlesex County Football LeagueFounded1984Country EnglandDivisions7Number of teams92Level on pyramidLevels 11–13Feeder toCombined Counties LeagueHellenic LeaguePromotion toCombined Counties Football League Division OneHellenic League Division OneEssex Senior League (instance in 2012)Relegation toVarious inc. Hounslow & District FootballCurrent championsClapton Community (2022–23)Most championshipsWillesden Constantine (4)Webs...

 

 

Investigational antidepressant compound ApimostinelClinical dataOther namesNRX-1074; AGN-241660; Threonyl-prolyl-2R-(2-benzyl)-prolyl-threonine amideRoutes ofadministrationBy mouthDrug classNMDA receptor modulatorLegal statusLegal status US: Investigational New Drug Identifiers IUPAC name (2R)-1-[(2S)-1-[(2S,3R)-2-Amino-3-hydroxybutanoyl]pyrrolidine-2-carbonyl]-N-[(2S,3R)-1-amino-3-hydroxy-1-oxobutan-2-yl]-2-benzylpyrrolidine-2-carboxamide CAS Number1421866-48-9PubChem CID71249967ChemSpi...

 

 

American general Sean MacFarlandLieutenant General Sean MacFarland in April 2017Born (1959-02-12) February 12, 1959 (age 65)Albany, New York, United StatesAllegianceUnited States of AmericaService/branchUnited States ArmyYears of service1981–2018RankLieutenant GeneralCommands heldDeputy Commander, TRADOCIII Corps1st Armored Division1st Brigade Combat Team, 1st Armored Division2nd Battalion, 63rd Armor RegimentBattles/warsGulf WarIraq War Battle of Ramadi War in AfghanistanMilitary...

Dominican baseball player (born 1994) In this Spanish name, the first or paternal surname is Lopez and the second or maternal family name is Kely. Baseball player Reynaldo LópezLópez with the Washington Nationals in 2016Atlanta Braves – No. 40PitcherBorn: (1994-01-04) January 4, 1994 (age 30)San Pedro de Macorís, Dominican RepublicBats: RightThrows: RightMLB debutJuly 19, 2016, for the Washington NationalsMLB statistics (through April 16, 2024)Win–loss recor...

 

 

The Second Sex Edisi terjemahan kedua (2009)PengarangSimone de BeauvoirJudul asliLe Deuxième SexePenerjemahConstance Borde and Sheila Malovany-ChevalierNegaraPrancisBahasaFrenchGenreFilsafat FeminismeTanggal terbit1949Jenis mediaSampul keras Sampul lunakHalaman800ISBNISBN 0-679-72451-6OCLC20905133 The Second Sex (Prancis: Le Deuxième Sexe) adalah buku tahun 1949 karya eksistensialis Simone de Beauvoir. Buku ini adalah salah satu karya Beauvoir yang paling terkenal, membah...

 

 

Prime Minister of Tuvalu since 2024 The Right HonourableFeleti TeoOBE MPTeo in 201614th Prime Minister of TuvaluIncumbentAssumed office 26 February 2024MonarchCharles IIIGovernor GeneralSir Tofiga Vaevalu FalaniDeputyPanapasi NelesoniPreceded byKausea NatanoMember of ParliamentIncumbentAssumed office 26 January 2024Preceded bySamuelu TeoConstituencyNiutao Other offices Executive Director of the Western and Central Pacific Fisheries Commission (WCPFC)In officeDecember 2014 –...

For the automobile, see SEAT Marbella. Municipality in Andalusia, SpainMarbellaMunicipalityMarbella in early September 2009 FlagSealLocation of MarbellaCoordinates: 36°31′0″N 4°53′0″W / 36.51667°N 4.88333°W / 36.51667; -4.88333CountrySpainAutonomous communityAndalusiaProvinceMálagaComarcaCosta del Sol OccidentalGovernment • TypeMayor–council • BodyAyuntamiento de Marbella • MayorMaría Ángeles Muñoz (People's Party)A...

 

 

1943 film by Jean Renoir, Bruce Manning The Amazing Mrs. HollidayTheatrical release posterDirected byBruce ManningWritten by Boris Ingster (adaptation) Leo Townsend (adaptation) Screenplay by Frank Ryan Hans Jacoby Story bySonya LevienProduced byBruce ManningStarring Deanna Durbin Edmond O'Brien Barry Fitzgerald CinematographyElwood BredellEdited byTed J. KentMusic by Hans J. Salter Frank Skinner ProductioncompanyUniversal PicturesDistributed byUniversal PicturesRelease date February 19,...

 

 

University in Helsinki, Finland This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources in this article. Unsourced material may be challenged and removed.Find sources: University of Helsinki – news · newspapers · books · scholar · JSTOR (March 2019) (Learn how and when to remove this message) This article contains academic boosterism which primarily serves to praise or promo...

هذه المقالة عن المجموعة العرقية الأتراك وليس عن من يحملون جنسية الجمهورية التركية أتراكTürkler (بالتركية) التعداد الكليالتعداد 70~83 مليون نسمةمناطق الوجود المميزةالبلد  القائمة ... تركياألمانياسورياالعراقبلغارياالولايات المتحدةفرنساالمملكة المتحدةهولنداالنمساأسترالي�...

 

 

1969 Yukhnov mid-air collisionAccidentDate23 June 1969SummaryMid-air collisionSitenear Poroslitsy village, Yukhnov district, Kaluga region   Аn-12 54°35′53.51″N 35°36′27.86″E / 54.5981972°N 35.6077389°E / 54.5981972; 35.6077389 Il-14 54°36′8″N 35°32′59″E / 54.60222°N 35.54972°E / 54.60222; 35.54972 Total fatalities120First aircraft An Aeroflot Ilyushin Il-14, similar to the one involved in the collisionTypeIlyushin ...

 

 

此條目可能包含不适用或被曲解的引用资料,部分内容的准确性无法被证實。 (2023年1月5日)请协助校核其中的错误以改善这篇条目。详情请参见条目的讨论页。 各国相关 主題列表 索引 国内生产总值 石油储量 国防预算 武装部队(军事) 官方语言 人口統計 人口密度 生育率 出生率 死亡率 自杀率 谋杀率 失业率 储蓄率 识字率 出口额 进口额 煤产量 发电量 监禁率 死刑 国债 ...

Kohtes in a camp The Kohte [ˈkoːtə] is the typical tent of German Scouting and the German Youth Movement. Based on the Sámi goahti and lavvu and developed in the late 1920s and early 1930s, it is an open-topped tent assembled on-site from four characteristically shaped panels, which are traditionally black, and uses two tent poles lashed together in a V shape, from which the top of the tent is suspended using crossed sticks. The central hole serves as a smoke hole, so that a fire ...

 

 

Art or handicraft of decorating fabric or other materials with needle and thread or yarn This article is about handcraft. For Bradbury's short story, see Embroidery (short story). Embroidery sampler by Alice Maywood, 1826 Laid threads, a surface technique in wool on linen. The Bayeux Tapestry, 11th century Embroidery is the art of decorating fabric or other materials using a needle to stitch thread or yarn. Embroidery may also incorporate other materials such as pearls, beads, quills, and seq...

 

 

Stasiun Tsugawa津川駅Stasiun Tsugawa pada Juni 2010Lokasi127 Tsugawa, Aga-machi, Higashikambara-gun, Niigata-ken 959-4401JepangKoordinat37°41′17″N 139°26′49″E / 37.6881°N 139.4470°E / 37.6881; 139.4470Koordinat: 37°41′17″N 139°26′49″E / 37.6881°N 139.4470°E / 37.6881; 139.4470Operator JR EastJalur■ Jalur Ban'etsu BaratLetak137.0 km dari KōriyamaJumlah peron1 peron pulauJumlah jalur2Informasi lainStatusMemiliki staf ...

Abryna regispetri Klasifikasi ilmiah Kerajaan: Animalia Filum: Arthropoda Kelas: Insecta Ordo: Coleoptera Famili: Cerambycidae Genus: Abryna Spesies: Abryna regispetri Abryna regispetri adalah spesies kumbang tanduk panjang yang berasal dari famili Cerambycidae. Spesies ini juga merupakan bagian dari genus Abryna, ordo Coleoptera, kelas Insecta, filum Arthropoda, dan kingdom Animalia. Larva kumbang ini biasanya mengebor ke dalam kayu dan dapat menyebabkan kerusakan pada batang kayu hidup ata...

 

 

Scottish botanist (1773–1858) For other botanists with the same name, see Robert Brown (botanist, born 1842) and Robert Brown (New Zealand botanist). The Right HonourableRobert BrownFRS FRSE FLS MWS.Portrait by Henry William PickersgillBorn(1773-12-21)21 December 1773Montrose, ScotlandDied10 June 1858(1858-06-10) (aged 84)London, England[1]Alma materUniversity of Aberdeen University of EdinburghKnown forBrownian motion, Prodromus Florae Novae Hollandiae et Insulae Van...

 

 

Sporting event delegationPortugal at the1912 Summer OlympicsIOC codePORNOCOlympic Committee of PortugalWebsitewww.comiteolimpicoportugal.pt (in Portuguese)in StockholmCompetitors6 in 3 sportsFlag bearerFrancisco LázaroOfficials1Medals Gold 0 Silver 0 Bronze 0 Total 0 Summer Olympics appearances (overview)19121920192419281932193619481952195619601964196819721976198019841988199219962000200420082012201620202024 Portugal's first participation in the Summer Olympic Games took place at th...

This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: History of Charlottetown – news · newspapers · books · scholar · JSTOR (May 2009) (Learn how and when to remove this message) View of Charlottetown, 1872. The History of Charlottetown can be traced back to the original French military settlement established on ...

 

 

Acta EruditorumLogoStatoDEU Lingualatino Periodicitàmensile Genererivista scientifica e letteraria Formatovolume FondatoreOtto Mencke e Gottfried Leibniz Fondazione1682 Chiusura1782 SedeLipsia DirettoreOtto Mencke ISSN0166-6304 (WC · ACNP) DistribuzionemultimedialeEdizione digitaleElenco delle uscite   Modifica dati su Wikidata · Manuale Gli Acta Eruditorum (titolo latino, letteralmente Atti degli eruditi, nel senso di 'pubblicazioni di dotti') sono stati un periodico mensil...