第一,一般来说最后的那个分号是没有的
第二,一般来说分割符也是不固定的,今天是=和;明天有可能就变成了=和:
第三,代码要简洁
下面说说我做这件事情的过程
1.最早的时候时直接将分隔符嵌在代码里,并且采用了一个while循环后面加上处理最后一个对的方法,代码如下:
char *begin = line,*end;
while((end = strchr(line,':')) != NULL){
char *v = strchr(begin,'=');
char *k = begin;
*v = 0;
v++;
*end = 0;
begin = end + 1;
}
char *v = strchr(begin,'=');
char *k = begin;
*v = 0;
v++;
2, 将分隔符作为参数传入,但代码总体结构不变
3.今天又遇到了这样的事,又要写这样的代码,实在是不想要while外面那一段了,第一想法是用do while,但明显不行,最后分析begin和end的变化,end开始是NULL,结束时也是NULL,并且当end为NULL时处理并没有结束,而begin却是从line变化到NULL,并且当beign==NULL时,处理结束,于是代码改成如下:
while(begin != NULL){
end = strchr(begin,delimiter);
if(end == NULL)
begin = NULL;
else{
*end = 0;
begin = end + 1;
}
}
ok,done!
第二,一般来说分割符也是不固定的,今天是=和;明天有可能就变成了=和:
第三,代码要简洁
下面说说我做这件事情的过程
1.最早的时候时直接将分隔符嵌在代码里,并且采用了一个while循环后面加上处理最后一个对的方法,代码如下:
char *begin = line,*end;
while((end = strchr(line,':')) != NULL){
char *v = strchr(begin,'=');
char *k = begin;
*v = 0;
v++;
*end = 0;
begin = end + 1;
}
char *v = strchr(begin,'=');
char *k = begin;
*v = 0;
v++;
2, 将分隔符作为参数传入,但代码总体结构不变
3.今天又遇到了这样的事,又要写这样的代码,实在是不想要while外面那一段了,第一想法是用do while,但明显不行,最后分析begin和end的变化,end开始是NULL,结束时也是NULL,并且当end为NULL时处理并没有结束,而begin却是从line变化到NULL,并且当beign==NULL时,处理结束,于是代码改成如下:
while(begin != NULL){
end = strchr(begin,delimiter);
if(end == NULL)
begin = NULL;
else{
*end = 0;
begin = end + 1;
}
}
ok,done!