好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

C99标准的新特性(相对于Ansi C)

[转]C99标准的新特性(相对于Ansi C)

C99是在C89(Ansi C)的基础上发展起来的,增加了基本数据类型,关键字 ,和一些系统函数等。

其实在初学阶段C89(ANSI C)和C99的区别是不易察觉的,所以不必太在意这个。

C99有一部分是对于大字符集的优化(很多资料上写的是ANSI标准化),还加入了一些数据库函数,是C89之后的标 准,我们用的C是C89标准的,C++是C89编写的,目前的C99标准其实在以前的编译器中就或多或少的支持了,目前完全支持的有这些:MinGW、 Borland C++、dev-C++。

在C99中包括的特性有:

对编译器限制增加了,比如源程序每行要求至少支持到 4095 字节,变量名函数名的要求支持到 63 字节 (extern 要求支持到 31) 预处理增强了。例如: 宏支持取参数 #define Macro(...) __VA_ARGS__ 使用宏的时候,参数如果不写,宏里用 #,## 这样的东西会扩展成空串。(以前会出错的) 支持 // 行注释(这个特性实际上在C89的很多编译器上已经被支持了) 增加了新关键字 restrict, inline, _Complex, _Imaginary, _Bool 支持 long long, long double _Complex, float _Complex 这样的类型 支持 <: :> <% %> %: %:%: ,等等奇怪的符号替代,D&E 里提过这个 支持了不定长的数组。数组的长度就可以用变量了。声明类型的时候呢,就用 int a[*] 这样的写法。不过考虑到效率和实现,这玩意并不是一个新类型。所以就不能用在全局里,或者 struct union 里面,如果你用了这样的东西,goto 语句就受限制了。 变量声明不必放在语句块的开头,for 语句提倡这么写 for(int i=0;i<100;++i) 就是说,int i 的声明放在里面,i 只在 for 里面有效。(VC没有遵守这条标准,i 在 for 外也有效) 当一个类似结构的东西需要临时构造的时候,可以用 (type_name){.numberN=valueN, .numberK=valueK,...} 这有点像 C++ 的构造函数 初始化结构的时候现在可以这样写:
                struct {int a[3], b;} hehe[] =            { [0].a = {1}, [1].a = 2 };
                struct {int a, b, c, d;} hehe =            { .a = 1, .c = 3, 4, .b = 5}            // 3,4 是对 .c,.d 赋值的
字符串里面,\u 支持 unicode 的字符 支持 16 进制的浮点数的描述 所以 printf scanf 的格式化串多支持了 ll / LL (VC6 里用的 I64) 对应新的 long long 类型。 浮点数的内部数据描述支持了新标准,这个可以用 #pragma 编译器指定 除了已经有的 __line__ __file__ 以外,又支持了一个 __func__ 可以得到当前的函数名 对于非常数的表达式,也允许编译器做化简 修改了对于 / % 处理负数上的定义,比如老的标准里 -22 / 7 = -3, -22 % 7 = -1 而现在 -22 / 7 = -4, -22 % 7 = 6 取消了不写函数返回类型默认就是 int 的规定 允许 struct 定义的最后一个数组写做 [] 不指定其长度描述 const const int i; 将被当作 const int i; 处理 增加和修改了一些标准头文件, 比如定义 bool 的 <stdbool.h> 定义一些标准长度的 int 的 <inttypes.h> 定义复数的 <complex.h> 定义宽字符的 <wctype.h> 有点泛型味道的数学函数 <tgmath.h> 跟浮点数有关的 <fenv.h>。<stdarg.h> 里多了一个 va_copy 可以复制 ... 的参数。<time.h> 里多了个 struct tmx 对 struct tm 做了扩展 输入输出对宽字符还有长整数等做了相应的支持

相对于c89的变化包括

1、增加restrict指针
C99中增加了公适用于指针的restrict类型修饰符,它是初始访问指针所指对象的惟一途径,因此只有借 助restrict指针表达式才能访问对象。restrict指针指针主要用做函数变元,或者指向由malloc()函数所分配的内存变量。 restrict数据类型不改变程序的语义。
如果某个函数定义了两个restrict指针变元,编译程序就假定它们指向两个不同的对象,memcpy()函数就是restrict指针的一个典型应用示例。C89中memcpy()函数原型如下:

代码:

  void *memcpy (void *s1, const void *s2, size_t size);

       如果s1和s2所指向的对象重叠,其操作就是未定义的。memcpy()函数只能用于不重叠的对象 。C99中memcpy()函数原型如下:

代码:

    void *memcpy(void *restrict s1, const void *restrict s2,size_t size);

不再支持隐含式的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类型.

但是各个公司对C99的支持所表现出来的兴趣不同。当GCC和其它一些商业编译器支持C99的大部分特性的时候,微软和Borland却似乎对此不感兴趣。

C/C++ 基础-头文件的作用

头文件的作用
作者:林锐

早期的编程语言如 Basic、Fortran 没有头文件的概念,C++/C 语言的初学者虽然会

用使用头文件,但常常不明其理。这里对头文件的作用略作解释:

(1)通过头文件来调用库功能。在很多场合,源代码不便(或不准)向用户公布,只要向用户

提供头文件和二进制的库即可。用户只需要按照头文件中的接口声明来调用库功能,而不

必关心接口怎么实现的。编译器会从库中提取相应的代码。

(2)头文件能加强类型安全检查。如果某个接口被实现或被使用时,其方式与头文件中的声明

不一致,编译器就会指出错误,这一简单的规则能大大减轻程序员调试、改错的负担。

     可将头文件保存于 include 目录,将定义文件保存于 source 目录(可以是多级
目录)。

  如果某些头文件是私有的,它不会被用户的程序直接引用,则没有必要公开其“声明”。为了加强

信息隐藏,这些私有的头文件可以和定义文件存放于同一个目录。

查看更多关于C99标准的新特性(相对于Ansi C)的详细内容...

  阅读:39次

上一篇: yaml

下一篇:xpad a note tool for ubuntu