作者:康小白Code
字符串切割的使用频率还是挺高的,string本身没有提供切割的方法,但可以使用stl提供的封装进行实现或者通过c函数strtok()函数实现。
1、通过stl实现
涉及到string类的两个函数find和substr:
1、find函数
原型:size_t find ( const string& str, size_t pos = 0 ) const;
功能:查找子字符串第一次出现的位置。
参数说明:str为子字符串,pos为初始查找位置。
返回值:找到的话返回第一次出现的位置,否则返回string::npos
2、substr函数
原型:string substr ( size_t pos = 0, size_t n = npos ) const;
功能:获得子字符串。
参数说明:pos为起始位置(默认为0),n为结束位置(默认为npos)
返回值:子字符串
代码如下:
- std::vector<std::string> splitWithStl(const std::string &str,const std::string &pattern)
- {
- std::vector<std::string> resVec;
- if ("" == str)
- {
- return resVec;
- }
- //方便截取最后一段数据
- std::string strs = str + pattern;
- size_t pos = strs.find(pattern);
- size_t size = strs.size();
- while (pos != std::string::npos)
- {
- std::string x = strs.substr(0,pos);
- resVec.push_back(x);
- strs = strs.substr(pos+1,size);
- pos = strs.find(pattern);
- }
- return resVec;
- }
版权声明:本文为CSDN博主「康小白Code」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/k_bb_666/java/article/details/77651524