Hogyan iterálhatok egy karakterlánc szavain?

I'm megpróbálom végigvenni egy karakterlánc szavait.

A karakterlánc feltételezhetően szóközökkel elválasztott szavakból áll.

Megjegyzendő, hogy nem érdekelnek a C karakterláncfüggvények vagy a karakterek ilyen jellegű manipulációja/hozzáférése. Kérjük, hogy válaszában az eleganciát helyezze előtérbe a hatékonysággal szemben.

A legjobb megoldás, amivel most rendelkezem, a következő:

#include <iostream>
#include <sstream>
#include <string>

using namespace std;

int main()
{
    string s = "Somewhere down the road";
    istringstream iss(s);

    do
    {
        string subs;
        iss >> subs;
        cout << "Substring: " << subs << endl;
    } while (iss);
}

Van ennél elegánsabb megoldás?

Ez a kedvenc módszerem a karakterláncok iterálására. Szavanként azt csinálhatsz, amit csak akarsz.

string line = "a line of text to iterate through";
string word;

istringstream iss(line, istringstream::in);

while( iss >> word )     
{
    // Do something on `word` here...
}
Kommentárok (3)

Az STL még nem rendelkezik ilyen módszerrel.

Viszont vagy használhatjuk a C's [strtok()][1] függvényt az [std::string::c_str()][2] tag használatával, vagy írhatunk sajátot. Íme egy kódminta, amelyet egy gyors Google-keresés után találtam ("STL string split"):

void Tokenize(const string& str,
              vector& tokens,
              const string& delimiters = " ")
{
    // Skip delimiters at beginning.
    string::size_type lastPos = str.find_first_not_of(delimiters, 0);
    // Find first "non-delimiter".
    string::size_type pos     = str.find_first_of(delimiters, lastPos);

    while (string::npos != pos || string::npos != lastPos)
    {
        // Found a token, add it to the vector.
        tokens.push_back(str.substr(lastPos, pos - lastPos));
        // Skip delimiters.  Note the "not_of"
        lastPos = str.find_first_not_of(delimiters, pos);
        // Find next "non-delimiter"
        pos = str.find_first_of(delimiters, lastPos);
    }
}

A következő címből vettük:

Ha kérdésed van a kódmintával kapcsolatban, hagyj egy megjegyzést, és elmagyarázom.

És csak azért, mert nem implementál egy typedef nevű iterátort vagy nem terheli túl a `

Kommentárok (10)

Az std::stringstream használata tökéletesen működik, és pontosan azt teszi, amit akartál. Ha azonban másképp szeretnéd csinálni a dolgokat, használhatod az [std::find()][1]/[std::find_first_of()][2] és az [std::string::substr()][3]-t.

Íme'egy példa:


#include 
#include 

int main()
{
    std::string s("Somewhere down the road");
    std::string::size_type prev_pos = 0, pos = 0;

    while( (pos = s.find(' ', pos)) != std::string::npos )
    {
        std::string substring( s.substr(prev_pos, pos-prev_pos) );

        std::cout 
Kommentárok (1)