我今天学到了C99和C++中的有向图.以下是有效的计划:
%:include%:ifndef BUFSIZE %:define BUFSIZE 512 %:endif void copy(char d<::>, const char s<::>, int len) <% while (len-- >= 0) <% d<:len:> = s<:len:>; %> %>
我的问题是:它们为什么存在?
为没有支持ISO 646字符集的键盘的程序员创建了有向图.
http://en.wikipedia.org/wiki/C_trigraph
我相信它们的存在可以追溯到某个地方,有人正在使用带有操作系统的编译器的可能性,其操作系统的字符集过于陈旧,以至于它不一定具有C或C++需要表达整个语言的所有字符. .
此外,它在IOCCC中提供了良好的条目.
我认为这是因为这个星球上的一些键盘可能没有'#'和'{'等键.
c/c ++中的有向图和三字图来自CDC6000(60位),Univac 1108(36位),DECsystem 10和20系统(36位)使用的六位字符集的日子,每个字符集使用专有的64字符设置与ASA X3.4-1963不兼容(现在称为ANSI X3.4-1963"7位美国国家信息交换标准代码").最新版本是ANSI X3.4-1986.由于这些系统无法代表所有96个图形代码点,因此省略了许多.此外,X3.4与其他国家标准协会(GBR,GER,ITA等)协调,X3.4中的代码点被指定为国家替代字符 - 最明显的例子是Britsh Pound的#符号(显而易见,因为#字符的名称是"英镑符号",因为它是美国商业中的常规用法 - 在Twitter发展之前),而'{''}也被指定为国家替代字符.因此,引入有向图以便为那些不能表示字符的计算机系统提供机制,并且还为数据终端设备提供机制,该数据终端设备将国家替换字符分配给冲突的代码点.Di/Tri-graphs已经成为计算历史的一个古老的工件(这些天没有在计算机科学中教授过) - 关于这个主题的详尽论文可以在这里找到:http://citeseerx.ist.psu.edu/viewdoc/下载?DOI = 10.1.1.96.678&代表= REP1&类型= PDF