<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Basic_Combined_Programming_Language</id>
	<title>Basic Combined Programming Language - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Basic_Combined_Programming_Language"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Basic_Combined_Programming_Language&amp;action=history"/>
	<updated>2026-05-16T04:42:44Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Basic_Combined_Programming_Language&amp;diff=39125&amp;oldid=prev</id>
		<title>imported&gt;AreBureBoke: /* growthexperiments-addlink-summary-summary:2|0|0 */</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Basic_Combined_Programming_Language&amp;diff=39125&amp;oldid=prev"/>
		<updated>2025-05-07T14:53:08Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;growthexperiments-addlink-summary-summary:2|0|0&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{{Infobox Programmiersprache&lt;br /&gt;
|Name = BCPL&lt;br /&gt;
|Paradigma = [[Imperative Programmierung|imperativ]], [[Strukturierte Programmierung|strukturiert]]&lt;br /&gt;
|Erscheinungsjahr = 1967&lt;br /&gt;
|Entwickler = Martin Richards&lt;br /&gt;
|Typisierung = typenlos&lt;br /&gt;
|Implementierung = &lt;br /&gt;
|Dialekte = &lt;br /&gt;
|Beeinflusst_von = [[Combined Programming Language|CPL]]&lt;br /&gt;
|Beeinflusste = [[B (Programmiersprache)|B]]&lt;br /&gt;
}}&lt;br /&gt;
&lt;br /&gt;
Die &amp;#039;&amp;#039;&amp;#039;Basic Combined Programming Language&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;BCPL&amp;#039;&amp;#039;&amp;#039;) ist eine 1966 von [[Martin Richards (Informatiker)|Martin Richards]] entwickelte und im Frühjahr 1967 am [[Massachusetts Institute of Technology]] zum ersten Mal implementierte, kompilierte, systemnahe [[Programmiersprache]], abgeleitet von der Combined/Cambridge Programming Language [[Combined Programming Language|CPL]]. Es ist eine Sprache aus der [[ALGOL]]-Familie. Eine Weiterentwicklung von BCPL war die Programmiersprache [[B (Programmiersprache)|B]], die wiederum die Basis für die Entwicklung der dauerhaft bedeutsamen Programmiersprache [[C (Programmiersprache)|C]] darstellte.&lt;br /&gt;
&lt;br /&gt;
== Allgemeine Beschreibung ==&lt;br /&gt;
&lt;br /&gt;
Vorteile von BCPL sind schnelle Erlernbarkeit, einfache [[Implementierung]] und leichte Portierbarkeit. Es ist hauptsächlich gedacht zum [[Compilerbau]], zur [[Systemprogrammierung]] und als „Pioniersprache“, also als erste Sprache für ein neues System.&lt;br /&gt;
&lt;br /&gt;
Ein BCPL-Programm besteht aus einzelnen Funktionen, die auch rekursiv definiert sein dürfen; der Funktionsaufruf erfolgt mit [[Wertparameter]]n.&lt;br /&gt;
&lt;br /&gt;
BCPL kennt als Datentyp nur das Wort, typischerweise mit der Wortbreite des Prozessors. Bezeichner verweisen auf Speicherzellen als [[Variable (Programmierung)|Variablen]] oder Konstanten. Je nach Operator wird der Inhalt einer Speicherzelle oder das Ergebnis eines Ausdrucks als [[Ganze Zahl|Integralwert]], [[Referenzvariable|Speicherreferenz]], [[Array (Datentyp)|Vektor]] oder [[Funktionszeiger|Eintrittspunkt einer Funktion]] interpretiert, eine Typprüfung zur Kompile- oder Laufzeit findet nicht statt. Es gibt ausschließlich lokale Bezeichner sowie einen globalen Vektor, in dem im gesamten Programm sichtbare Bezeichner (insbesondere die Funktionsnamen) zusammengefasst sind.&lt;br /&gt;
&lt;br /&gt;
Bezeichner in und Ergebnisse von Ausdrücken werden abhängig von der Verwendung entweder als [[L-Wert (Programmierung)|L- oder R-Wert]] interpretiert, z.&amp;amp;nbsp;B. in der Zuweisung l = r die Variable l als L-Wert (Speicheradresse) und die Variable r als R-Wert (Inhalt). Die Operatoren RV und LV erlauben es, die Interpretation umzukehren. RV X = LV Y z.&amp;amp;nbsp;B. speichert die Adresse von Y an die Stelle, auf die der Inhalt von X verweist.&amp;lt;ref&amp;gt;Henry Ancona (MIT): [http://www.bitsavers.org/pdf/mit/tx-2/TX-2_BCPL_Reference_Manual_May69.pdf &amp;#039;&amp;#039;The BCPL Reference Manual.&amp;#039;&amp;#039;] 6. Mai 1969.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
BCPL selbst stellt praktisch nur Funktionen zur Bit- und Wortmanipulation zur Verfügung. Alle anderen Funktionen sind in zusätzlichen Bibliotheken zusammengefasst.&lt;br /&gt;
&lt;br /&gt;
[[Ken Thompson]] entwickelte 1969 die Sprache [[B (Programmiersprache)|B]], die stark von BCPL beeinflusst ist. Da B für die Interpretation auf einer [[PDP-7]] mit 8&amp;amp;nbsp;kB [[Arbeitsspeicher|RAM]] entwickelt wurde, ist B einfacher aufgebaut als BCPL.&amp;lt;ref&amp;gt;{{Literatur |Autor=[[Dennis Ritchie]] |Titel=The Development of the C Language |Sammelwerk=History of Programming Languages |Verlag=ACM Press and Addison-Wesley |Ort=New York |Datum=1996 |ISBN=0-201-89502-1}}&amp;lt;/ref&amp;gt; Beispielsweise sind keine verschachtelten Funktionsdefinitionen möglich. Aus der Weiterentwicklung von B entstand die Programmiersprache [[C (Programmiersprache)|C]].&lt;br /&gt;
&lt;br /&gt;
Es gibt BCPL-Implementierungen für praktisch jedes [[Betriebssystem]], die verschiedenen Implementierungen sind nicht quelltextkompatibel.&lt;br /&gt;
&lt;br /&gt;
Die BCPL-Philosophie wird durch folgendes Zitat aus dem nur auf Englisch verfügbaren Buch &amp;#039;&amp;#039;[[#Literatur|BCPL-The language and its compiler]]&amp;#039;&amp;#039; illustriert:&lt;br /&gt;
&lt;br /&gt;
{{Zitat&lt;br /&gt;
 |Text=The philosophy of BCPL is not one of the tyrant who thinks he knows best and lays down the law on what is and what is not allowed; rather, BCPL acts more as a servant offering his services to the best of his ability without complaint, even when confronted with apparent nonsense. The programmer is always assumed to know what he is doing and is not hemmed in by petty restrictions.&lt;br /&gt;
 |Sprache=en&lt;br /&gt;
 |Quelle=BCPL-The language and its compiler&lt;br /&gt;
 |Übersetzung=Die BCPL-Philosophie ist nicht die des Tyrannen, der alles besser weiß und Regeln darüber erlässt, was erlaubt und was verboten ist. Stattdessen verhält sich BCPL mehr wie der Diener, der seine Dienste ohne Murren bestmöglich anbietet, auch wenn ihm augenscheinlicher Unsinn aufgetragen wird. Es wird stets vorausgesetzt, dass der Programmierer weiß, was er tut. Er wird daher nicht durch kleinkarierte Einschränkungen eingeengt.}}&lt;br /&gt;
&lt;br /&gt;
== O-Code ==&lt;br /&gt;
&lt;br /&gt;
Richards entwickelte in den späten 1960er Jahren einen [[Zwischencode]], der BCPL maschinenunabhängig machen sollte. Der BCPL-[[Compiler]] erzeugt O-Code, wobei das O für Objekt, also &amp;#039;&amp;#039;Objektcode&amp;#039;&amp;#039; steht.&lt;br /&gt;
&lt;br /&gt;
Der O-Code kann dann von einem weiteren Programm entweder [[Interpreter|interpretiert]] oder in spezifischen [[Maschinencode]] übersetzt werden. Diese Idee wurde und wird auch in neueren Compilern eingesetzt, z.&amp;amp;nbsp;B. in Form des RTL (Register Transfer Language)-Zwischencodes beim [[GNU Compiler Collection|GCC]] oder dem [[P-Code]] von [[UCSD Pascal]]. [[Java (Programmiersprache)|Java]] mit der [[Java Virtual Machine]] verwendet ebenfalls einen eigenen Zwischencode, der allerdings irgendwo zwischen O-Code und Maschinencode liegt.&lt;br /&gt;
&lt;br /&gt;
O-Code erlaubt die Trennung von generellen und prozessorspezifischen Übersetzungsanforderungen. Die [[Portierung (Software)|Portierung]] des BCPL-Compilers wurde durch seine Verwendung extrem erleichtert, und BCPL wurde schnell auf verschiedenen Maschinen verfügbar.&lt;br /&gt;
&lt;br /&gt;
== Programmbeispiel ==&lt;br /&gt;
&amp;lt;syntaxhighlight lang=&amp;quot;text&amp;quot;&amp;gt;&lt;br /&gt;
GET &amp;quot;LIBHDR&amp;quot;&lt;br /&gt;
&lt;br /&gt;
LET START () BE&lt;br /&gt;
$(WRITES (&amp;quot;Hello, world!*N&amp;quot;)&lt;br /&gt;
&amp;lt;/syntaxhighlight&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Betriebssysteme ==&lt;br /&gt;
&lt;br /&gt;
Teile des [[AmigaOS]] (die Komponente AmigaDOS) basieren auf [[TRIPOS]], einem [[Mehrbenutzersystem|Mehrbenutzerbetriebssystem]] der Firma [[MetaComCo]], das in der Programmiersprache BCPL entwickelt wurde, und tragen daher heute noch Spuren von BCPL. So enden beispielsweise BCPL-[[Zeiger (Informatik)|Zeiger]] in AmigaDOS-Datenstrukturen zwangsläufig auf 32-Bit-Grenzen, da sie um 2 Bit nach rechts verschoben sind, was einer Division durch 4 entspricht. Weiterhin werden in AmigaDOS oft Zeichenketten verwendet, die statt der in der Programmiersprache C üblichen Nullterminierung ein vorangestelltes Längenbyte verwenden.&lt;br /&gt;
&lt;br /&gt;
Ein ebenfalls in BCPL entwickeltes Betriebssystem der AEG (Systemsoftware-Abteilung Konstanz) für die eigenen Maschinen [[AEG 80 Prozessrechner|AEG 80-40]] und AEG 80-60 (Stückzahl unter 100, um 1980) war &amp;#039;&amp;#039;MARTOS&amp;#039;&amp;#039; (Multi Access Real Time Operating System). Ebenfalls für diese nur in wenigen Projekten eingesetzten, damals eigentlich sehr modernen Maschinen, wurde die in BCPL implementierte, mit C und [[PL/I]] verwandte Programmiersprache &amp;#039;&amp;#039;&amp;#039;SL3&amp;#039;&amp;#039;&amp;#039; (System Low Level Language) entwickelt, bei der man systemnah wie in Assembler einzelnen Variablen feste Register zuordnen, andererseits aber auch mit komplexen und geschachtelten Strukturen programmieren konnte.&lt;br /&gt;
&lt;br /&gt;
== Literatur ==&lt;br /&gt;
* {{Literatur&lt;br /&gt;
   |Autor=M. Richards, C. Whitby-Strevens&lt;br /&gt;
   |Titel=BCPL – the language and its compiler&lt;br /&gt;
   |Verlag=Cambridge University Press&lt;br /&gt;
   |Ort=Cambridge&lt;br /&gt;
   |Datum=1980&lt;br /&gt;
   |ISBN=0-521-28681-6}}&lt;br /&gt;
* {{Literatur&lt;br /&gt;
   |Autor=Martin Richards&lt;br /&gt;
   |Titel=The Portability of the BCPL Compiler&lt;br /&gt;
   |Sammelwerk=Software – Practice and Experience&lt;br /&gt;
   |Band=1&lt;br /&gt;
   |Nummer=2&lt;br /&gt;
   |Datum=1971&lt;br /&gt;
   |Seiten=135–146}}&lt;br /&gt;
* [http://www.cl.cam.ac.uk/~mr10/bcpl4raspi.pdf &amp;#039;&amp;#039;Young Persons Guide to BCPL Programming on the Raspberry Pi&amp;#039;&amp;#039;] (PDF; 9,7&amp;amp;nbsp;MB) Teil 1 und 2&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* [http://www.cl.cam.ac.uk/~mr10/bcplman.pdf The BCPL Cintcode and Cintcode User Guide by Martin Richards, 2007] (englisch; PDF; 933&amp;amp;nbsp;kB)&lt;br /&gt;
* [https://www.bell-labs.com/usr/dmr/www/bcpl.html Martin Richards’s BCPL Reference Manual, 1967] (englisch)&lt;br /&gt;
* [http://www.cl.cam.ac.uk/~mr10/BCPL.html Machine independent interpretive implementation of BCPL, free of charge for private and academic purposes] (englisch)&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Programmiersprache]]&lt;/div&gt;</summary>
		<author><name>imported&gt;AreBureBoke</name></author>
	</entry>
</feed>