#include<iostream>
#include<vector>
#include<set>
#include<list>
#include<queue>
#include<deque>
#include<limits.h>
using namespace std;
//vector作为桥梁连接STL容器和C的API
void doSomething(const int* pInts, size_t numInts)
{
}
void doSomething(const char* pString)
{
}
/*
该函数是以一个指向最多有arraySize个double数组,并向该数组写入数据,并返回写入的double数据的个数,这个数小于arraySize
*/
size_t fillArray(double *pArray, size_t arraySize)//size_t 是unsigned int
{
return 100;
}
size_t fillString(char* pArray, size_t arraySize)
{
return 100;
}
int main()
{
cout << numeric_limits<size_t>::max() << endl;
/*
把vector string数据传给旧的c API
1、如果想把vector 中的数据以数组的形式传给某个函数,只需要使用 &v[0] 就行
注意v.begin()返回的是迭代器,不是指针,如果你想用v.begin(),你可以使用&*v.begin(),因为这样是和&v[0]
产生同样的效果。
2、对于string ,可以使用s.c_str();而不能使用和vector相同的方法,原因如下:
<1>string中的数据不一定存储在连续的内存中,
<2>string的内部表示不一定是以空字符结尾的
C_str()函数返回了一个指向字符串的值的指针,而且改值能用于C
*/
vector<int> v;
if (!v.empty())//&v[0]试图产生一个指针,而该指针的指向的东西并不存在,这不好,所以需要判断。
{
doSomething(&v[0], v.size());
}
/*
以下这一小段代码不知道是否正确,因为书上也没说清楚,但是我认为可以这么写
string本身包含空字符没关系,但是对基于char*的 C API是不行的
c_str所产生的指针并不一定指向字符串的内部表示,他返回的指针可能是指向字符串数据的一个不可修改的拷贝
*/
string s("哈哈");
doSomething(s.c_str());
//想用C API的元素初始化一个vector
vector<double> vd(100);
vd.reserve(fillArray(&vd[0], 100));
//想用C的api初始化一个string
vector<char> vc(100);
vd.reserve(fillArray(&vd[0], 100));
string s1(vc.begin(), vc.end());
//实际上,先让C 的API 将数据写入一个vector中,然后把数据复制到相应的STL容器中总是可行的
vector<double> vdd(100);
vd.reserve(fillArray(&vdd[0], vd.size()));
deque<double> d(vdd.begin(), vdd.end());
list<double> l(vd.begin(), vd.end());
set<double> sm(vdd.begin(), vdd.end());
//而且意味着,除了vector和string以外的其他容器也能把它们的数据传给C API,只需将它们中的元素复制给vector,然后传给该API
set<int> intSet;
vector<int> vv(intSet.begin(), intSet.end());
if (!v.empty())
{
doSomething(&v[0], vv.size());
}
return 0;
}
effective stl 第16条: 了解如何把vector和string数据传给旧的API
最新推荐文章于 2022-04-24 17:22:50 发布