Content deleted Content added
Origin of language name B Tags: Reverted Visual edit |
Added another major implementation, and removed two out-dated, no longer maintained implementations. |
||
(19 intermediate revisions by 17 users not shown) | |||
Line 2:
{{about|a programming language developed at Bell Labs|"b" language of Meertens and Pemberton|ABC (programming language)|other uses|B (disambiguation)}}
{{Infobox programming language
| name
| logo =
| logo caption =
| paradigm =
| year
| designer
| developer
| latest_release_version =
| latest_release_date =
| latest_test_version =
| latest_test_date =
| turing-complete
| typing
| influenced_by = [[BCPL]], [[PL/I]], [[TMG (language)|TMG]]
▲| dialects =
|
| implementations = [https://github.com/wgibbs-rs/blang BLang LLVM-based B Compiler], [https://github.com/tsoding/b B by Alexey Kutepov (incomplete)], [https://github.com/Spydr06/BCause BCause, A Modern B Compiler]
| operating_system =
| license =
| website =
| file_ext
}}
'''B''' is a [[programming language]] developed at [[Bell Labs]] circa 1969 by [[Ken Thompson (computer programmer)|Ken Thompson]] and [[Dennis Ritchie]].
B was derived from [[BCPL]],
B was designed for recursive, non-numeric, machine-independent applications, such as system and language software.<ref name=bur>{{cite web
Line 42:
}}</ref> It was a typeless language, with the only data type being the underlying machine's natural [[memory word]] format, whatever that might be. Depending on the context, the word was treated either as an [[integer]] or a [[memory address]].
As machines with [[ASCII]] processing became common, notably the [[DEC PDP-11]] that arrived at Bell Labs, support for character data stuffed in memory words became important. The typeless nature of the language was seen as a disadvantage, which led Thompson and Ritchie to develop an expanded version of the language supporting new internal and user-defined types, which became the ubiquitous [[C programming language]].
== History ==
{{rquote|quote=BCPL semantics with a lot of SMALGOL syntax|author=Ken Thompson|source=<ref name=Ars>{{cite web |last1=Jensen |first1=Richard |title="A damn stupid thing to do"—the origins of C |url=https://arstechnica.com/features/2020/12/a-damn-stupid-thing-to-do-the-origins-of-c/ |website=Ars Technica |access-date=2022-03-28 |language=en-us |date=9 December 2020}}</ref>}}
Circa 1969, [[Ken Thompson (computer programmer)|Ken Thompson]]<ref name=chist /> and later Dennis Ritchie<ref name=bur /> developed B basing it mainly on the [[BCPL]] language Thompson used in the [[Multics]] project. B was essentially the BCPL system stripped of any component Thompson felt he could do without in order to make it fit within the memory capacity of the minicomputers of the time. The BCPL to B transition also included changes made to suit Thompson's preferences (mostly along the lines of reducing the number of non-whitespace characters in a typical program).<ref name=chist /> Much of the typical [[ALGOL]]-like syntax of BCPL was rather heavily changed in this process. The assignment operator <code>:=</code> reverted to the <code>=</code> of [[Heinz Rutishauser|Rutishauser]]'s [[Superplan]], and the equality operator <code>=</code> was replaced by <code>==</code>.
Thompson added "two-address assignment operators" using <code>x =+ y</code> syntax to add y to x (in C the operator is written <code>+=</code>). This syntax came from [[Douglas McIlroy]]'s implementation of [[TMG (language)|TMG]], in which B's compiler was first implemented (and it came to TMG from [[ALGOL 68]]'s <code>x +:= y</code> syntax).<ref name=chist /><ref>{{cite web |author=Michael S. Mahoney |author-link=Michael Sean Mahoney |url=https://www.princeton.edu/~hos/mike/transcripts/mcilroy.htm |title=Interview with M.D. McIlroy |___location=Murray Hill |date=18 August 1989|website=Princeton.edu}}</ref> Thompson went further by inventing the increment and decrement operators (<code>++</code> and <code>--</code>). Their prefix or postfix position determines whether the value is taken before or after alteration of the operand. This innovation was not in the earliest versions of B. According to Dennis Ritchie, people often assumed that they were created for the auto-increment and auto-decrement address modes of the DEC PDP-11, but this is historically impossible as the machine didn't exist when B was first developed.<ref name=chist />
Line 56:
In Thompson's words: "B and the old old C were very very similar languages except for all the types [in C]".<ref name="ken"/>
Early implementations were for the DEC [[PDP-7]] and [[PDP-11]] minicomputers using early [[Unix]], and [[Honeywell]] {{nowrap|[[GE-600 series|GE 645]]}}<ref name="Evolution">{{cite journal |first=Dennis M. |last=Ritchie |title=The Evolution of the Unix Time-sharing System |url=https://www.bell-labs.com/usr/dmr/www/hist.html |archive-url=https://web.archive.org/web/20150611114353/https://www.bell-labs.com/usr/dmr/www/hist.html |archive-date=11 June 2015 |journal=AT&T Bell Laboratories Technical Journal |volume=63 |number=6 Part 2 |year=1984 |pages=1577–1593|doi=10.1002/j.1538-7305.1984.tb00054.x |url-access=subscription }}</ref> 36-bit mainframes running the operating system [[General Comprehensive Operating System|GCOS]]. The earliest PDP-7 implementations compiled to [[threaded code]], and Ritchie wrote a compiler using [[TMG (language)|TMG]] which produced machine code.<ref>{{cite web |url=http://www.multicians.org/tmg.html |title=TMG |publisher=multicians.org}}</ref><ref>{{cite web |url=https://www.bell-labs.com/usr/dmr/www/chist.html |archive-url=https://web.archive.org/web/20150611114355/https://www.bell-labs.com/usr/dmr/www/chist.html |archive-date=11 June 2015 |title=The Development of the C Language |first=Dennis M. |last=Ritchie |author-link=Dennis Ritchie |publisher=Bell Labs/Lucent Technologies}}</ref><ref name="reader">{{cite
The typeless nature of B made sense on the Honeywell, PDP-7 and many older computers, but was a problem on the PDP-11 because it was difficult to elegantly access the character data type that the PDP-11 and most modern computers fully support. Starting in 1971 Ritchie made changes to the language while converting its compiler to produce machine code, most notably adding data typing for variables. During 1971 and 1972 B evolved into "New B" (NB) and then C.<ref name=chist />
Line 86:
code values. */
printn(n,
}
</syntaxhighlight>
Line 102:
/* The following program will calculate the constant e-2 to about
4000 decimal digits, and print it 50 characters to the line in
groups of 5 characters. The method is simple output
sion of the expansion
1/2! + 1/3! + ... = .111
where the bases of the digits are 2, 3, 4, .
main() {
while(col<2*n) {▼
a = n+1;▼
c = i = 0;▼
c =+ v[i] *10;▼
v[i++] = c%a;▼
c =/ a--;▼
putchar(c+'0');▼
if(!(++col%5))▼
putchar(col%50?' ': '*n');▼
while(i<n) {
putchar('*n*n');▼
}
}
}
v[2000];
n 2000;
</syntaxhighlight>
{{portal-inline|Computer programming}}▼
== Notes ==
Line 145 ⟶ 143:
* [http://man.cat-v.org/unix-1st/1/b Manual page for b(1) from Unix First Edition]
* [https://www.bell-labs.com/usr/dmr/www/chist.html The Development of the C Language], [[Dennis Ritchie|Dennis M. Ritchie]]. Puts B in the context of [[BCPL]] and [[C (programming language)|C]].
* ''[https://www.bell-labs.com/usr/dmr/www/kbman.html Users' Reference to B]'', Ken Thompson. Describes the [[PDP-11]] version.
* [https://www.bell-labs.com/usr/dmr/www/bintro.html The Programming Language B], S. C. Johnson & B. W. Kernighan, Technical Report CS TR 8, [[Bell Labs]] (January 1973). The [[General Comprehensive Operating System|GCOS]] version on [[Honeywell]] equipment.
* [http://www.thinkage.ca/english/gcos/expl/b/index.html B Language Reference Manual], Thinkage Ltd. The production version of the language as used on GCOS, including language and runtime library.
Line 151 ⟶ 149:
{{Ken Thompson navbox}}
{{Programming languages}}
[[Category:Procedural programming languages]]
|