CString常用方法简介

353人阅读 评论(0)
CString::Compare
int Compare( LPCTSTR lpsz ) const;

小于lpsz 返回-1
大于lpsz 返回1
区分大小字符
CString s1( "abc" );
CString s2( "abd" );
ASSERT( s1.Compare( s2 ) == -1 );
ASSERT( s1.Compare( "abe" ) == -1 );

CString::CompareNoCase
int CompareNoCase( LPCTSTR lpsz ) const;

小于lpsz 返回-1
大于lpsz 返回1
不区分大小字符

CString::Collate
int Collate( LPCTSTR lpsz ) const;
CString::Compare

CString::CollateNoCase
int CollateNocase( LPCTSTR lpsz ) const;
CString::CompareNoCase

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::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);

CString::Empty
Void Empty( );

CString s( "abc" );
s.Empty();
ASSERT( s.GetLength( ) == 0 );

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;

nStar 代表以索引值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)

CString::FindOneOf
int FindOneOf( LPCTSTR lpszCharSet ) const;

注意::返回此字符串中第一个在lpszCharSet中 也包括字符并且从零开始的索引值

CString s( "abcdef" );
ASSERT( s.FindOneOf( "xd" ) == 3 ); // 'd' is first match.

CString::Format
void Format( LPCTSTR lpszFormat, ... );
void Format( UINT nFormatID, ... );
lpszFormat  一个格式控制字符串
nFormatID 字符串标识符

CString str;
Str.Format(“%d”,13);

CString::GetAt
TCHAR GetAt( int nIndex ) const;

CString::GetBuffer
LPTSTR GetBuffer( int nMinBufLength );

nMinBufLength

// 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

CString::GetLength
int GetLength( ) const;

// CString::GetLength 示例
CString s( "abcdef" );
ASSERT( s.GetLength() == 6 );

CString::Insert
int Insert( int nIndex, TCHAR ch );
int Insert( int nIndex, LPCTSTR pstr );

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!

CString::IsEmpty
BOOL IsEmpty( ) const;

// CString::IsEmpty 示例
CString s;
ASSERT( s.IsEmpty() );

CString::Left
CString Left( int nCount ) const;
throw( CMemoryException );

CString s( _T("abcdef") );
ASSERT( s.Left(2) == _T("ab") );

throw( CMemoryException );

nID 一个Windows 字符串资源ID。

#define IDS_FILENOTFOUND 1
CString s;

CString::MakeLower
void MakeLower( );

CString::MakeReverse
void MakeReverse( );

CString::MakeUpper
void MakeUpper( );

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") );
CString::ReleaseBuffer
void ReleaseBuffer( int nNewLength = -1 );

nNewLength

ReleaseBuffer 或其它CString 操作之后，由GetBuffer 返回的地址是无效的。

// 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

CString::Remove
int CString::Remove ( TCHAR ch );

ch

// 从一个句子中移走小写字母'c':
CString str (“This is a test.”);
int n = str.Remove( 't' );
ASSERT( n == 2 );
ASSERT( str ==“This is a es. ” );

CString::Replace
int Replace( TCHAR chOld, TCHAR chNew );
int Replace( LPCTSTR lpszOld, LPCTSTR lpszNew );

chOld

chNew

lpszOld

lpszNew

// 第一个例子，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 ”。

CString::ReverseFind
int ReverseFind( TCHAR ch ) const;

ch

// CString::ReverseFind 示例
CString s( "abcabc" );
ASSERT( s.ReverseFind( 'b' ) == 4 );

CString::Right
CString Right( int nCount ) const;
throw( CMemoryException );

CString s( _T("abcdef") );
ASSERT( s.Right(2) == _T("ef") );

CString:: SetAt
void SetAt( int nIndex, TCHAR ch );

CString s( "abc" );
s.MakeReverse();
ASSERT( s == "cba" );

CString::TrimLeft
void TrimLeft( );
void CString::TrimLeft( TCHAR chTarget );

/n 换行符
/t TAB字符
CString str = "/n/t a";
str.TrimLeft();
str为“a”;

str.TrimLeft("ab");

str.TrimLeft("ac");

CString::TrimRight
void TrimRight( );
void CString::TrimRight( TCHAR chTarget );
void CString::TrimRight( LPCTSTR lpszTargets );

0
0

【直播】机器学习&数据挖掘7周实训--韦玮
【套餐】系统集成项目管理工程师顺利通关--徐朋
【直播】3小时掌握Docker最佳实战-徐西宁
【套餐】机器学习系列套餐（算法+实战）--唐宇迪
【直播】计算机视觉原理及实战--屈教授
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之矩阵--黄博士
【套餐】微信订阅号+服务号Java版 v2.0--翟东平
【直播】机器学习之凸优化--马博士
【套餐】Javascript 设计模式实战--曾亮

* 以上用户言论只代表其个人观点，不代表CSDN网站的观点或立场
个人资料
• 访问：4471次
• 积分：68
• 等级：
• 排名：千里之外
• 原创：2篇
• 转载：2篇
• 译文：0篇
• 评论：6条
文章存档
最新评论