C++常用技巧Word文件下载.docx
- 文档编号:15291958
- 上传时间:2022-10-29
- 格式:DOCX
- 页数:17
- 大小:23.17KB
C++常用技巧Word文件下载.docx
《C++常用技巧Word文件下载.docx》由会员分享,可在线阅读,更多相关《C++常用技巧Word文件下载.docx(17页珍藏版)》请在冰豆网上搜索。
:
toupper);
cout<
<
s<
endl;
tolower);
当然,我知道很多人希望的是s.to_upper(),但是对于一个这么通用的basic_string来说,的确没办法把这些专有的方法放进来。
如果你用booststringalgo,那当然不在话下,你也就不需要读这篇文章了。
------------------------------------------------------------------------
trim
我们还知道string没有trim,不过自力更生也不困难,比toupper来的还要简单:
strings("
hello
"
s.erase(0,s.find_first_not_of("
));
cout<
s.erase(s.find_last_not_of('
'
)+1);
注意由于find_first_not_of和find_last_not_of都可以接受字符串,这个时候它们寻找该字符串中所有字符的absence,所以你可以一次trim掉多种字符。
-----------------------------------------------------------------------
erase
string本身的erase还是不错的,但是只能erase连续字符,如果要拿掉一个字符串里面所有的某个字符呢?
用STL的erase+remove_if就可以了,注意光remove_if是不行的。
hello,world.saybye
s.erase(remove_if(s.begin(),s.end(),
bind2nd(equal_to<
char>
(),'
)),
s.end());
上面的这段会拿掉所有的空格,于是得到hello,world.saybye。
replace
string本身提供了replace,不过并不是面向字符串的,譬如我们最常用的把一个substr换成另一个substr的操作,就要做一点小组合:
hello,world"
stringsub("
ello,"
s.replace(s.find(sub),sub.size(),"
appy"
输出为happyworld。
注意原来的那个substr和替换的substr并不一定要一样长。
startwith,endwith
这两个可真常用,不过如果你仔细看看string的接口,就会发现其实没必要专门提供这两个方法,已经有的接口可以干得很好:
stringhead("
hello"
stringtail("
ld"
boolstartwith=pare(0,head.size(),head)==0;
boolalpha<
startwith<
boolendwith=pare(s.size()-tail.size(),tail.size(),tail)==0;
endwith<
当然了,没有s.startwith("
)这样方便。
toint,todouble,tobool...
这也是老生常谈了,无论是C的方法还是C++的方法都可以,各有特色:
123"
inti=atoi(s.c_str());
i<
intii;
stringstream(s)>
>
ii;
ii<
stringsd("
12.3"
doubled=atof(sd.c_str());
d<
doubledd;
stringstream(sd)>
dd;
dd<
stringsb("
true"
boolb;
stringstream(sb)>
boolalpha>
b;
b<
C的方法很简洁,而且赋值与转换在一句里面完成,而C++的方法很通用。
split
这可是件麻烦事,我们最希望的是这样一个接口:
s.split(vect,'
'
)。
用STL算法来做有一定难度,我们可以从简单的开始,如果分隔符是空格、tab和回车之类,那么这样就够了:
helloworld,bye."
vector<
string>
vect;
vect.assign(
istream_iterator<
(stringstream(s)),
()
);
不过要注意,如果s很大,那么会有效率上的隐忧,因为stringstream会copy一份string给自己用。
concat
把一个装有string的容器里面所有的string连接起来,怎么做?
希望你不要说是handcode循环,这样做不是更好?
vect.push_back("
"
world"
accumulate(vect.begin(),vect.end(),string("
"
不过在效率上比较有优化余地。
-------------------------------------------------------------------------
reverse
其实我比较怀疑有什么人需要真的去reverse一个string,不过做这件事情的确是很容易:
std:
reverse(s.begin(),s.end());
上面是原地反转的方法,如果需要反转到别的string里面,一样简单:
s1.assign(s.rbegin(),s.rend());
效率也相当理想。
解析文件扩展名
字数多点的写法:
stringfilename("
hello.exe"
string:
size_typepos=filename.rfind('
.'
stringext=filename.substr(pos==std:
npos?
filename.length():
pos+1);
不过两行,合并成一行呢?
也不是不可以:
stringext=filename.substr(filename.rfind('
)==std:
filename.rfind('
我知道,rfind执行了两次。
不过第一,你可以希望编译器把它优化掉,其次,扩展名一般都很短,即便多执行一次,区别应该是相当微小。
STL算法
1.distance
2.max,min
3.copy_if
4.惯用手法:
erase(iter++)
5.惯用手法:
erase(remove...)
distance
很多时候我们希望在一个vector,或者list,或者什么其他东西里面,找到一个值在哪个位置,这个时候find帮不上忙,而有人就转而求助手写循环了,而且是原始的手写循环:
for(inti=0;
vect.size();
++i)
if(vect[i]==value)break;
如果编译器把i看作forscope的一部分,你还要把i的声明拿出去。
真的需要这样么?
看看这个:
intdist=
distance(col.begin(),
find(col.begin(),col.end(),5));
其中col可以是很多容器,list,vector,deque...当然这是你确定5就在col里面的情形,如果你不确定,那就加点判断:
intdist;
list<
int>
iteratorpos=find(col.begin(),col.end(),5);
if(pos!
=col.end())
dist=dista
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 常用 技巧