标签:mfc cstring类
在MFC框架中,CString类用的很多,它是对原来标准c中字符串类型的一种包装,因为里面有两个成员变量char* m_pData和int m_nLength来维护这个类。
对于成员函数:
1、几个默认的构造函数
CString(); //缺省构造
CString( const CString& stringSrc );
//拷贝构造
CString( const char* lpsz );
//根据字符串常量初始化
CString( char ch, int nRepeat = 1);
//串内有n个ch字符
CString(const char* cstr,int nLength); //根据字符串常量的一部分
实现函数:
CString::CString()
{
//m_pData = new char;
//m_pData[0] = 0
m_pData = new char(0);//new一个字符串 并且等于0
m_nLength = 0;
}
//拷贝构造发生的条件是:当用一个已有的对象作为初始化数据构造一个新对象时
CString::CString( const CString& str ) //拷贝构造
{
m_nLength = str.m_nLength;
//由于是拷贝构造,不需要删除原来的空间
//申请内存空间
m_pData = new char[m_nLength+1];
//m_pData = str.m_pData;//浅拷贝
strcpy(m_pData,str);//深拷贝
}
CString::CString( const char* lpsz ) //根据字符串常量初始化
{
m_nLength = strlen(lpsz);
//申请空间
m_pData = new char[m_nLength + 1];
strcpy(m_pData,lpsz);
}
CString::CString( char ch, int nRepeat) //串内有n个ch字符
{
m_nLength = nRepeat;
m_pData = new char[m_nLength+1];
m_pData[m_nLength] = '\0';//最后一个字符表示为0;
int i = m_nLength;
while(i--)
{
m_pData[i] = ch;
}
}
CString::CString(const char* cstr,int nLength)//根据字符串常量的一部分
{
//m_nLength = nLength;
//m_pData = new char[nLength+1];
//strncpy(m_pData,cstr,nLength);//函数根据长度进行拷贝
m_nLength = strlen(cstr);
m_nLength = m_nLength>nLength ? nLength:m_nLength;
m_pData = new char[m_nLength+1];
m_pData[m_nLength] = '\0';
int i =0;
while(i<m_nLength)
m_pData[i] = cstr[i++];
}
CString& operator=(const char* cstr) ;
//删除已有文字的堆空间,重新分配
CString& operator=(const CString &str);
//删除已有文字的堆空间,重新分配
<span style="font-size:18px;">//重载赋值操作
CString& CString::operator=(const char* cstr) //删除已有文字的堆空间,重新分配
{
int nLen = strlen(cstr);
if (nLen>m_nLength)
{
//删除已有的堆空间
delete []m_pData;
m_pData = new char[m_nLength+1];
}
//m_pData = cstr;//浅拷贝
m_nLength = nLen;
strcpy(m_pData,cstr);
return *this;
}
CString& CString::operator=(const CString &str) //删除已有文字的堆空间,重新分配
{
int nlen = str.m_nLength;
if (nlen > m_nLength)
{
//删除已有长度
delete []m_pData;
m_pData = new char[nlen + 1];
}
m_nLength = nlen;
strcpy(m_pData,str.m_pData);
return *this;
}</span>3、类型转化
//类型转化
operator const char* () const
{
return m_pData;
}
//凡是单行函数放在头文件中,编译器会自动使用inline内联格式编译
char operator []( int nIndex ) const //获取串内上的某个字符
{
return m_pData[nIndex];
}
friend bool operator!=(const CString& str1,const CString& str2) ; friend bool operator==(const CString& str1,const CString& str2) ; friend bool operator<(const CString& str1, const CString& str2) ; friend bool operator>(const CString& str1, const CString& str2) ;
<pre name="code" class="html">//友元
bool operator!=(const CString& str1,const CString& str2)
{
return strcmp(str1,str2) != 0;
}
bool operator==(const CString& str1,const CString& str2)
{
return !strcmp(str1,str2);
}
bool operator<(const CString& str1, const CString& str2)
{
return strcmp(str1,str2)<0;
}
bool operator>(const CString& str1, const CString& str2)
{
return strcmp(str1,str2)>0;
}CString CString::Mid( int nFirst ) const
{
return Mid(nFirst,m_nLength - nFirst);
}
//原字符串不变
//需要进行条件判断
CString CString::Mid( int nFirst, int nCount ) const
{
CString str;
if (nFirst<0)
{
nFirst = 0;
}
if (nCount <= 0 || nFirst > m_nLength -1)
{
return str;//直接返回空字符串
}
//在中间区域
int nLen = m_nLength - nFirst;
//如果nlen 比ncount大,则拷贝nfirst后面的所有字符
nLen = nLen < nCount ? nLen:nCount;
//释放原有的空间,一个字节
delete []str.m_pData;//重要
str.m_pData = new char[nLen+1];
//逐一拷贝
str.m_nLength = nLen;
str.m_pData[nLen] = '\0';
while(nLen--)
{
str.m_pData[nLen] = m_pData[nFirst+nLen];
}
//为什么会触发构造函数,,?
return str;
}
//
CString CString::Left( int nCount ) const
{
return Mid(0,nCount);
}
void CString::MakeUpper( )
{
int i = m_nLength;
while(i--)
{
m_pData[i] = _toupper(m_pData[i]);
}
//也可以用
//_strupr(m_pData);直接转化
}
void CString::MakeLower( )
{
_strlwr(m_pData);
}
void CString::MakeReverse( )
{
//int i = 0,j = m_nLength-1;
//char c;
//while(i<j)
//{
// c = m_pData[i];
// m_pData[i] = m_pData[j];
// m_pData[j] = c;
// ++i;
// ++j;
//}
int i = 0,j = m_nLength;
char c;
char *p = m_pData;
char *q = m_pData+m_nLength-1;
while(p<q)
{
c = *p;
*p = *q;
*q = c;
++p;
--q;
}
}
int CString::Replace( char chOld, char chNew )
{
int i = m_nLength;
int nCount = 0;
while(i--)
{
if (m_pData[i] == chOld)
{
m_pData[i] = chNew;
++nCount;
}
}
return nCount;
}
int CString::Find( char ch ) const
{
int i = 0;
while(i<m_nLength)
{
if (m_pData[i] == ch)
{
return i;
}
++i;
}
return -1;
}
//int CString::Find( const char* lpszSub ) const
//{
//
//}
//int CString::Find( char ch, int nStart ) const
//{
//
//}
int CString::Find( const char* pstr, int nStart ) const
{
//字串比较
if (nStart>=m_nLength)
{
return -1;
}
char *p = strstr(m_pData+nStart,pstr);
return p-m_pData;//返回的索引是基于首地址的
}
int CString::ReverseFind( char ch ) const
{
int i = m_nLength;
while(i--)
{
if (m_pData[i] == ch)
{
return i;
}
}
return -1;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:mfc cstring类
原文地址:http://blog.csdn.net/life061522/article/details/47146417