C での文字列の基本的な使用法を学習しているときに、sstream の isstringstream[1] がコンソールのような方法で文字列を入力できることを発見しました。実際、この動作は文字列を入力するためにスペースを使用するのと同じです。
そこで、この機能を利用して文字列分割関数split
string src("Avatar 123 5.2 Titanic K"); istringstream istrStream(src); //建立src到istrStream的联系 string s1, s2; int n; double d; char c; istrStream >> s1 >> n >> d >> s2 >> c; //以空格为分界的各数值则输入到了对应变量上
実装の詳細#を実装できるのではないかと考えました。
js と同じように関数呼び出しで簡単に加工後の文字列配列を取得し、c の実情に合わせてパラメータを調整するのが目的です。1. 入力と出力:
string* split(int& length, string str, const char token = ' ')
渡します: 文字列 str、区切り文字トークン (デフォルトのパラメータ)はスペースです)、および参照パラメータの長さ (処理後に動的に割り当てられた配列の長さを示します)
2. データ透過処理: istringstream はスペースを cin と同様に扱うため、はデータ間の境界であるため、区切り文字がスペースでない場合は、受信した区切り文字をスペースに置き換える必要があり、元のスペースは事前に透過的に処理する必要があります。
文字の置換は、ライブラリ アルゴリズムの replace() を使用します [ 2]
const char SPACE = 0; if(token!=' ') { // 先把原有的空格替换为ASCII中的不可见字符 replace(str.begin(), str.end(), ' ', SPACE); // 再把分隔符换位空格,交给字符串流处理 replace(str.begin(), str.end(), token, ' '); }
假设输入字符串为:"a b,c,d,e,f g" 分隔符为非空格:',' 则被替换为:"aSPACEb c d e fSPACEg"
3. データのセグメント化:
//实例化一个字符串输入流,输入参数即待处理字符串 istringstream i_stream(str); //将length置零 length = 0; queue<string> q; //用一个string实例s接收输入流传入的数据,入队并计数 string s; while (i_stream>>s) { q.push(s); length++; }
4. 配列の生成:
//根据计数结果动态开辟一个字符串数组空间 string* results = new string[length]; //将队列中的数据转入数组中 for (int i = 0; i < length; i++) { results[i] = q.front(); //将替换掉的空格进行还原 if(token!=' ') replace(results[i].begin(), results[i].end(), SPACE, ' '); q.pop(); }
#完全なコード 以上がC++で文字列分割関数splitを実装するにはどうすればよいですか? (コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。#include <iostream>
#include <string>
#include <queue>
#include <sstream>
#include <algorithm>
using namespace std;
string* split(int& length, string str,const char token = ' ') {
const char SPACE = 0;
if(token!=' ') {
replace(str.begin(), str.end(), ' ', SPACE);
replace(str.begin(), str.end(), token, ' ');
}
istringstream i_stream(str);
queue<string> q;
length = 0;
string s;
while (i_stream>>s) {
q.push(s);
length++;
}
string* results = new string[length];
for (int i = 0; i < length; i++) {
results[i] = q.front();
q.pop();
if(token!=' ') replace(results[i].begin(), results[i].end(), SPACE, ' ');
}
return results;
}
//测试:
int main() {
int length;
string* results = split(length, "a b,c,d,e,f g", ',');
for (int i = 0; i < length; i++) cout<<results[i]<<endl;
return 0;
}