更新时间:2020-10-30 17:28:35 来源:极悦 浏览6592次
字符串在存储上类似字符数组,所以它每一位的单个元素都是可以提取的,同理,字符串也是可以分割的。当然,字符串分割需要借助一些工具,比如一些函数和正则表达式。本我们就为大家梳理一些字符串分割的一些方式。
一、用strtok函数进行字符串分割
原型: char *strtok(char *str, const char *delim);
功能:分解字符串为一组字符串。
参数说明:str为要分解的字符串,delim为分隔符字符串。
返回值:从str开头开始的一个个被分割的串。当没有被分割的串时则返回NULL。
其它:strtok函数线程不安全,可以使用strtok_r替代。
示例:
//借助strtok实现split
#include
#include
int main()
{
char s[] = "Golden Global View,disk * desk";
const char *d = " ,*";
char *p;
p = strtok(s,d);
while(p)
{
printf("%s\n",p);
p=strtok(NULL,d);
}
return 0;
}
运行效果图:
二、用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::vectorsplit(std::string str,std::string pattern)
{
std::string::size_type pos;
std::vectorresult;
str+=pattern;//扩展字符串以方便操作
int size=str.size();
for(int i=0; i<size; p="" i++)<="">
{
pos=str.find(pattern,i);
if(pos<size)< p="">
{
std::string s=str.substr(i,pos-i);
result.push_back(s);
i=pos+pattern.size()-1;
}
}
return result;
}
View Code
运行效果:
三、用Boost进行字符串的分割
用boost库的正则表达式实现字符串分割
实现如下:
std::vectorsplit(std::string str,std::string s)
{
boost::regex reg(s.c_str());
std::vectorvec;
boost::sregex_token_iterator it(str.begin(),str.end(),reg,-1);
boost::sregex_token_iterator end;
while(it!=end)
{
vec.push_back(*it++);
}
return vec;
}
View Code
运行效果:
总的来说,字符串分割还是要靠一些函数和其他方法,字符串本身是没有自我分割的能力的。字符串的相关知识其实都是Java的基础,对于这方面有提升意向的小伙伴可以观看本站的Java基础教程,为自己的Java基础查漏补缺!
0基础 0学费 15天面授
Java就业班有基础 直达就业
业余时间 高薪转行
Java在职加薪班工作1~3年,加薪神器
工作3~5年,晋升架构
提交申请后,顾问老师会电话与您沟通安排学习