C 语言数据类型是如何被大多数计算机系统所支持?
问题
在读 K&R 版的 The C Programming Language 一书时,我在 [介绍,第 3 页] 看到这样一条说明:
因为 C 语言提供的数据类型和控制结构可以直接被大部分计算机系统所支持,所以在实现自包含程序时所需要的运行库文件一般很小。
这段黑体说明了什么?能否找到一个例子来说明 C 语言中的某种数据类型或控制结构不被某种计算机系统直接支持呢?
回答
事实上,C 语言中确实有不被直接支持的数据类型。
在许多嵌入式系统中,硬件上并没有浮点运算单元。因此,如果你写出下面的代码:
float x = 1.0f, y = 2.0f;
return x + y;
可能会被转化成下面这种形式:
unsigned x = 0x3f800000, y = 0x40000000;
return _float_add(x, y);
然后编译器或标准库必须提供'floatadd()'的具体实现,这会占用嵌入式系统的内存空间。依此去计算代码在某个微型系统(译者注:也就是指微型嵌入式系统)的实际字节数,也会发现有所增加。
另一个常见的例子是 64 位整型数(C 语言标准中'long long'类型是 1999 年之后才出现的),这种类型在 32 位系统上也不能直接使用。古董级的 SPARC 系统则不支持整型乘法,所以在运行时必须提供乘法的实现。当然,还有一些其它例子。
其它语言
相比起来,其它编程语言有更加复杂的基本类型。
比如,Lisp 中的 symbol 需要大量的运行时实现支持,就像 Lua 中的 table、Python 中的 string、Fortran 中的 array,等等。在 C 语言中等价的类型通常要么不属于标准库(C 语言没有标准 symbol 或 table),要么更加简单,而且并不需要那么多的运行时支持(C 语言中的 array 基本上就是指针,以 NULL 结尾的字符串实现起来也很简单)。
控制结构
异常处理是 C 语言中没有的一种控制结构。非局部的退出只有'setjmp()'和'longjmp()'两种,只能提供保存和恢复某些部分的处理器状态。相比之下,C++运行时环境必须先遍历函数调用栈,然后调用析构函数和异常处理函数。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: CSS 和 CSS 预处理器简介
下一篇: 彻底找到 Tomcat 启动速度慢的元凶
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论