更新時間:2020-10-30 17:28:35 來源:動力節點 瀏覽6907次
字符串在存儲上類似字符數組,所以它每一位的單個元素都是可以提取的,同理,字符串也是可以分割的。當然,字符串分割需要借助一些工具,比如一些函數和正則表達式。本我們就為大家梳理一些字符串分割的一些方式。
一、用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天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習