C89、C99和C11标准之间的差异

收集了大部分差异特性,不断完善和补充,有遗漏的地方欢迎留言补正。
一、C99针对C89的改变
1.增加了restrict指针
通过restrict修饰指针,可以确保两个指针不能指向同样的内存空间。
如memcpy函数在C99标准下的定义为

void *memcpy(void *restrict s1, const void *restrict s2,size_t size);
1
2.增加inline关键字
和C++一样,通过inline函数可以创建内联函数,提高代码的编译效率和执行效率。

3.新的数据类型
C99标准支持一些新的数据类型
布尔类型:bool
复数类型:float_Complex; float_Imaginary; double_Complex; double_Imaginary; long double_Complex; long double_Imaginary
整型类型:long long int; unsigned long long int

4.扩展了数组的功能
C99中允许用运行时确定值的变量声明数组长度。
C99中允许对数组元素进行修饰,但是修饰只有装饰提示效果,不能真正改变元素的类型或特性。
支持的修饰符有restrict,volatile,const和static
如:

int a[static 3]
1
C99中允许数组进行索引键值对式初始化
如:

int x[10] = {[0] = 10, [5] = 30, [7] = 40};
1
5.单行注释
正式引入单行注释符号“//”

6.函数的声明与实现可以分离
7.for循环的改进
C99标准允许在for循环的头部声明变量,变量的作用域在循环体内。
如:

for(int i=0; i<10; i++){
// do someting …
}
1
2
3
8.复合赋值
C99中,复合赋值中,可以指定对象类型的数组、结构或联合表达式。当使用复合赋值时,应在括弧
内指定类型,后跟由花括号围起来的初始化列表;若类型为数组,则不能指定数组的大小。
如:

double *fp = (double[]) {1.1, 2.2, 3.3};
1
9.零元素数组
C99中,结构体中的最后一个元素允许是未知大小的数组,这就叫做柔性数组成员,但结构中的柔性数组成员前面必须至少一个其他成员。

10.printf()和scanf()函数系列的增强
C99中printf()和scanf()函数系列引进了处理long long int和unsigned long long int数据类型
的特性。long long int 类型的格式修饰符是ll。在printf()和scanf()函数中,ll适用于d, i, o, u 和x
格式说明符。另外,C99还引进了hh修饰符。当使用d, i, o, u和x格式说明符时,hh用于指定char
型变元。ll和hh修饰符均可以用于n说明符。
格式修饰符a和A用在printf()函数中时,结果将会输出十六进制的浮点数。格式如下:[-]0xh, hhhhp + d 使用A格式修饰符时,x和p必须是大写。A和a格式修饰符也可以用在scanf()函数中,用于读取
浮点数。调用printf()函数时,允许在%f说明符前加上l修饰符,即%lf,但不起作用。

11.新增了函数库
C89的库
<assert.h> 定义宏assert()
<ctype.h> 字符处理
<errno.h> 错误报告
<float.h> 定义与实现相关的浮点值勤
<limits.h> 定义与实现相关的各种极限值
<locale.h> 支持函数setlocale()
<math.h> 数学函数库使用的各种定义
<setjmp.h> 支持非局部跳转
<signal.h> 定义信号值
<stdarg.h> 支持可变长度的变元列表
<stddef.h> 定义常用常数
<stdio.h> 支持文件输入和输出
<stdlib.h> 其他各种声明
<string.h> 支持串函数
<time.h> 支持系统时间函数

C99增加的库
<complex.h> 支持复数算法
<fenv.h> 给出对浮点状态标记和浮点环境的其他方面的访问
<inttypes.h> 定义标准的、可移植的整型类型集合。也支持处理最大宽度整数的函数(常见)
<iso646.h> 首先在此1995年第一次修订时引进,用于定义对应各种运算符的宏
<stdbool.h> 支持布尔数据类型类型。定义宏bool,以便兼容于C++
<stdint.h> 定义标准的、可移植的整型类型集合。该文件包含在<inttypes.h>中(常见)
<tgmath.h> 定义一般类型的浮点宏
<wchar.h> 首先在1995年第一次修订时引进,用于支持多字节和宽字节函数
<wctype.h> 首先在1995年第一次修订时引进,用于支持多字节和宽字节分类函数

12.__func__预定义标识符
用于指出__func__所存放的函数名,类似于字符串赋值。

13.预处理程序的修改
变元列表
宏可以带变元,在宏定义中用省略号(…)表示。内部预处理标识符__VA_ARGS__决定变元将在何
处得到替换。
如:

#define MySum(…) sum(VA_ARGS) 语句MySum(k,m,n);
1
将被转换成:

sum(k, m, n);
1
变元还可以包含变元。
如:

#define compare(compf, …)compf(VA_ARGS) 其中的compare(strcmp,“small”, “large”);
1
将替换成:

strcmp(“small”,“large”);
1
_Pragma运算符
C99引入了在程序中定义编译指令的另外一种方法:_Pragma运算符。格式如下:

_Pragma(“directive”)
1
其中directive是要满打满算的编译指令。_Pragma运算符允许编译指令参与宏替换。
内部编译指令
STDCFP_CONTRACT ON/OFF/DEFAULT 若为ON,浮点表达式被当做基于硬件方式处理的独立单元。默认值是定义的工具。
STDCFEVN_ACCESS ON/OFF/DEFAULT 告诉编译程序可以访问浮点环境。默认值是定义的工具。
STDC CX_LIMITED_RANGE ON/OFF/DEFAULT 若值为ON,相当于告诉编译程序某程序某些含
有复数的公式是可靠的。默认是OFF。

新增的内部宏
__STDC_HOSTED 若操作系统存在,则为1
__STDC_VERSION 199991L或更高。代表C的版本
__STDC_IEC_599 若支持IEC 60559浮点运算,则为1
__STDC_IEC_599_COMPLEX 若支持IEC 60599复数运算,则为1
__STDC_ISO_10646 由编译程序支持,用于说明ISO/IEC 10646标准的年和月格式:yyymmmL

14.其它特性的改动
放宽的转换限制
限制             C89标准  C99标准
数据块的嵌套层数       15     127
条件语句的嵌套层数      8      63
内部标识符中的有效字符个数  31     63
外部标识符中的有效字符个数  6      31
结构或联合中的成员个数    127    1023
函数调用中的参数个数     31     127

不再支持隐含式的int规则
删除了隐含式函数声明
对返回值的约束
C99中,非空类型函数必须使用带返回值的return语句.

扩展的整数类型
扩展类型 含义
int16_t 整数长度为精确16位
int_least16_t 整数长度为至少16位
int_fast32_t 最稳固的整数类型,其长度为至少32位
intmax_t 最大整数类型
uintmax_t 最大无符号整数类型

对整数类型提升规则的改进
C89中,表达式中类型为char,short int或int的值可以提升为int或unsigned int类型.
C99中,每种整数类型都有一个级别.例如:long long int 的级别高于int, int的级别高于char等.在表达式中,其级别低于int或unsigned int的任何整数类型均可被替换成int或unsigned int类型.

原文链接:https://blog.csdn.net/qq_36429002/article/details/100183508
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值