1.toupper, tolower
#include <iostream>#include <iostream> #include <fstream> #include <algorithm> #include <vector> #include <iterator>
#include <cctypes>
string s("heLLo");transform(s.begin(), s.end(), s.begin(), toupper);cout << s << endl;transform(s.begin(), s.end(), s.begin(), tolower);cout << s << endl;
2.trimstring s(" hello "); s.erase(0, s.find_first_not_of(" /n")); cout << s << endl; s.erase(s.find_last_not_of('' '') + 1); cout << s << endl;
注意由于 find_first_not_of 和 find_last_not_of 都可以接受字符串,这个时候它们寻找该字符串中所有字符的 absence ,所以你可以一次 trim 掉多种字符。
3.erase
string 本身的 erase 还是不错的,但是只能 erase 连续字符,如果要拿掉一个字符串里面所有的某个字符呢?用 STL 的 erase + remove_if 就可以了,注意光 remove_if 是不行的。
string s(" hello, world. say bye "); s.erase(remove_if(s.begin(),s.end(), bind2nd(equal_to<char>(), '' '')), s.end());
上面的这段会拿掉所有的空格,于是得到 hello,world.saybye。
4.replacestring 本身提供了 replace ,不过并不是面向字符串的,譬如我们最常用的把一个 substr 换成另一个 substr 的操作,就要做一点小组合:
string s("hello, world"); string sub("ello, "); s.replace(s.find(sub), sub.size(), "appy "); cout << s << endl;
输出为 happy world。注意原来的那个 substr 和替换的 substr 并不一定要一样长。
5.startwith, endwith这两个可真常用,不过如果你仔细看看 string 的接口,就会发现其实没必要专门提供这两个方法,已经有的接口可以干得很好:
string s("hello, world"); string head("hello"); string tail("ld"); bool startwith = s.compare(0, head.size(), head) == 0; cout << boolalpha << startwith << endl; bool endwith = s.compare(s.size() - tail.size(), tail.size(), tail) == 0; cout << boolalpha << endwith << endl;
当然了,没有 s.startwith("hello") 这样方便。
6.toint, todouble, tobool... string s("123"); int i = atoi(s.c_str()); cout << i << endl; int ii; stringstream(s) >> ii; cout << ii << endl; string sd("12.3"); double d = atof(sd.c_str()); cout << d << endl;
double dd; stringstream(sd) >> dd; cout << dd << endl; string sb("true"); bool b; stringstream(sb) >> boolalpha >> b; cout << boolalpha << b << endl;
7.切割字符串
#include <sstream>#include <string>#include <iostream>using namespace std;int main(){ string text = "big|dog|china|sonic|free"; stringstream ss(text); string sub_str; while(getline(ss,sub_str,'|')) //以|为间隔分割test的内容 cout << sub_str << endl; return 0;}
8.concat把一个装有 string 的容器里面所有的 string 连接起来,怎么做?希望你不要说是 hand code 循环,这样做不是更好?
vector<string> vect; vect.push_back("hello"); vect.push_back(", "); vect.push_back("world"); cout << accumulate(vect.begin(), vect.end(), string(""));
9.取文件的扩展名
std::string filename("hello.exe");
std::string::size_type pos = filename.rfind(''.''); std::string ext = filename.substr(pos == std::string::npos ? filename.length() : pos + 1);
不过两行,合并成一行呢?也不是不可以:
std::string ext = filename.substr(filename.rfind(''.'') == std::string::npos ? filename.length() : filename.rfind(''.'') + 1);
我知道,rfind 执行了两次。不过第一,你可以希望编译器把它优化掉,其次,扩展名一般都很短,即便多执行一次,区别应该是相当微小。