CString 的成员函数详解
CString的构造函数:
1 CString( );
2 CString( const CString& stringSrc );
3 CString( TCHAR ch, int nRepeat = 1 );
4 CString( LPCTSTR lpch, int nLength );
5 CString( const unsigned char* psz );
6 CString( LPCWSTR lpsz );
7 CString( LPCSTR lpsz );
CString 成员函数详解:
1.CString 的构造函数:
// 缺省构造函数
CString()
例:
CString csStr;
// 复制构造函数
CString(const CString& stringSrc)
例:
CString csStr("ABCDEF 中文 123456");
CString csStr2(csStr);
// 用字符初始化
CString(TCHAR ch, int nRepeat = 1)
例:
CString csStr('a', 5); // csStr = "aaaaa"
// 用字符串前几个字符初始化
CString(LPCTSTR lpch, int nLength)
例:
CString csStr("abcdef", 3); // csStr = "abc"
// 用宽字符串初始化
CString(LPCWSTR lpsz)
例:
wchar_t s[] = L"abcdef";
CString csStr(s); // csStr = L"abcdef"
// 用字符串初始化
CString(LPCSTR lpsz)
例:
CString csStr("abcdef"); // csStr = "abcdef"
// 用字符串初始化
CString(const unsigned char * psz)
例:
const unsigned char s[] = "abcdef";
const unsigned char *sp = s;
CString csStr(sp); // csStr = "abcdef"
2.CString 的成员函数:
int GetLength( ) const;
返回字符串的长度,不包含结尾的空字符。
例:
csSt r= "ABCDEF中文123456";
printf("%d",csStr.GetLength());
// 16
void MakeReverse( );
颠倒字符串的顺序
例:
csStr="ABCDEF中文123456";
csStr.MakeReverse();
cout<<csStr;
// 654321文中FEDCBA
void MakeUpper( );
将小写字母转换为大写字母
例:
csStr="abcdef中文123456";
csStr.MakeUpper();
cout<<csStr;
// ABCDEF中文123456
void MakeLower( );
将大写字母转换为小写字母
例:
csStr="ABCDEF中文123456";
csStr.MakeLower();
cout<<csStr;
// abcdef中文123456
int Compare( LPCTSTR lpsz ) const;
区分大小写比较两个字符串,相等时返回0,大于时返回1,小于时返回-1
csStr="abcdef中文123456";
csStr2="ABCDEF中文123456";
cout<<csStr.CompareNoCase(csStr2);
// -1
int CompareNoCase( LPCTSTR lpsz ) const;
不区分大小写比较两个字符串,相等时返回0,大于时返回1,小于时返回-1
csStr="abcdef中文123456";
csStr2="ABCDEF中文123456";
cout<<csStr.CompareNoCase(csStr2);
//0
int Delete( int nIndex, int nCount = 1 )
删除字符,删除从下标nIndex开始的nCount个字符
例:
csStr="ABCDEF";
csStr.Delete(2,3);
cout<<csStr;
// ABF
//当nIndex过大,超出对像所在内存区域时,函数没有任何操作。
//当nIndex为负数时,从第一个字符开始删除。
//当nCount过大,导致删除字符超出对像所在内存区域时,会发生无法预料的结果。
//当nCount为负数时,函数没有任何操作。
int Insert( int nIndex, TCHAR ch )
int Insert( int nIndex, LPCTSTR pstr )在下标为nIndex的位置,插入字符或字符串。返回插入后对象的长度
例:
csStr="abc";
csStr.Insert(2,'x');
cout<<csStr;
//abxc
csStr="abc";
csStr.Insert(2,"xyz");
cout<<csStr;
//abxyzc
//当nIndex为负数时,插入在对象开头
//当nIndex超出对象末尾时,插入在对象末尾
int Remove( TCHAR ch );
移除对象内的指定字符。返回移除的数目
例:
csStr="aabbaacc";
csStr.Remove('a');
cout<<csStr;
//bbcc
int Replace( TCHAR chOld, TCHAR chNew );
int Replace( LPCTSTR lpszOld, LPCTSTR lpszNew );
替换字串
例:
csStr="abcdef";
csStr.Replace('a','x');
cout<<csStr;
//xbcdef
csStr="abcdef";
csStr.Replace("abc","xyz");
cout<<csStr;
//xyzdef
void TrimLeft( );
void TrimLeft( TCHAR chTarget );
void TrimLeft( LPCTSTR lpszTargets );
从左删除字符,被删的字符与chTarget或lpszTargets匹配,一直删到第一个不匹配的字符为止
例:
csStr="aaabaacdef";
csStr.TrimLeft('a');
cout<<csStr;
//baacdef
csStr="aaabaacdef";
csStr.TrimLeft("ab");
cout<<csStr;
//cdef
//无参数时删除空格
void TrimRight( );
void TrimRight( TCHAR chTarget );
void TrimRight( LPCTSTR lpszTargets );
从右删除字符,被删的字符与chTarget或lpszTargets匹配,一直删到第一个不匹配的字符为止
例:
csStr="abcdeaafaaa";
csStr.TrimRight('a');
cout<<csStr;
//abcdeaaf
csStr="abcdeaafaaa";
csStr.TrimRight("fa");
cout<<csStr;
//abcde
//无参数时删除空格
void Empty( );
清空
例:
csStr="abcdef";
csStr.Empty();
printf("%d",csStr.GetLength());
//0
BOOL IsEmpty( ) const;
测试对象是否为空,为空时返回true,不为空时返回false
例:
csStr="abc";
cout<<csStr.IsEmpty();
//1;
csStr.Empty();
cout<<csStr.IsEmpty();
//0;
int Find( TCHAR ch ) const;
int Find( LPCTSTR lpszSub ) const;
int Find( TCHAR ch, int nStart ) const;
int Find( LPCTSTR pstr, int nStart ) const;
查找字串,nStart为开始查找的位置。未找到匹配时返回-1,否则返回字串的开始位置
例:
csStr="abcdef";
cout<<csStr.Find('b');
//1
cout<<csStr.Find("de");
//3
cout<<csStr.Find('b',3);
//-1
cout<<csStr.Find('b',0);
//1
cout<<csStr.Find("de",4);
//-1
cout<<csStr.Find("de",0);
//3
//当nStart超出对象末尾时,返回-1。
//当nStart为负数时,返回-1。
int FindOneOf( LPCTSTR lpszCharSet ) const;
查找lpszCharSet中任意一个字符在CString对象中的匹配位置。未找到时返回-1,否则返回字串的开始位置
例:
csStr="abcdef";
cout<<csStr.FindOneOf("cxy");
//2
CString SpanExcluding( LPCTSTR lpszCharSet ) const;
返回对象中与lpszCharSet中任意匹配的第一个字符之前的子串
例:
csStr="abcdef";
cout<<csStr.SpanExcluding("cf");
//ab
CString SpanIncluding( LPCTSTR lpszCharSet ) const;
从对象中查找与lpszCharSe中任意字符不匹配的字符,并返回第一个不匹配字符之前的字串
例:
csStr="abcdef";
cout<<csStr.SpanIncluding("fdcba");
//abcd
int ReverseFind( TCHAR ch ) const;
从后向前查找第一个匹配,找到时返回下标。没找到时返回-1
例:
csStr="abba";
cout<<csStr.ReverseFind('a');
//3
void Format( LPCTSTR lpszFormat, ... );
void Format( UINT nFormatID, ... );
格式化对象,与C语言的sprintf函数用法相同
例:
csStr.Format("%d",13);
cout<<csStr;
//13
TCHAR GetAt( int nIndex ) const;
返回下标为nIndex的字符,与字符串的[]用法相同
例:
csStr="abcdef";
cout<<csStr.GetAt(2);
//c
//当nIndex为负数或超出对象末尾时,会发生无法预料的结果。
void SetAt( int nIndex, TCHAR ch );
给下标为nIndex的字符重新赋值
例:
csStr="abcdef";
csStr.SetAt(2,'x');
cout<<csStr;
//abxdef
//当nIndex为负数或超出对象末尾时,会发生无法预料的结果。
CString Left( int nCount ) const;
从左取字串
例:
csStr="abcdef";
cout<<csStr.Left(3);
//abc
//当nCount等于0时,返回空。
//当nCount为负数时,返回空。
//当nCount大于对象长度时,返回值与对象相同。
CString Right( int nCount ) const;
从右取字串
例:
csStr="abcdef";
cout<<csStr.Right(3);
//def
//当nCount等于0时,返回空。
//当nCount为负数时,返回空。
//当nCount大于对象长度时,返回值与对象相同。
CString Mid( int nFirst ) const;
CString Mid( int nFirst, int nCount ) const;
从中间开始取字串
例:
csStr="abcdef";
cout<<csStr.Mid(2);
//cdef
csStr="abcdef";
cout<<csStr.Mid(2,3);
//cde
//当nFirst为0和为负数时,从第一个字符开始取。
//当nFirst等于对象末尾时,返回空字串。
//当nFirst超出对象末尾时,会发生无法预料的结果。
//当nCount超出对象末尾时,返回从nFirst开始一直到对象末尾的字串
//当nCount为0和为负数时,返回空字串。
LPTSTR GetBuffer( int nMinBufLength );
申请新的空间,并返回指针
例:
csStr="abcde";
LPTSTR pStr=csStr.GetBuffer(10);
strcpy(pStr,"12345");
csStr.ReleaseBuffer();
pStr=NULL;
cout<<csStr
//12345
//使用完GetBuffer后,必须使用ReleaseBuffer以更新对象内部数据,否则会发生无法预料的结果。
void ReleaseBuffer( int nNewLength = -1 );
使用GetBuffer后,必须使用ReleaseBuffer以更新对象内部数据
例:
csStr="abc";
LPTSTR pStr=csStr.GetBuffer(10);
strcpy(pStr,"12345");
cout<<csStr.GetLength();
//3(错误的用法)
csStr.ReleaseBuffer();
cout<<csStr.GetLength();
//5(正确)
//CString 对象的任何方法都应在ReleaseBuffer之后调用
LPTSTR GetBufferSetLength( int nNewLength );
申请新的空间,并返回指针
例:
csStr="abc";
csStr.GetBufferSetLength(20);
cout<<csStr;
//abc
count<<csStr.GetLength();
//20;
csStr.ReleaseBuffer();
count<<csStr.GetLength();
//3;
//使用GetBufferSetLength后可以不必使用ReleaseBuffer
CString 的成员函数详解的更多相关文章
- CString成员函数详解[转]
1.构造函数(常用) CString( const unsigned char* psz ); 例:char s[]="abcdef"; cha ...
- C++ 11 智能指针(shared_ptr)类成员函数详解
C++ 11 模板库的 <memory> 头文件中定义的智能指针,即 shared_ptr 模板类,用来管理指针的存储,提供有限的内存回收函数,可同时与其他对象共享该管理功能. share ...
- malloc 与 free函数详解<转载>
malloc和free函数详解 本文介绍malloc和free函数的内容. 在C中,对内存的管理是相当重要.下面开始介绍这两个函数: 一.malloc()和free()的基本概念以及基本用法: 1 ...
- C++ 虚函数详解
C++ 虚函数详解 这篇文章主要是转载的http://blog.csdn.net/haoel/article/details/1948051这篇文章,其中又加入了自己的理解和难点以及疑问的解决过程,对 ...
- linux select函数详解
linux select函数详解 在Linux中,我们可以使用select函数实现I/O端口的复用,传递给 select函数的参数会告诉内核: •我们所关心的文件描述符 •对每个描述符,我们所关心的状 ...
- AdapterView的使用与getView函数详解
作者:徐冉.文章首发在他的个人博客. ) AdapterView&Adapter家族 adapterview就是和数据有关的控件,如listview,gridview,spinnerview等 ...
- c/c++ socket函数详解
c/c++ socket函数详解 注意: 使用socketAPI前,要先将相关链接库(Ws2_32.lib)加入链接,并使用WSAStartUp函数初始化.每个socket函数都可能失败(返回-1), ...
- 【P2158】仪仗队&欧拉函数详解
来一道数论题吧. 这个题一眼看上去思路明确,应该是数论,但是推导公式的时候却出了问题,根本看不出来有什么规律.看了马佬题解明白了这么个规律貌似叫做欧拉函数,于是就去百度学习了一下这东西. 欧拉函数的含 ...
- Jquery之each函数详解
最近项目被each函数坑惨了,想来还是好好整理下关于each函数的方方面面,一来方便自己查阅,二来为读者提供经验和教训,废话不多说,来看看Each函数到底是怎么坑人的. 一. 全局jQuery.eac ...
随机推荐
- 2019-3-13-win10-uwp-使用-ScaleTransform-放大某个元素
title author date CreateTime categories win10 uwp 使用 ScaleTransform 放大某个元素 lindexi 2019-3-13 19:5:56 ...
- 运行docker容器镜像
docker容器可以理解为在盒中运行的进程. 这个盒包含了该进程运行所必须的资源,包括文件系统.系统类库.shell 环境等等. 但这个盒默认是不会运行任何程序的. 1.运行镜像之前,可以先查看本地有 ...
- 利用IDEA构建springboot应用-构建好SpringBoot + SSM 框架
一. 创建项目 选择 Spring Initiallizr 添加最基本的几个依赖 Web,MySQL,MyBatis,其他需求可以后续再添加 ; 数据库选择了 MySQL 二. 配置数据源 数据源中存 ...
- pytest笔记
-v 参数显示执行过程 测试覆盖率: ldy@ldy-D214:~/workspace/socai$ pipenv run pytest tests/unit/test_models.py --cov ...
- qt 中创建一个工作线程(例子)
当一个事件需要很长的处理时间,就创建一个工作线程,防止主界面卡死. 1.新建一个QT的gui项目,里面包含main.cpp,mainwindow.h,mainwindow.cpp,mainwindow ...
- composer基本使用
一.Composer的安装 1.下载Composer 2.Composer安装 1).Composer安装前请确保已经安装了php:打开命令行窗口输入php -v可以查看php的当前版本号. 3.局部 ...
- 22-2 模板语言的进阶和fontawesome字体的使用
一 fontfawesome字体的使用 http://fontawesome.dashgame.com/ 官网 1 下载 2 放到你的项目下面 3 html导入这个目录 实例: class最前面的f ...
- 「BZOJ2654」tree
「BZOJ2654」tree 最小生成树+二分答案. 最开始并没有觉得可以二分答案,因为答案并不单调啊. 其实根据题意,白边的数目肯定大于need条,而最小生成树的白边数并不等于need(废话),可以 ...
- poj 1263 Reflections (Simple Geometry)
1263 -- Reflections 简单计算几何.题目给出射线以及若干个不相交的圆,求出射线会在哪些圆上反弹,依次写出反弹球的编号. 代码如下: #include <cstdio> # ...
- 请求(RequestInfo)
请求类型 StringRequestInfo 用在 SuperSocket 命令行协议中. 你也可以根据你的应用程序的需要来定义你自己的请求类型. 例如, 如果所有请求都包含 DeviceID 信息, ...