s.compare(s); //相等
s.compare(0,2,s,2,2); //用”ab”和”cd”进行比较 小于零 s.compare(1,2,”bcx”,2); //用”bc”和”bc”比较。
怎么样?功能够全的吧!什么?还不能满足你的胃口?好吧,那等着,后面有更个性化的比较算法。先给个提示,使用的是STL的比较算法。什么?对STL一窍不通?靠,你重修吧!
2.5 更改内容
这在字符串的操作中占了很大一部分。
首先讲赋值,第一个赋值方法当然是使用操作符=,新值可以是string(如:s=ns) 、c_string(如:s=”gaint”)甚至单一字符(如:s=’j’)。还可以使用成员函数assign(),这个成员函数可以使你更灵活的对字符串赋值。还是举例说明吧: s.assign(str); //不说
s.assign(str,1,3);//如果str是”iamangel” 就是把”ama”赋给字符串 s.assign(str,2,string::npos);//把字符串str从索引值2开始到结尾赋给s s.assign(“gaint”); //不说
s.assign(“nico”,5);//把’n’ ‘I’ ‘c’ ‘o’ ‘\\0’赋给字符串 s.assign(5,’x’);//把五个x赋给字符串
把字符串清空的方法有三个:s=””;s.clear();s.erase();(我越来越觉得举例比说话让别人容易懂!)。
string提供了很多函数用于插入(insert)、删除(erase)、替换(replace)、增加字符。
先说增加字符(这里说的增加是在尾巴上),函数有 +=、append()、push_back()。举例如下:
s+=str;//加个字符串
s+=”my name is jiayp”;//加个C字符串 s+=’a’;//加个字符
s.append(str);
s.append(str,1,3);//不解释了同前面的函数参数assign的解释 s.append(str,2,string::npos)//不解释了
s.append(“my name is jiayp”); s.append(“nico”,5); s.append(5,’x’);
字符串操作是一个不小的主题,在标准C++中,string字符串类成为一个标准,之所以抛弃char*的字符串而选用C++标准程序库中的string类,是因为他和前者比较起来,不必担心内存是否足够、字符串长度等等,而且作为一个类出现,他集成的操作函数足以完成我们大多数情况下的需要.
主要内容:
1,主要函数的实现 2,常用函数
3.CString与char []的相互转换 4,将NULL字节放入CString中
vc中最主要函数不易理解。 CString::CString(char *p) {
int n=strlen(p);
m_data = new char[n+1]; strcpy(m_data,p); }
CString::CString(CString &other) {
int n=strlen(other.m_data); m_data = new char[n+1];
strcpy(m_data,other.m_data); }
CString& CString::operator = (CString& other) {
delete[] m_data;
int n=strlen(other.m_data); m_data = new char[n+1];
strcpy(m_data,other.m_data); return *this; }
String::~String() {
delete [] m_data; }
Collate,Compare 与一个字符长指针所指的字符串进行比较,与strcmp相同,它们的区别是,分别调用_tcscoll,_tcsicmp。 Delete
int Delete( int nIndex, int nCount = 1 )
返回值是被删除前的字符串的长度,nIndex是第一个被删除的字符,nCount是一次删除几个字符。根据我实验得出的结果:当nCount>字符串的长度时会出错,当nCount过大,没有足够的字符删除时,此函数不执行。
FindOneOf
int FindOneOf( LPCTSTR lpszCharSet ) const;
此函数的功能是在查找lpszCharSet中的任意一个字符,查到一个就把位置返回,没有查到返回0。如:
CString str = \ int x = str.FindOneOf(\ x的值是1。
Find
int Find( TCHAR ch ) const; int Find( LPCTSTR lpszSub ) const; int Find( TCHAR ch, int nStart ) const; int Find( LPCTSTR pstr, int nStart ) const;
返回值查找到的序号,ch待搜索的字符,lpszSub待搜索的字符子串,nStart 从那里开始搜索。如:
CString str = \ int x = str.Find(\ 返回的值是-1.
GetAt
TCHAR GetAt( int nIndex ) const;
返回标号为nIndex的字符,你可以把字符串理解为一个数组,GetAt类似于[].注意nIndex的范围,如果不合适会有调试错误。
Insert
int Insert( int nIndex, TCHAR ch )
int Insert( int nIndex, LPCTSTR pstr )返回修改后的长度,nIndex字符(或字符串)插入后的标号。
Left
CString Left( int nCount ) const; 返回的字符串的前nCount个字符。
Right与Left类似
MakeLower ,MakeUpper改变字符的大小写 MakeReverse字符倒置,如:
CString str = \ str.MakeReverse(); str变为\ +=
const CString& operator +=( const CString& string ); const CString& operator +=( TCHAR ch ); const CString& operator +=( LPCTSTR lpsz );
将参数合并到自己身上。
如: CString str = \ str+=\ str为\;
str[]
TCHAR operator []( int nIndex ) const;
象处理字符数组一样处理字符串。 注意是只读的。
CString str = \ str[0]='x'; 是错误的。
TrimLeft,TrimRight void TrimLeft( );
void CString::TrimLeft( TCHAR chTarget ); void CString::TrimLeft( LPCTSTR lpszTargets ); void TrimRight( );
void CString::TrimRight( TCHAR chTarget ); void CString::TrimRight( LPCTSTR lpszTargets );
CString str = \; str.TrimLeft(); str为“a”;
如果没有参数,从左删除字符(\\n\\t空格等),至到遇到一个非此类字符.
当然你也可以指定删除那些字符.
如果指定的参数是字符串,那么遇上其中的一个字符就删除. CString str = \;
str.TrimLeft(\); 结果\
int CString::Remove( TCHAR ch ); ch删除的字符.
返回删除字符的个数,有多个时都会删除.
CString 与char []之间的转换. char str[100] = ”str”; CString sstr = “sstr”; str.Format(“%s”,str); str = LPCTSTR sstr;
strcpy(str,(LPCTSTR)sstr);
如果是赋值,则要:
CString s(_T(\LPTSTR p = s.GetBuffer(); // 在这里添加使用p的代码 if(p != NULL) *p = _T('\\0'); s.ReleaseBuffer();
// 使用完后及时释放,以便能使用其它的CString成员函数