我已经查看了其他问题等,我已经看到你不能在strtok中有一个无法编辑的第一个参数,但我不认为我在这段代码中有,但仍然得到一个seg错误??我是不是用错了strtok?
此代码将获取csv逗号分隔格式的stdin,并将stdin中的数字相加,然后将其打印到stdout,p.s.当token不是指针的时候,我让它工作了。i+= token;,但我得到的是随机输出,我想是这样的。
#include <stdio.h>
#include <string.h>
int main(){
char *token, input[256];
int i = 0;
scanf("%s" , input);
token = strtok (input, ",");
while(token != NULL){
token = strtok(NULL, ",");
i += *token;
}
printf("%d\n", i);
return 0;
}谢谢Lachlan
发布于 2012-04-13 16:19:49
在某些情况下,strtok会返回NULL,您不会检查它:
token = strtok(NULL, ",");
i += *token; /* Will dereference NULL. */相反,你应该做的是:
while(token != NULL){
i += *token; /* We know `token` isn't NULL. */
token = strtok(NULL, ",");
}顺便说一句,你正在做的事情--添加字符值--意义不大。您可能希望以某种方式转换它们,可能是使用strto(u)l。
发布于 2012-04-13 16:21:26
在执行i+=*token之前,您需要将字符串转换为整数,看看strtol等将字符串转换为整数的函数。
https://stackoverflow.com/questions/10137453
复制相似问题