Oberon-2 | |
---|---|
Språkklass | imperativ , strukturerad , modulär , objektorienterad |
Framträdde i | 1991 |
Författare | Niklaus Wirth , Hanspeter Mössenböck |
Typ system | statisk , stark |
Blivit påverkad | Oberon |
påverkas | Komponent Pascal , Go |
Oberon-2 ( Oberon-2 ) - en förlängning av programmeringsspråket Oberon med metaprogrammeringselement ( begränsad reflektion ) och verktyg för objektorienterad programmering, även lagt till öppna arrayer och grundläggande pekartyper, fält tillgängliga för skrivskyddad export, FOR operatör från Modula-2 .
Utvecklad 1991 vid ETH Zürich av Niklaus Wirth och Hanspeter Mössenböck som en omarbetning av Object Oberon. Oberon-2 är en utökad uppsättning av Oberon och är helt kompatibel med den.
Huvudsakliga tillägg:
Det finns en optimerande kompilator XDS [3] för Oberon-2; det finns också en språkkompilator till Java bytecode [4] .
Språkfamiljen Algol - Pascal - Modula-2 - Oberon - Oberon-2 - Komponent Pascal har utvecklats i riktning mot att minska komplexiteten i syntaxen . Samtidigt, trots expansionen av språket, är volymen av den formella beskrivningen av Oberon-2-syntaxen mindre än den för den klassiska Oberon på grund av optimeringen av beskrivningen: den fullständiga syntaxen beskrivs i endast 33 meningar i den utökade Backus-Naur-formen [5] :
Modul = MODUL- id ";" [ ImportList ] Senast deklarerad [ BEGIN Senaste uttalanden ] END id "." . ImportList = IMPORTERA [ id ":=" ] id { "," [ id ":=" ] id } ";" . LastDeclared = { CONST { DeclaredConst ";" } | TYPE { Typedeclaration ";" } | VAR { DeclaredVar ";" }} { DeclaredProc ";" | ForwardDeclared ";" }. DeclaredConst = IdentDef "=" ConstExpression . TypeDeclare = IdentDef "=" Typ . DeclaredVar = ListIdentifier ":" Typ . DeclaredProc = PROCEDUR [ Mottagare ] IdentDef [ FormalParam ] ";" Senaste deklarerade [ BEGIN Senaste uttalanden ] END Ident . ForwardDeclare = PROCEDUR "^" [ Mottagare ] IdentDef [ FormalParam ]. FormalParam = "(" [ FP Section { ";" FP Section }] ")" [ ":" SpecIdent ]. SektionFP = [ VAR ] id { "," id } ":" Typ . Mottagare = "(" [ var ] id ":" id ")" . Typ = QualID | ARRAY [ ConstExpression { "," ConstExpression }] AV Typ | RECORD [ "(" QualIdent ")" ] FieldList { ";" Fältlista } END | PEKARE TILL Typ | PROCEDUR [ FormalParam ]. FieldList = [ ListIdent ":" Typ ]. AfterOperators = Operatör { ";" Operatorn }. Operator = [ Notation ":=" Uttryck | Notation [ "(" [ ListExpression ] ")" ] | IF Expr THEN Statement Seq { ELSIF Expr THEN Statement Seq } [ ELSE Statement Seq ] END | CASE- uttryck för alternativ { "|" Variant } [ ELSE StatementSeq ] END | WHILE Express DO Statement Seq END | REPEAT StatementSeq TILL Uttryck | FÖR ident ":=" Express TO Express [ AV Const Express ] DO StatementSeq END | LOOP AfterStatements END | WITH Guard DO StatementSequence { "|" Guard DO StatementSeq } [ ELSE StatementSeq ] END | AVSLUTA | RETURN [ Express ] ]. Alternativ = [ Variantetiketter { "," Variantetiketter } ":" StatementLast ]. VariantLabels = ConstExpression [ ".." ConstExpression ]. Guard = SpecId ":" SpecId . ConstExpression = Express . Expression = SimpleExpression [ Relation SimpleExpression ]. SimpleExpression = [ "+" | "-" ] Term { OperSlog Term }. Term \ u003d Multiplikator { OperMul Multiplier }. Multiplikator = Notation [ "(" [ ListExpression ] ")" ] | nummer | symbol | sträng | NIL | Ställ in | "(" Uttryck ")" | " ~ " Multiplikator . Set = "{" [ Element { "," Element }] "}" . Element = Express [ ".." Express ]. Relation = "=" | "#" | "<" | "<=" | ">" | ">=" | IN | IS . OperSlog = "+" | "-" | ELLER . OperUmn = "*" | "/" | DIV | MOD | "&" . Designation = Qualifier { "." ident | "[" ListExpression "]" | "^" | "(" QualIdent ")" }. ListExpr = Uttryck { "," Express }. ListIdent = IdentDef { "," IdentDef }. QualID = [ identifierare "." ] ID . IdentDef = ident [ "*" | "-" ].
Programmeringsspråk | |
---|---|
|