c /c++實現split, 高效

//自帶strtokios

 

貼一個C實現的函數:
調用示例:
#define MAX_COLS 10
  char src[256];
char *cols[MAX_COLS];
  int count;
  int i;
  strcpy(src, "aa aa bbc cccd");
count = splitEx(src, ' ', cols, MAX_COLS);
  for (i=0; i<count; i++)
  {
       printf("%d. %s\n", i+1, cols[i]);
  }

int splitEx(char *src, const char seperator, char **pCols, const int nMaxCols)
{
        char *p;
        char **pCurrent;
        int count = 0;

        if (nMaxCols <= 0)
        {
                return 0;
        }

        p = src;
        pCurrent = pCols;

        while (true)
        {
                *pCurrent = p;
                pCurrent++;

                count++;
                if (count >= nMaxCols)
                {
                        break;
                }

                p = strchr(p, seperator);
                if (p == NULL)
                {
                        break;
                }

                *p = '\0';
                p++;
        }

        return count;
}c++

 

//c++///////////////////////////////////////////////////////////web

#include <string>
#include <iostream>
#include <vector>函數

using namespace std;spa

int main()
{
        string test = "aa aa bbc cccd";
        vector<string> strvec;
        string strtemp;
       
        string::size_type pos1, pos2;
        pos2 = test.find(' ');
        pos1 = 0;       
        while (string::npos != pos2)
        {
                strvec.push_back(test.substr(pos1, pos2 - pos1));
               
                pos1 = pos2 + 1;
                pos2 = test.find(' ', pos1);
        }
        strvec.push_back(test.substr(pos1));
       
        vector<string>::iterator iter1 = strvec.begin(), iter2 = strvec.end();
        while (iter1 != iter2)
        {
                cout << *iter1 << endl;
                ++iter1;
        }
       
        return 0;
}orm

相關文章
相關標籤/搜索