C/C++关于string.h头文件和string类

本文详细解析了C++中不同字符串处理方式的区别,包括C风格字符串处理函数如strcmp()的使用,以及C++标准库string类的功能。介绍了如何避免命名冲突,并解释了string.h与string之间的差异。

 学习C语言时,用字符串的函数例如stpcpy()、strcat()、strcmp()等,要包含头文件string.h
学习C++后,C++有字符串的标准类string,string类也有很多方法,用string类时要用到string.h头文件。
我现在看vc的书上也有CString类,这个要包含什么,怎么用?

我现在很迷惑,这两个 string.h有什么区别。是怎么回事

 

且看一:

这两个一个是标准C库的,定义了一些字符串的处理函数.一个是标准C++库的,定义了标准C++的std::string类.
要用这个类要包含头文件<string>...如下;
#include <string>
using namespace std;//关于名字空间有兴趣自己查去,一般用标准库这句就行了

当然标准C库也是标准C++库的一部分,要用标准C库里的处理函数...如下:
#include <string.h>//所以你用这句包含的是标准C库的头文件
...或者用如下C++风格的,它们是等价的,不过比较推荐:
#include <cstring>
using namespace std;

CString类是MFC的类,...不搞Windows MFC编程用不到

 

且看二:

 

 

#include < string .h >

void main()
{
string aaa = " abcsd d " ;
printf( " looking for abc from abcdecd %s/n " ,
(strcmp(aaa, " abc " )) ? " Found " : " Not Found " );

}

  不能正确执行,提示说是string类型没有定义

  而下面:

#include < string >

using namespace std;
void main()
{
string aaa = " abcsd d " ;
printf( " looking for abc from abcdecd %s/n " ,
(strcmp(aaa, " abc " )) ? " Found " : " Not Found " );
}

  这里的string编译器就认识了,但是strcmp就不认识了呢?

  一般一个C++的老的带“。h”扩展名的库文件,比如iostream.h,在新标准后的标准库中都有一个不带“。h”扩展名的相对应,区别除了后者的好多改进之外,还有一点就是后者的东东都塞进了“std”名字空间中。

  但唯独string特别。

  问题在于C++要兼容C的标准库,而C的标准库里碰巧也已经有一个名字叫做“string.h”的头文件,包含一些常用的C字符串处理函数,比如楼主提到的strcmp.

  这个头文件跟C++的string类半点关系也没有,所以<string>并非<string.h>的“升级版本”,他们是毫无关系的两个头文件。

  要达到楼主的目的,比如同时:

#include < string .h >
#include < string >
using namespace std;

或者

 

#include < cstring >
#include < string >

  其中<cstring>是与C标准库的<string.h>相对应,但裹有std名字空间的版本。

  笑谈(来自高质量++)

  C++标准库很大。非常大。难以置信的大。怎么个大法?这么说吧:在C++标准中,关于标准库的规格说明占了密密麻麻300 多页,这还不包括标准C 库,后者只是"作为参考"(老实说,原文就是用的这个词)包含在C++库中。当然,并非总是越大越好,但在现在的情况下,确实越大越好,因为大的库会包含大量的功能。标准库中的功能越多,开发自己的应用程序时能借助的功能就越多。C++库并非提供了一切(很明显的是,没有提供并发和图形用户接口的支持),但确实提供了很多。几乎任何事你都可以求助于它。在归纳标准库中有些什么之前,需要介绍一下它是如何组织的。因为标准库中东西如此之多,你(或象你一样的其他什么人)所选择的类名或函数名就很有可能和标准库中的某个名字相同。为了避免这种情况所造成的名字冲突,实际上标准库中的一切都被放在名字空间std 中(参见条款28)。但这带来了一个新问题。无数现有的C++代码都依赖于使用了多年的伪标准库中的功能,例如,声明在<iostream.h>,<complex.h>,<limits.h>等头文件中的功能。现有软件没有针对使用名字空间而进行设计,如果用std 来包装标准库导致现有代码不能用,将是一种可耻行为。(这种釜底抽薪的做法会让现有代码的程序员说出比"可耻" 更难听的话)慑于被激怒的程序员会产生的破坏力,标准委员会决定为包装了std 的那部分标准库构件创建新的头文件名。生成新头文件的方法仅仅是将现有C++头文件名中的。h 去掉,方法本身不重要,正如最后产生的结果不一致也并不重要一样。所以<iostream.h>变成了<iostream>,<complex.h>变成了<complex>,等等。对于C 头文件,采用同样的方法,但在每个名字前还要添加一个c.所以C 的<string.h>变成了<cstring>,<stdio.h>变成了<cstdio>,等等。最后一点是,旧的C++头文件是官方所反对使用的(即,明确列出不再支持),但旧的C 头文件则没有(以保持对C 的兼容性)。实际上,编译器制造商不会停止对客户现有软件提供支持,所以可以预计,旧的C++头文件在未来几年内还是会被支持。

 

  所以,实际来说,下面是C++头文件的现状:

  旧的C++头文件名如<iostream.h>将会继续被支持,尽管它们不在官方标准中。这些头文件的内容不在名字空间std 中。

  新的C++头文件如<iostream>包含的基本功能和对应的旧头文件相同,但头文件的内容在名字空间std 中。(在标准化的过程中,库中有些部分的细节被修改了,所以旧头文件和新头文件中的实体不一定完全对应。)

  标准C 头文件如<stdio.h>继续被支持。头文件的内容不在std 中。

  具有C 库功能的新C++头文件具有如<cstdio>这样的名字。它们提供的内容和相应的旧C 头文件相同,只是内容在std 中。

  所有这些初看有点怪,但不难习惯它。最大的挑战是把字符串头文件理清楚:

  <string.h>是旧的C 头文件,对应的是基于char*的字符串处理函数;

  <cstring>是对应于旧C 头文件的std 版本;

  <string>是包装了std 的C++头文件,对应的是新的string 类。

  如果能掌握这些(我相信你能),其余的也就容易了。

 

 

 

### C++ 中 `bits/stdc++.h` 头文件的作用解释 #### 简介 `bits/stdc++.h` 是一个特殊的头文件,在某些编译器环境中被提供给开发者作为便捷工具。此头文件包含了几乎所有常用的C++标准库功能,使得编写代码更加简便快捷[^1]。 #### 功能特性 该头文件集成了大量的STL组件其他常用的功能模块,具体来说: - **输入输出流**:如 `<iostream>` 提供了 cin cout 的操作接口; - **容器**:像 `<vector>`, `<list>`, `<map>` 等数据结构可以直接使用而无需单独引入相应头文件; - **算法模板**:例如 `<algorithm>` 包含了许多实用的泛型算法,如 sort(), find() 等; - **其他辅助库**:还包括诸如 `<string>`, `<cmath>`, `<ctime>` 这样的基础库支持字符串处理、数学运算及时钟时间获取等功能; 因此,在竞赛编程或其他快速原型开发场景下,只需简单地加入这唯一的一条预处理器指令即可获得全面的标准库访问权限,极大地方便了程序员的工作流程[^2]。 然而值得注意的是,并不是所有的平台都默认提供了这样的便利性头文件,特别是在正式的产品级软件工程实践中,通常建议显式指定所需的各个特定头文件来保持项目的清晰度与可移植性[^3]。 ```cpp #include <bits/stdc++.h> using namespace std; int main(){ vector<int> vec = {4, 7, 2}; // 使用内置排序函数 sort(vec.begin(), vec.end()); for(auto &val : vec){ cout << val << " "; } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值