如何快速解析以分号相隔的字符串?

原始需求就是如何解析形如:
"a,b,c,1,21,2"这样的字符串?
我尝试了sscanf等方法,也在sscanf中使用了正则表达式,但是发现如果上述字符串有空值时(就是"a,b,c,1,21,2"是"a,b,c,,,2"),就不能正确解析。
目前我是这样做的:
sub = a.substr(0,a.find_first_of(","));
item->Setbase_type(atoi(sub.c_str()));
a = a.substr(sub.length()+1);
循环。。

这种方法可以定位到“,”,当“,”前面为空的时候也能得到空串而不是异常。

问题是,当数据比较大,有四五十个“,”间隔时,代码量很大。
有没有什么简单的方法来解析?

谢谢了!

楼主是要这种吗

 #include<iostream>
#include<string.h>
using namespace std;

void main()
{
    string str = "a,b,c,,1,21,2,";
    char buffer[32] = {0};
    while(1)
    {
        sscanf(str.c_str(), "%[^,]", buffer);
        cout << buffer << endl;
        if(str.length() >= 1 + strlen(buffer))
            str = str.substr(1 + strlen(buffer));
        else
            break;
        memset(buffer, 0, 32);
    }
}

图片说明

正则表达式“,"换成",+"

char *s = "aaa,,ccc,ddd";
char a[32] = {0},b[32] = {0},c[32] = {0},d[32] = {0};

//sscanf(s, "%s,%s,%s,%s\n", a, b, c, d);



sscanf(s, "%[^,],%[^,],%[^,],%s", a, b, c, d);
printf("[%s][%s][%s][%s]\n", a, b, c, d);

输出a有值 bcd没有值 为什么
 char *s = "aaa,,ccc,ddd";
char a[32] = {0},b[32] = {0},c[32] = {0},d[32] = {0};

//sscanf(s, "%s,%s,%s,%s\n", a, b, c, d);



sscanf(s, "%[^,],%[^,],%[^,],%s", a, b, c, d);
printf("[%s][%s][%s][%s]\n", a, b, c, d);

输出a有值 bcd没有值 为什么