16 진수 리터럴에 대한 '0x'규칙은 언제 어디서 시작 되었나요?

Aug 16 2020

1980 년대 초에 C는 0x16 진수로 표현 된 정수 리터럴을 나타내는 접두사 로 사용 했습니다 (예 : 0xCAFE. 이것은 B에 존재하지 않았다 B가 통해 리터럴 정수 지원 진수를했다지만, 1972 년 같은 0접두사.

0x접두사 는 언제 어디서 처음 사용 되었습니까?

답변

36 Raffzahn Aug 16 2020 at 13:28

B는 0 접두사를 통해 8 진 정수 리터럴을 지원했지만 1972 년 B에는 존재하지 않았습니다.

사실이지만 B의 전임자 인 BCPL #은 8 진수와 #x16 진수 에 대한 표기법을 사용 했습니다 . 그래서 아이디어는 한 세대를 '점프'했습니다.


C의 역사는 나중에 다시 추가 할 기능을 제거하는 것 중 하나입니다.

  • CPL (Combined Programming Language)은 Cambridge와 London에서 시스템 프로그래밍을위한 단순화 된 Algol로 개발되었습니다 (* 1). EDSAC 2, Atlas 및 IBM 7094 용으로 1965/66 년에 구현되었습니다.

  • BCPL (Basic CPL)은 이름에서 알 수 있듯이 CPL의 단순화 된 버전으로 1967 년 IBM 7094 (* 2)에서 처음 구현되었습니다.

  • B 는 다시 단순화 된 BCPL (* 3, * 4)로, 1969 년에 PDP-7에 맞게 만들어졌습니다.

  • C는 1972ff에서 PDP-11 용 NB (New B)를 통해 개발되어 기능을 추가했습니다.

#8 진수 상수를 나타내는 데 사용되는 CPL . 구현 된 모든 컴퓨터는 3으로 나눌 수있는 단어 크기를 가지고 있고 출력에 6 비트 문자를 사용했기 때문에 16 진수가 실제로 필요하지 않았습니다.

BCPL 은 (아주 짧은) 시간에 걸쳐 진화했습니다. 처음부터 #8 진수를 표시하는 데 사용 되었지만 곧 16 진수 와 8 진수 를 #b위한 2 #x진수로 보완되었습니다 #o. 이러한 추가는 시간과 구현에 따라 다르지만 최소한 #x빠르게 표준이되었습니다.

B#x 는 전체 #표기법 (* 5)을 사용하여 이전 0을 선호하여 다시 삭제 하여 구문 분석기를 단순화했습니다. PDP-7은 3 단어 크기의 배수 기계 였기 때문에 8 진법이 필요한 유일한 기계 별 표기법이었습니다 (* 6,7).

C 는 차례로 PDP-11 용으로 개발되었습니다. 16 비트 머신으로서 많은 머신 종속 상수는 자연스럽게 16 진수로 제공됩니다. 8 비트 바이트와 ASCII의 32 그룹 분할은 말할 것도 없습니다. 이제 16 진수 표기법을 다시 도입하는 것이 고려되었습니다. 유용함-이번에는 앞의 0이라는 아이디어를 유지합니다.


* 1-CPL은 정말 볼만한 가치가 있습니다. 기본 요소로 단어에 대한 포인터와 같은 C의 기본 기능이 이미 많이 포함되어 있지만 오늘날과는 전혀 다른 기능도 포함되어 있습니다. 예를 들어 a = bc변수 bc를 a에 할당하지 않고 b 곱하기 c를 곱합니다. 다중 문자 식별자는 대문자로 시작해야했습니다. 이것은 또한 많이 좋아하는 낙타 케이스의 기원 일 수도 있습니다.

* 2-당시에는 중괄호 나 대괄호가 없었던 Model 35 TTY가 추가되었습니다. 마찬가지로 백 슬래시가 없으므로 *문자열의 특수 문자에 사용되었습니다.

* 3-재미있는 스위치도 있습니다. Algol +:=을 증강 할당으로 사용했기 때문에 CPL 및 BCPL =+을 사용하고 B는 +=.

* 4-PL / I가 추가되었을 수 있습니다.

* 5- #비교 연산자의 일부로도 유사하게 떨어졌습니다.

* 6-8 비트 바이트와 해당 16 진수 표기법은 IBM / 360에서 바로 이전에 도입되었다는 점을 항상 염두에 두어야합니다.

* 7-흥미로운 부가 메모는 CTC가 1970 Datapoint 2200 용 어셈블러에서 8 진 상수에 대해 선행 0을 사용했다는 것입니다 . 그래서 직접적인 관계가 없다는 것을 알지만, 그들이 톰슨과 같은 시간에 같은 해결책을 내놓았다는 것은 꽤 흥미 롭습니다.