Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1744399
  • 博文数量: 263
  • 博客积分: 1218
  • 博客等级: 少尉
  • 技术积分: 2862
  • 用 户 组: 普通用户
  • 注册时间: 2011-06-19 02:33
文章分类

全部博文(263)

文章存档

2020年(12)

2019年(2)

2018年(10)

2016年(1)

2015年(20)

2014年(115)

2013年(46)

2012年(37)

2011年(20)

分类: C/C++

2014-09-30 22:35:55

标准库的string类提供了3个成员函数来从一个string得到c类型的字符数组:c_str()、data()、copy(p,n)。

1. c_str():生成一个const char*指针,指向以空字符终止的数组。

注:

①这个数组的数据是临时的,当有一个改变这些数据的成员函数被调用后,其中的数据就会失效。因此要么现用先转换,要么把它的数据复制到用户自己可以管理的内存中。注意。看下例:

点击(此处)折叠或打开

  1. const char* c;
  2. string s="1234";
  3. c = s.c_str();
  4. cout<<c<<endl; //输出:1234
  5. s="abcd";
  6. cout<<c<<endl; //输出:abcd

上面如果继续用c指针的话,导致的错误将是不可想象的。就如:1234变为abcd

其实上面的c = s.c_str(); 不是一个好习惯。既然c指针指向的内容容易失效,我们就应该按照上面的方法,那怎么把数据复制出来呢?这就要用到strcpy等函数(推荐)。


点击(此处)折叠或打开

  1. //const char* c; //
  2. //char* c; //
  3. //char c[20];
  4. char* c=new char[20];
  5. string s="1234";
  6. //c = s.c_str();
  7. strcpy(c,s.c_str());
  8. cout<<c<<endl; //输出:1234
  9. s="abcd";
  10. cout<<c<<endl; //输出:1234
注意:不能再像上面一样①所示了,const还怎么向里面写入值啊;也不能②所示,使用了未初始化的局部变量“c”,运行会出错的 。

 ② c_str()返回一个客户程序可读不可改的指向字符数组的指针,不需要手动释放或删除这个指针。


2. data():与c_str()类似,但是返回的数组不以空字符终止。( C99是不以空字符终止的. 但C++11中返回的是以空字符结尾的与c_str()一样. 可查MSDN)

 3. copy(p,n,size_type _Off = 0):从string类型对象中至多复制n个字符到字符指针p指向的空间中。默认从首字符开始,但是也可以指定,开始的位置(记住从0开始)。返回真正从对象中复制的字符。------用户要确保p指向的空间足够保存n个字符。

点击(此处)折叠或打开

  1. // basic_string_copy.cpp
  2. // compile with: /EHsc /W3
  3. #include <string>
  4. #include <iostream>
  5.  
  6. int main( )
  7. {
  8.     using namespace std;
  9.     string str1 ( "1234567890" );
  10.     basic_string <char>::iterator str_Iter;
  11.     char array1 [ 20 ] = { 0 };
  12.     char array2 [ 10 ] = { 0 };
  13.     basic_string <char>:: pointer array1Ptr = array1;
  14.     basic_string <char>:: value_type *array2Ptr = array2;
  15.  
  16.     cout << "The original string str1 is: ";
  17.     for ( str_Iter = str1.begin( ); str_Iter != str1.end( ); str_Iter++ )
  18.         cout << *str_Iter;
  19.     cout << endl;
  20.  
  21.     basic_string <char>:: size_type nArray1;
  22.     // Note: string::copy is potentially unsafe, consider
  23.     // using string::_Copy_s instead.
  24.     nArray1 = str1.copy ( array1Ptr , 12 ); // C4996
  25.     cout << "The number of copied characters in array1 is: "
  26.         << nArray1 << endl;
  27.     cout << "The copied characters array1 is: " << array1Ptr << endl;
  28.  
  29.     basic_string <char>:: size_type nArray2;
  30.     // Note: string::copy is potentially unsafe, consider
  31.     // using string::_Copy_s instead.
  32.     nArray2 = str1.copy ( array2Ptr , 5 , 6 ); // C4996
  33.     cout << "The number of copied characters in array2 is: "
  34.         << nArray2 << endl;
  35.     cout << "The copied characters array2 is: " << array2Ptr << endl;
  36.      
  37.     ////注意一定要使array3有足够的空间
  38.     //char array3[5]={0};
  39.     //basic_string<char>::pointer array3Ptr=array3;
  40.     //basic_string<char>::size_type nArray3;
  41.     //nArray3 = str1.copy(array3,9); //错误!!!!
  42.     //cout<<"The number of copied characters in array3 is: "
  43.     // <<nArray3<<endl;
  44.     //cout<<"The copied characters array3 is: "<<array3Ptr<<endl;
  45.      
  46. }


 上面最后注释掉的部分,虽然编译没有错误,但是运行时会产生错误:Stack around the variable 'array3' was corrupted.

转: http://www.cnblogs.com/qlwy/archive/2012/03/25/2416937.html




阅读(1392) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

xuebabybaby2014-09-30 23:04:17

C风格字符串与标准库类型string性能比较(C-style character string and std::string)
《c++primer》上提到,推荐在c++程序中使用string,而不使用从C集成而来的风格字符串,原因如下:
(1)使用string安全,不用程序员管理内存分配释放
(2)程序写起来比较简洁、方便、不容易出错
(3)效率比较高

转:http://blog.csdn.net/husongchao/article/details/6336888