分辨C和C++的标准原型

王朝c/c++·作者佚名  2006-01-06
窄屏简体版  字體: |||超大  

尽管标准的C通常在C和C++中的功能相同,但是一些函数在每个语言中有不同的符号差。标准的函数他们的符号差不同的是:strchr(), strpbrk(), strrchr(), strstr(), 和 memchr(),字符副本也和它们一样:wcschr(), wcspbrk(), wcsrchr(), wcsstr(), wmemchr()。它们中所有的标准头文件〈cstring〉和〈string.h〉都被定义。这些差异可以被忽略,但是在在移植C代码到C++编译器时候非常重要。

下面我们来看看strstr(),在C中,这个函数是下面的原型:

char * strstr(const char*s1, const char *s2);

在C++中,这个函数有两个不同的原型,它们中的任何一个在C中的版本都不一样。

char * strstr(char *s1, const char * s2);

const char * strstr(const char * s1, const char *s2);

下面让我们在看另外一个例子:strpbrk()。在C中,它的形式是这个样子:

char * strpbrk(const char *s1, const char *s2);

在C++中,它有两个不同的符号差:

char * strpbrk(char *s1, const char *s2);

const char * strpbrk(const char *s1, const char *s2);

现在你看到了一个模式了吧?当这些函数其中一个的C版本作为一个参数获得“const X”并返回"X *"的时候,C++定义的两个版本:一个获得"X *"并返回"X *"另外一个获得“const X”并返回"X *"。C++的用户使用重载来提高类型的安全性。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航