C++常用技巧.docx

上传人:b****1 文档编号:2374872 上传时间:2022-10-29 格式:DOCX 页数:17 大小:23.17KB
下载 相关 举报
C++常用技巧.docx_第1页
第1页 / 共17页
C++常用技巧.docx_第2页
第2页 / 共17页
C++常用技巧.docx_第3页
第3页 / 共17页
C++常用技巧.docx_第4页
第4页 / 共17页
C++常用技巧.docx_第5页
第5页 / 共17页
点击查看更多>>
下载资源
资源描述

C++常用技巧.docx

《C++常用技巧.docx》由会员分享,可在线阅读,更多相关《C++常用技巧.docx(17页珍藏版)》请在冰豆网上搜索。

C++常用技巧.docx

C++常用技巧

字符串处理

1.toupper,tolower

2.trim

3.erase

4.replace

5.startwith、endwith

6.类型转换

7.split

8.concat

9.reverse

10.解析文件扩展名

toupper,tolower

地球人都知道C++的string没有toupper,好在这不是个大问题,因为我们有STL算法:

strings("heLLo");

transform(s.begin(),s.end(),s.begin(),:

:

toupper);

cout<

transform(s.begin(),s.end(),s.begin(),:

:

tolower);

cout<

当然,我知道很多人希望的是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);

   cout<

注意由于find_first_not_of和find_last_not_of都可以接受字符串,这个时候它们寻找该字符串中所有字符的absence,所以你可以一次trim掉多种字符。

-----------------------------------------------------------------------

erase

string本身的erase还是不错的,但是只能erase连续字符,如果要拿掉一个字符串里面所有的某个字符呢?

用STL的erase+remove_if就可以了,注意光remove_if是不行的。

   strings("  hello,world.saybye  ");

   s.erase(remove_if(s.begin(),s.end(),

       bind2nd(equal_to(),'')),

   s.end());

上面的这段会拿掉所有的空格,于是得到hello,world.saybye。

-----------------------------------------------------------------------

replace

string本身提供了replace,不过并不是面向字符串的,譬如我们最常用的把一个substr换成另一个substr的操作,就要做一点小组合:

   strings("hello,world");

   stringsub("ello,");

   s.replace(s.find(sub),sub.size(),"appy");

   cout<

输出为happyworld。

注意原来的那个substr和替换的substr并不一定要一样长。

-----------------------------------------------------------------------

startwith,endwith

这两个可真常用,不过如果你仔细看看string的接口,就会发现其实没必要专门提供这两个方法,已经有的接口可以干得很好:

   strings("hello,world");

   stringhead("hello");

   stringtail("ld");

   boolstartwith=pare(0,head.size(),head)==0;

   cout<

   boolendwith=pare(s.size()-tail.size(),tail.size(),tail)==0;

   cout<

当然了,没有s.startwith("hello")这样方便。

------------------------------------------------------------------------

toint,todouble,tobool...

这也是老生常谈了,无论是C的方法还是C++的方法都可以,各有特色:

   strings("123");

   inti=atoi(s.c_str());

   cout<

   

   intii;

   stringstream(s)>>ii;

   cout<

   

   stringsd("12.3");

   doubled=atof(sd.c_str());

   cout<

   

   doubledd;

   stringstream(sd)>>dd;

   cout<

   

   stringsb("true");

   boolb;

   stringstream(sb)>>boolalpha>>b;

   cout<

C的方法很简洁,而且赋值与转换在一句里面完成,而C++的方法很通用。

------------------------------------------------------------------------

split

这可是件麻烦事,我们最希望的是这样一个接口:

s.split(vect,',')。

用STL算法来做有一定难度,我们可以从简单的开始,如果分隔符是空格、tab和回车之类,那么这样就够了:

   strings("helloworld,bye.");

   vectorvect;

   vect.assign(

       istream_iterator(stringstream(s)),

       istream_iterator()

   );

不过要注意,如果s很大,那么会有效率上的隐忧,因为stringstream会copy一份string给自己用。

------------------------------------------------------------------------

concat

把一个装有string的容器里面所有的string连接起来,怎么做?

希望你不要说是handcode循环,这样做不是更好?

   vectorvect;

   vect.push_back("hello");

   vect.push_back(",");

   vect.push_back("world");

   

   cout<

不过在效率上比较有优化余地。

-------------------------------------------------------------------------

reverse

其实我比较怀疑有什么人需要真的去reverse一个string,不过做这件事情的确是很容易:

 std:

:

reverse(s.begin(),s.end());

上面是原地反转的方法,如果需要反转到别的string里面,一样简单:

 s1.assign(s.rbegin(),s.rend());

效率也相当理想。

-------------------------------------------------------------------------

解析文件扩展名

字数多点的写法:

   std:

:

stringfilename("hello.exe");

   std:

:

string:

:

size_typepos=filename.rfind('.');

   std:

:

stringext=filename.substr(pos==std:

:

string:

:

npos?

filename.length():

pos+1);

不过两行,合并成一行呢?

也不是不可以:

   std:

:

stringext=filename.substr(filename.rfind('.')==std:

:

string:

:

npos?

filename.length():

filename.rfind('.')+1);

我知道,rfind执行了两次。

不过第一,你可以希望编译器把它优化掉,其次,扩展名一般都很短,即便多执行一次,区别应该是相当微小。

STL算法

1.distance

2.max,min

3.copy_if

4.惯用手法:

erase(iter++)

5.惯用手法:

erase(remove...)

distance

很多时候我们希望在一个vector,或者list,或者什么其他东西里面,找到一个值在哪个位置,这个时候find帮不上忙,而有人就转而求助手写循环了,而且是原始的手写循环:

for(inti=0;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:

:

iteratorpos=find(col.begin(),col.end(),5);

   if(pos!

=col.end())

       dist=dista

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 总结汇报 > 学习总结

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1