亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

string中c_str(),data(),copy(p,n)函數(shù)的用法總結(jié)

 更新時(shí)間:2013年09月10日 09:37:58   作者:  
以下是對(duì)string中c_str(),data(),copy(p,n)函數(shù)的用法進(jìn)行了詳細(xì)的介紹,需要的朋友可以過(guò)來(lái)參考下

標(biāo)準(zhǔn)庫(kù)的string類提供了3個(gè)成員函數(shù)來(lái)從一個(gè)string得到c類型的字符數(shù)組:c_str()、data()、copy(p,n)。

1. c_str():生成一個(gè)const char*指針,指向以空字符終止的數(shù)組。

注:
這個(gè)數(shù)組的數(shù)據(jù)是臨時(shí)的,當(dāng)有一個(gè)改變這些數(shù)據(jù)的成員函數(shù)被調(diào)用后,其中的數(shù)據(jù)就會(huì)失效。因此要么現(xiàn)用先轉(zhuǎn)換,要么把它的數(shù)據(jù)復(fù)制到用戶自己可以管理的內(nèi)存中。注意。看下例:

復(fù)制代碼 代碼如下:

const char* c;
string s="1234";
c = s.c_str(); 
cout<<c<<endl; //輸出:1234
s="abcd";
cout<<c<<endl; //輸出:abcd

上面如果繼續(xù)用c指針的話,導(dǎo)致的錯(cuò)誤將是不可想象的。就如:1234變?yōu)閍bcd

其實(shí)上面的c = s.c_str(); 不是一個(gè)好習(xí)慣。既然c指針指向的內(nèi)容容易失效,我們就應(yīng)該按照上面的方法,那怎么把數(shù)據(jù)復(fù)制出來(lái)呢?這就要用到strcpy等函數(shù)(推薦)。

復(fù)制代碼 代碼如下:

//const char* c; //①
//char* c;       //②
//char c[20]; 
char* c=new char[20];
string s="1234";
//c = s.c_str(); 
strcpy(c,s.c_str());
cout<<c<<endl; //輸出:1234
s="abcd";
cout<<c<<endl; //輸出:1234

注意:不能再像上面一樣①所示了,const還怎么向里面寫入值?。灰膊荒堍谒?,使用了未初始化的局部變量“c”,運(yùn)行會(huì)出錯(cuò)的 。

c_str()返回一個(gè)客戶程序可讀不可改的指向字符數(shù)組的指針,不需要手動(dòng)釋放或刪除這個(gè)指針。

2. data():與c_str()類似,但是返回的數(shù)組不以空字符終止。

3. copy(p,n,size_type _Off = 0):從string類型對(duì)象中至多復(fù)制n個(gè)字符到字符指針p指向的空間中。默認(rèn)從首字符開始,但是也可以指定,開始的位置(記住從0開始)。返回真正從對(duì)象中復(fù)制的字符。------用戶要確保p指向的空間足夠保存n個(gè)字符。

復(fù)制代碼 代碼如下:

// basic_string_copy.cpp
// compile with: /EHsc /W3
#include <string>
#include <iostream>

int main( )
{
    using namespace std;
    string str1 ( "1234567890" );
    basic_string <char>::iterator str_Iter;
    char array1 [ 20 ] = { 0 };
    char array2 [ 10 ] = { 0 };
    basic_string <char>:: pointer array1Ptr = array1;
    basic_string <char>:: value_type *array2Ptr = array2;

    cout << "The original string str1 is: ";
    for ( str_Iter = str1.begin( ); str_Iter != str1.end( ); str_Iter++ )
        cout << *str_Iter;
    cout << endl;

    basic_string <char>:: size_type nArray1;
    // Note: string::copy is potentially unsafe, consider
    // using string::_Copy_s instead.
    nArray1 = str1.copy ( array1Ptr , 12 );  // C4996
    cout << "The number of copied characters in array1 is: "
        << nArray1 << endl;
    cout << "The copied characters array1 is: " << array1Ptr << endl;

    basic_string <char>:: size_type nArray2;
    // Note: string::copy is potentially unsafe, consider
    // using string::_Copy_s instead.
    nArray2 = str1.copy ( array2Ptr , 5 , 6  );  // C4996
    cout << "The number of copied characters in array2 is: "
        << nArray2 << endl;
    cout << "The copied characters array2 is: " << array2Ptr << endl;

    ////注意一定要使array3有足夠的空間
    //char array3[5]={0};
    //basic_string<char>::pointer array3Ptr=array3;
    //basic_string<char>::size_type nArray3;
    //nArray3 = str1.copy(array3,9); //錯(cuò)誤?。。。?
    //cout<<"The number of copied characters in array3 is: "
    //  <<nArray3<<endl;
    //cout<<"The copied characters array3 is: "<<array3Ptr<<endl;
}

上面最后注釋掉的部分,雖然編譯沒(méi)有錯(cuò)誤,但是運(yùn)行時(shí)會(huì)產(chǎn)生錯(cuò)誤:Stack around the variable 'array3' was corrupted.

相關(guān)文章

  • 詳解C語(yǔ)言中動(dòng)態(tài)內(nèi)存管理及柔性數(shù)組的使用

    詳解C語(yǔ)言中動(dòng)態(tài)內(nèi)存管理及柔性數(shù)組的使用

    這篇文章主要為大家詳細(xì)介紹一下C語(yǔ)言中動(dòng)態(tài)內(nèi)存管理以及柔性數(shù)組的使用方法,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)C語(yǔ)言有一定的幫助,需要的可以參考一下
    2022-07-07
  • C語(yǔ)言字符串旋轉(zhuǎn)問(wèn)題的深入講解

    C語(yǔ)言字符串旋轉(zhuǎn)問(wèn)題的深入講解

    這篇文章主要給大家介紹了關(guān)于C語(yǔ)言字符串旋轉(zhuǎn)問(wèn)題的相關(guān)資料,文中給出了詳細(xì)的實(shí)現(xiàn)方法,并對(duì)每種方法進(jìn)行了分析和示例代碼,需要的朋友可以參考下
    2021-09-09
  • C++深入講解類與對(duì)象之OOP面向?qū)ο缶幊膛c封裝

    C++深入講解類與對(duì)象之OOP面向?qū)ο缶幊膛c封裝

    學(xué)習(xí)過(guò)C語(yǔ)言的小伙伴知道:C語(yǔ)言是面向過(guò)程的,關(guān)注的是過(guò)程,分析出求解問(wèn)題的步驟,通過(guò)函數(shù)調(diào)用逐步解決問(wèn)題,接下來(lái)讓我們?cè)敿?xì)的了解
    2022-05-05
  • C++ 函數(shù)重載詳情介紹

    C++ 函數(shù)重載詳情介紹

    這篇文章主要介紹了C++ 函數(shù)重載詳情,函數(shù)重載還有一個(gè)別名叫函數(shù)多態(tài),函數(shù)多態(tài)是C++在C語(yǔ)言基礎(chǔ)上的新特性,它可以讓我們使用多個(gè)同名函數(shù),下面來(lái)看看文章具體內(nèi)容的介紹
    2021-11-11
  • C語(yǔ)言封裝函數(shù)字符串練習(xí)匯總分享

    C語(yǔ)言封裝函數(shù)字符串練習(xí)匯總分享

    這篇文章主要介紹了C語(yǔ)言封裝函數(shù)字符串練習(xí)匯總分享,分享內(nèi)容有字符串查找、字符串拼接、字符串轉(zhuǎn)整數(shù)等內(nèi)容,需要而小伙伴可以參考一下
    2022-03-03
  • C++ 多線程編程建議之 C++ 對(duì)多線程/并發(fā)的支持(下)

    C++ 多線程編程建議之 C++ 對(duì)多線程/并發(fā)的支持(下)

    這篇文章主要介紹的是 C++ 多線程編程建議之 C++ 對(duì)多線程/并發(fā)的支持的相關(guān)資料,承接前文 現(xiàn)代 C++ 對(duì)多線程/并發(fā)的支持,接下來(lái)我們看看回發(fā)生什么吧
    2021-10-10
  • C/C++最短路徑算法之迪杰斯特拉Dijkstra的實(shí)現(xiàn)詳解

    C/C++最短路徑算法之迪杰斯特拉Dijkstra的實(shí)現(xiàn)詳解

    Dijkstra(迪杰斯特拉)算法是典型的單源最短路徑算法,用于計(jì)算一個(gè)節(jié)點(diǎn)到其他所有節(jié)點(diǎn)的最短路徑。本文將詳解該算法的圖解與實(shí)現(xiàn),需要的可以參考一下
    2022-07-07
  • C/C++編程判斷String字符串是否包含某個(gè)字符串實(shí)現(xiàn)示例

    C/C++編程判斷String字符串是否包含某個(gè)字符串實(shí)現(xiàn)示例

    這篇文章主要為大家介紹了C++編程中判斷String字符串是否包含某個(gè)字符串的實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-11-11
  • C++實(shí)現(xiàn)LeetCode(171.求Excel表列序號(hào))

    C++實(shí)現(xiàn)LeetCode(171.求Excel表列序號(hào))

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(171.求Excel表列序號(hào)),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C語(yǔ)言指針類型與野指針引起的原因

    C語(yǔ)言指針類型與野指針引起的原因

    我們C語(yǔ)言獨(dú)一無(wú)二的特色——指針。說(shuō)起指針,可能很多人都是還沒(méi)學(xué)就已經(jīng)聽說(shuō)過(guò)其鼎鼎大名,因?yàn)橛泻芏鄠餮院屯嫘κ裁吹恼f(shuō)指針很難,其實(shí)大家大可不必有畏難情緒,指針這個(gè)東西雖然確實(shí)有一定難度,但是這是基于其優(yōu)秀的靈活性而衍生的一點(diǎn)小問(wèn)題
    2023-02-02

最新評(píng)論