1.CString::IsEmpty BOOL IsEmpty( ) const; 傳回值:如果CString 對象的長度為0,則傳回非零值;否則傳回0。 說明:此成員函數用來測試一個CString 對象是否是空的。 示例: 下面的例子說明了如何使用CString::IsEmpty。 // CString::IsEmpty 示例 CString s; ASSERT( s.IsEmpty() ); 請參閱 CString::GetLength 2.CString::Left CString Left( int nCount ) const; throw( CMemoryException ); 傳回值:傳回的字元串是前nCount個字元。 示例: CString s( _T("abcdef") ); ASSERT( s.Left(2) == _T("ab") ); 3.CString::LoadString BOOL LoadString( UINT nID ); throw( CMemoryException ); 傳回值:如果加載資源成功則傳回非零值;否則傳回0。 nID 一個Windows 字元串資源ID。 說明: 此成員函數用來讀取一個由nID 辨別的Windows 字元串資源,并放入一個已有CString 對象中。 示例: 下面的例子說明了如何使用CString::LoadString。 // CString::LoadString 示例 #define IDS_FILENOTFOUND 1 CString s; if (! s.LoadString( IDS_FILENOTFOUND )) 4.CString::MakeLower void MakeLower( ); //改變字元的小寫 5.CString::MakeReverse void MakeReverse( ); //字元倒置 6.CString::MakeUpper void MakeUpper( ); //改變字元的大寫 7.CString::Mid CString Mid( int nFirst ) const; CString Mid( int nFirst, int nCount ) const; nCount代表要提取的字元數, nFirst代表要提取的開始索引位置 示例: CString s( _T("abcdef") ); ASSERT( s.Mid( 2, 3 ) == _T("cde") ); 8.CString::ReleaseBuffer void ReleaseBuffer( int nNewLength = -1 ); 參數:nNewLength 此字元串的以字元數表示的新長度,不計算結尾的空字元。如果這個字 符串是以空字元結尾的,則參數的預設值-1 将把CString 的大小設定為 字元串的目前長度。 說明: 使用ReleaseBuffer 來結束對由GetBuffer 配置設定的緩沖區的使用。如果你知道緩 沖區中的字元串是以空字元結尾的,則可以省略nNewLength 參數。如果字元 串不是以空字元結尾的,則可以使用nNewLength 指定字元串的長度。在調用 ReleaseBuffer 或其它CString 操作之後,由GetBuffer 傳回的位址是無效的。 示例: 下面的例子說明了如何使用CString::ReleaseBuffer。 // CString::ReleaseBuffer 示例 CString s; s = "abc"; LPTSTR p = s.GetBuffer( 1024 ); strcpy(p, "abc"); // 直接使用該緩沖區 ASSERT( s.GetLength() == 3 ); // 字元串長度 = 3 s.ReleaseBuffer(); // 釋放多餘的記憶體,現在p 無效。 ASSERT( s.GetLength() == 3 ); // 長度仍然是3 9.CString::Remove int CString::Remove ( TCHAR ch ); 傳回值:傳回從字元串中移走的字元數。如果字元串沒有改變則傳回零。 參數:ch 要從一個字元串中移走的字元。 說明:此成員函數用來将ch 執行個體從字元串中移走。與這個字元的比較是區分大小寫 的。 示例: // 從一個句子中移走小寫字母'c': CString str (“This is a test.”); int n = str.Remove( 't' ); ASSERT( n == 2 ); ASSERT( str ==“This is a es. ” ); 10.CString::Replace int Replace( TCHAR chOld, TCHAR chNew ); int Replace( LPCTSTR lpszOld, LPCTSTR lpszNew ); 傳回值:傳回被替換的字元數。如果這個字元串沒有改變則傳回零。 參數:chOld 要被chNew 替換的字元。 chNew 要用來替換chOld 的字元。 lpszOld 一個指向字元串的指針,該字元串包含了要被lpszNew 替換的字元。 LpszNew 一個指向字元串的指針,該字元串包含了要用來替換lpszOld 的字元。 說明:此成員函數用一個字元替換另一個字元。函數的第一個原形在字元串中用chNew 現場替換chOld。函數的第二個原形用lpszNew 指定的字元串替換lpszOld 指定 的子串。 在替換之後,該字元串有可能增長或縮短;那是因為lpszNew 和lpszOld 的長度 不需要是相等的。兩種版本形式都進行區分大小寫的比對。 示例: // 第一個例子,old 和new 具有相同的長度。 CString strZap( “C - -” ); int n = strZap.Replace('-', '+' ); ASSERT( n == 2 ); ASSERT(strZap == “C++” ); // 第二個例子,old 和new 具有不同的長度。 CString strBang( “Everybody likes ice hockey” ); n = strBang.Replace( “hockey”, “golf” ); ASSERT( n ==1 ); n = strBang.Replace ( “likes” , “plays” ); ASSERT( n == 1 ); n = strBang.Replace( “ice”, NULL ); ASSERT( n == 1 ); ASSERT( strBang == “Everybody plays golg” ); // 注意,現在在你的句子中有了一個額外的空格。 // 要移走這個額外的空格,可以将它包括在要被替換的字元串中,例如,“ice ”。 11.CString::ReverseFind int ReverseFind( TCHAR ch ) const; 傳回值: 傳回此CString 對象中與要求的字元比對的最後一個字元的索引;如果沒有找 到需要的字元則傳回-1。 參數: ch 要搜尋的字元。 說明:此成員函數在此CString 對象中搜尋與一個子串比對的最後一個字元。此函數 類似于運作時函數strrchr。 示例: // CString::ReverseFind 示例 CString s( "abcabc" ); ASSERT( s.ReverseFind( 'b' ) == 4 ); 12.CString::Right CString Right( int nCount ) const; throw( CMemoryException ); 傳回值: 傳回的字元串是最後nCount個字元。 CString s( _T("abcdef") ); ASSERT( s.Right(2) == _T("ef") ); 13.CString:: SetAt void SetAt( int nIndex, TCHAR ch ); 說明:可以把字元串了解為一個數組,SetAt類似于[].注意nIndex的範圍,如果不合适會有調試錯誤。 Ch 更替字元, 把nIndex位置上的字元 變成ch 示例: CString s( "abc" ); s.MakeReverse(); ASSERT( s == "cba" ); 14.CString::TrimLeft void TrimLeft( ); void CString::TrimLeft( TCHAR chTarget ); 說明:如果沒有參數,從左删除字元(\n\t空格等),至到遇到一個非此類字元. 當然你也可以指定删除那些字 符. 如果指定的參數是字元串,那麼遇上其中的一個字元就删除. \n 換行符 \t TAB字元 示例1: CString str = "\n\t a"; str.TrimLeft(); str為“a”; 示例2: CString str = "abbcadbabcadb "; str.TrimLeft("ab"); 結果"cadbabcadb " str.TrimLeft("ac"); 結果"bcadbabcadb " 15.CString::TrimRight void TrimRight( ); void CString::TrimRight( TCHAR chTarget ); void CString::TrimRight( LPCTSTR lpszTargets ); 說明:用法類似于上面。 16.CString::Compare int Compare( LPCTSTR lpsz ) const; 傳回值:字元串一樣傳回0,小于lpsz 傳回-1,大于lpsz 傳回1, 區分大小字元 示例: CString s1( "abc" ); CString s2( "abd" ); ASSERT( s1.Compare( s2 ) == -1 ); ASSERT( s1.Compare( "abe" ) == -1 17.CString::CompareNoCase int CompareNoCase( LPCTSTR lpsz ) const; 傳回值: 字元串一樣 傳回0,小于lpsz 傳回-1,大于lpsz 傳回1,不區分大小字元 18.CString::Collate int Collate( LPCTSTR lpsz ) const; 同CString::Compare 19.CString::CollateNoCase int CollateNocase( LPCTSTR lpsz ) const; 同CString::CompareNoCase 20.CString::CString //構造函數 CString( ); CString( const CString& stringSrc ); CString( TCHAR ch, int nRepeat = 1 ); CString( LPCTSTR lpch, int nLength ); CString( const unsigned char* psz ); CString( LPCWSTR lpsz ); CString( LPCSTR lpsz ); 示例: CString s1; CString s2( "cat" ); CString s3 = s2; CString s4( s2 + " " + s3 ); CString s5( 'x' ); // s5 = "x" CString s6( 'x', 6 ); // s6 = "xxxxxx" CString s7((LPCSTR)ID_FILE_NEW); // s7 = "Create a new document" CString city = "Philadelphia"; 21.CString::Delete int Delete( int nIndex, int nCount = 1); 傳回值:是被删除前的字元串的長度 nIndex是第一個被删除的字元,nCount是一次删除幾個字元。根據我實驗得出的結果:當nCount>要删除字元 串的最大長度(GetCount() - nIndex)時會出錯,當nCount過大,沒有足夠的字元删除時,此函數不執行。 示例: CString str1,str2,str3; char a; str1 = "nihao"; str2 = "nIhao"; int x; // int i=(str1 == str2); str1.Delete(2,3); 如果nCount(3) > GetCount() – nIndex (5-2)就會執行錯誤 22.CString::Empty Void Empty( ); 傳回值:沒有傳回值 清空操作; 示例: CString s( "abc" ); s.Empty(); ASSERT( s.GetLength( ) == 0 ); 23.CString::Find int Find( TCHAR ch ) const; int Find( LPCTSTR lpszSub ) const; int Find( TCHAR ch, int nStart ) const; int Find( LPCTSTR lpszSub, int nStart ) const; 傳回此CString對象中與需要的子字元串或字元比對的第一個字元的 從nStart開始 的索引; 如果沒有找到子字元串或字元則傳回-1。 傳回值: 不比對的話傳回 -1; 索引以0 開始; nStar 代表以索引值nStart 的字元開始搜尋 , 即為包含以索引nStart字元後的字元串. 示例: CString s( "abcdef" ); ASSERT( s.Find( 'c' ) == 2 ); ASSERT( s.Find( "de" ) == 3 ); Cstring str(“The stars are aligned”); Ing n = str.Find('e',5); ASSERT(n == 12) 24.CString::FindOneOf int FindOneOf( LPCTSTR lpszCharSet ) const; 傳回值: 不比對的話傳回 -1; 索引以0 開始 注意::傳回此字元串中第一個在lpszCharSet中也包括字元并且從零開始的索引值 示例: CString s( "abcdef" ); ASSERT( s.FindOneOf( "xd" ) == 3 ); // 'd' is first match. 25.CString::Format void Format( LPCTSTR lpszFormat, ... ); void Format( UINT nFormatID, ... ); 參數:lpszFormat 一個格式控制字元串 nFormatID 字元串辨別符 示例: CString str; Str.Format(“%d”,13); 此時Str為13 26.CString::GetAt TCHAR GetAt( int nIndex ) const; 傳回值:傳回标号為nIndex的字元,你可以把字元串了解為一個數組,GetAt類似于[].注意nIndex的範圍, 如果不合适會有調試錯誤。 27.CString::GetBuffer LPTSTR GetBuffer( int nMinBufLength ); 傳回值:一個指向對象的(以空字元結尾的)字元緩沖區的LPTSTR 指針。 參數:nMinBufLength 字元緩沖區的以字元數表示的最小容量。這個值不包括一個結尾的空字元的空間。 說明:此成員函數傳回一個指向CString 對象的内部字元緩沖區的指針。傳回的LPTSTR 不是const,是以可 以允許直接修改CString 的内容。如果你使用由GetBuffer 傳回的指針來改變字元串的内容,你必須在使用 其它的CString 成員函數之前調用ReleaseBuffer 函數。 在調用ReleaseBuffer 之後,由GetBuffer 傳回的位址也許就無效了,因為其它的CString 操作可能會導緻 CString 緩沖區被重新配置設定。如果你沒有改變此CString 的長度,則緩沖區不會被重新配置設定。當此CString 對象被銷毀時,其緩沖區記憶體将被自動釋放。 注意:如果你自己知道字元串的長度,則你不應該添加結尾的空字元。但是,當你用ReleaseBuffer 來釋放 該緩沖區時,你必須指定最後的字元串長度。如果你添加了結尾的空字元,你應該給ReleaseBuffer 的長度 參數傳遞-1 ,ReleaseBuffer 将對該緩沖區執行strlen 來确定它的長度。 示例: // CString::GetBuffer 例子 CString s( "abcd" ); #ifdef _DEBUG afxDump << "CString s " << s << "\n"; #endif LPTSTR p = s.GetBuffer( 10 ); strcpy( p, "Hello" ); // 直接通路CString 對象。 s.ReleaseBuffer( ); #ifdef _DEBUG afxDump << "CString s " << s << "\n"; #endif 28.CString::GetLength int GetLength( ) const; 傳回值:傳回字元串中的位元組計數。 說明:此成員函數用來擷取這個CString 對象中的位元組計數。這個計數不包括結尾的空字元。 對于多位元組字元集(MBCS),GetLength 按每一個8 位字元計數;即,在一個多位元組字元中的開始和結尾字 節被算作兩個位元組。 示例 下面的例子說明了如何使用CString::GetLength。 // CString::GetLength 示例 CString s( "abcdef" ); ASSERT( s.GetLength() == 6 ); 29.CString::Insert int Insert( int nIndex, TCHAR ch ); int Insert( int nIndex, LPCTSTR pstr ); 傳回值:傳回修改後的長度,nIndex是字元(或字元串)插入後的索引号例子 示例: CString str( “HockeyBest”); int n = str.Insert( 6, “is” ); ASSERT( n == str.GetLength( ) ); printf( “1: %s\n”, ( LPCTSTR ) str ); n = str.Insert( 6, ' ' ); ASSERT( n == str.GetLength( ) ); printf ( “2: %s\n”, (LPCTSTR) STR ); n = str.Insert(555, ‘1’); ASSERT( n == str.GetLength ( ) ); printf ( “3: %s\n”, ( LPCTSTR ) str ); 輸出 1. Hockeyis Best 2. Hockey is Best 3. Hockey is Best! http://blog.sina.com.cn/s/blog_6d4b374e010143pf.html