Movatterモバイル変換


[0]ホーム

URL:


Jump to content
WikipediaThe Free Encyclopedia
Search

B (programming language)

From Wikipedia, the free encyclopedia
Procedural programming language
This article is about the language developed at Bell Labs. For the predecessor of the ABC language, seeABC (programming language).
B
Designed byKen Thompson
DeveloperKen Thompson,Dennis Ritchie
First appeared1969; 57 years ago (1969)[1]
Typing disciplinetypeless (everything is aword)
Filename extensions.b
Majorimplementations
BLang LLVM-based B Compiler,B by Alexey Kutepov (incomplete),BCause, A Modern B Compiler
Influenced by
Fortran,BCPL,PL/I,TMG
Influenced
C

B is aprogramming language developed atBell Labs circa 1969 byKen Thompson andDennis Ritchie.

B was designed for recursive, non-numeric, machine-independent applications, such as system and language software.[2] It was a typeless language, with the only data type being the underlying machine's naturalmemory word format, whatever that might be. Depending on the context, the word was treated either as aninteger or amemory address.

As machines withASCII processing became common, notably theDEC 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 ubiquitousC programming language.

History

[edit]

BCPL semantics with a lot of SMALGOL syntax

— Ken Thompson,[3]

Ken Thompson began developing B as aFortran compiler for thePDP-7, but found that his initial implementation far exceeded available memory. Through several iterations of simplifying the compiler and adapting the language to his own tastes that were influenced byBCPL, he arrived at a language that expressed a subset of BCPL semantics in a distinct syntax. Thompson named the language B, which has been variously explained as an abbreviation of BCPL or Bon, another language he had developed, although he confirmed neither explanation.[4][5]

Thompson added "two-address assignment operators" usingx =+ y syntax to add y to x (in C the operator is written+=). This syntax came fromDouglas McIlroy's implementation ofTMG, in which B's compiler was first implemented (and it came to TMG fromALGOL 68'sx +:= y syntax).[4][6] Thompson went further by inventing the increment and decrement operators (++ and--). 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.[4]

B is typeless, or more precisely has one data type: the computer word. Most operators (e.g.+,-,*,/) treated this as an integer, but others treated it as a memory address to bedereferenced. In many other ways it looked a lot like an early version of C. It included a generalizedfor loop as later appeared in C, which Thompson adapted from earlier work byStephen Johnson.[5] There are a few library functions, including some that vaguely resemble functions from thestandard I/O library in C.[2] In Thompson's words: "B and the old old C were very very similar languages except for all the types [in C]".[5]

Early implementations were for the DECPDP-7 andPDP-11 minicomputers using earlyUnix, andHoneywellGE 645[7] 36-bit mainframes running the operating systemGCOS. The earliest PDP-7 implementations compiled tothreaded code, and Ritchie wrote a compiler usingTMG which produced machine code.[8][9][10] In 1970 a PDP-11 was acquired and threaded code was used for the port; an assembler,dc, and the B language itself were written in B tobootstrap the computer. An early version ofyacc was produced with this PDP-11 configuration. Ritchie took over maintenance during this period.[4][10]

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.[4]

B is almost extinct, having been superseded by theC language.[11] However, it continues to see use onGCOS mainframes (as of 2014[update])[12] and on certainembedded systems (as of 2000[update]) for a variety of reasons: limited hardware in small systems, extensive libraries, tooling, licensing cost issues, and simply being good enough for the job.[11] The highly influentialAberMUD was originally written in B.

Examples

[edit]

The following examples are from theUsers' Reference to B by Ken Thompson:[2]

/* The following function will print a non-negative number, n, to   the base b, where 2<=b<=10.  This routine uses the fact that   in the ASCII character set, the digits 0 to 9 have sequential   code values.  */printn(n,b){extrnputchar;autoa;/* Wikipedia note: the auto keyword declares a variable with      automatic storage (lifetime is function scope), not      "automatic typing" as in C++11. */if(a=n/b)/* assignment, not test for equality */printn(a,b);/* recursive */putchar(n%b+'0');}
/* 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 conver-   sion of the expansion      1/2! + 1/3! + ... = .111...   where the bases of the digits are 2, 3, 4, ... */main(){extrnputchar,n,v;autoi,c,col,a;i=col=0;while(i<n)v[i++]=1;while(col<2*n){a=n+1;c=i=0;while(i<n){c=+v[i]*10;v[i++]=c%a;c=/a--;}putchar(c+'0');if(!(++col%5))putchar(col%50?' ':'*n');}putchar('*n*n');}v[2000];n2000;

References

[edit]
  1. ^"B - computer programming language".Encyclopedia Britannica.
  2. ^abcThompson, Ken (7 January 1972)."Users' Reference to B"(PDF). Bell Laboratories. Archived fromthe original(PDF) on 17 March 2015. Retrieved21 March 2014.
  3. ^Jensen, Richard (9 December 2020).""A damn stupid thing to do"—the origins of C".Ars Technica. Retrieved2022-03-28.
  4. ^abcdeRitchie, Dennis M. (March 1993)."The Development of the C Language".ACM SIGPLAN Notices.28 (3):201–208.doi:10.1145/155360.155580.
  5. ^abc"VCF East: Ken Thompson interviewed by Brian Kernighan".YouTube. 6 May 2019. 41:07
  6. ^Michael S. Mahoney (18 August 1989)."Interview with M.D. McIlroy".Princeton.edu. Murray Hill.
  7. ^Ritchie, Dennis M. (1984)."The Evolution of the Unix Time-sharing System".AT&T Bell Laboratories Technical Journal.63 (6 Part 2):1577–1593.doi:10.1002/j.1538-7305.1984.tb00054.x. Archived fromthe original on 11 June 2015.
  8. ^"TMG". multicians.org.
  9. ^Ritchie, Dennis M."The Development of the C Language". Bell Labs/Lucent Technologies. Archived fromthe original on 11 June 2015.
  10. ^abMcIlroy, M. D. (1987).A Research Unix reader: annotated excerpts from the Programmer's Manual, 1971–1986(PDF) (Technical report). CSTR. Bell Labs. 139.Archived(PDF) from the original on 2022-10-09.
  11. ^abJohnson and Kernighan."THE PROGRAMMING LANGUAGE B". Bell Laboratories. Archived fromthe original on 11 June 2015. Retrieved21 March 2014.
  12. ^"Thinkage UW Tools Package". Thinkage, Ltd. Retrieved26 March 2014.

External links

[edit]
Operating systems
Programming languages
Software
Associated institutions
Other
Portal:
Retrieved from "https://en.wikipedia.org/w/index.php?title=B_(programming_language)&oldid=1334549546"
Categories:
Hidden categories:

[8]ページ先頭

©2009-2026 Movatter.jp