組み込みシステムで入力を解析しようとしています。私はこのようなものを期待しています:
SET VARNAME=1,2,3,4,5,6,7,8,9,10\0
個別の文字列を int に変換しているときに、文字列が 8 で始まる場合、両方とも 0 を返しているようですatoi()
。strtol()
これが私のコードです:
char *pch, *name, *vars;
signed long value[256];
int i;
#ifdef UARTDEBUG
char convert[100];
#endif
if(strncmp(inBuffer, "SET",3)==0)
{
pch = strtok(inBuffer," ");
pch = strtok(NULL," ");
name = strtok(pch, "=");
vars = strtok(NULL,"=");
pch = strtok(vars,",");
i = 0;
while(pch != NULL)
{
value[i] = atoi(pch);
#ifdef UARTDEBUG
snprintf(convert, sizeof(convert), "Long:%d=String:\0", value[i]);
strncat(convert, pch, 10);
SendLine(convert);
#endif
i++;
pch = strtok(NULL,",");
// Check for overflow
if(i > sizeof(value)-1)
{
return;
}
}
SetVariable(name, value, i);
}
それを渡す:
SET VAR=1,2,3,4,5,6,7,8,9,10\0
私のuartデバッグで次のようになります:
Long:1=String:1
Long:2=String:2
Long:3=String:3
Long:4=String:4
Long:5=String:5
Long:6=String:6
Long:7=String:7
Long:0=String:8
Long:9=String:9
Long:10=String:10
アップデート:
「value[i] = atoi(pch);」の前後に inBuffer をチェックしました。それは同一であり、適切なポイントで分割されているように見えます。
S E T V A R 1 2 3 4 5 6 7 8 9 , 1 0
53 45 54 00 56 41 52 00 31 00 32 00 33 00 34 00 35 00 36 00 37 00 38 00 39 2c 31 30 00 00 00 00
更新 2:
私の UARTDEBUG セクションは現在次のようになっています。
#ifdef UARTDEBUG
snprintf(convert, 20, "Long:%ld=String:%s", value[i], pch);
SendLine(convert);
#endif
行をコメントアウトするとsnprintf()
、すべてが完全に機能します。それで、それで何が起こっているのですか?