字符串未正确标记

string is not tokenized properly

我正在对 ip 地址应用一个公式。但它有时会给我一些随机输出,这很奇怪。有时它没有正确标记化,有时它给出 0 值。在 1000 个样本中,错误再生率几乎为 2-5。
调用函数 = 公式(IPADDRESS); 我每秒调用数百个不同的 IP。

 int formula ( char ip[]){

            char *token = NULL;
            unsigned long value;
            int finalv;
            char ipaddress[16];
            char delims[]=".";        
            int octet=3;
            value = 0;
            FILE *fp;
            fp = fopen(LOGFILE, "a");
            strcpy(ipaddress,ip);
            fprintf(fp, "%s\n",ipaddress);
            token = strtok( ipaddress,delims);

            while( token != NULL ) {
               fprintf(fp,"%d",(atoi(token));
               if ( atoi(token) != 0 ){
                    if(octet ==3)
                            value = value + (255 * 255 * 255 * (atoi(token)));
                    else if(octet ==2)
                            value = value + (255 * 255 * (atoi(token)));
                    else if(octet ==1)
                            value = value + (255 * (atoi(token)));
                    else if(octet ==0)
                            value = value + (atoi(token));
               }
                    octet--;
               token = strtok( NULL,delims);
            }

            finalv = value % 9999;

            fprintf(fp, " -- %d \n",(int)finalv);
            if(fp)
                    fclose(fp);
            return (int)v;
    }

输出文件: (我只给出了错误的输出)

172.17.82.255
 172  0  1  -- 1983
--
172.254.254.254
 172  0  0  0  -- 1728
--
172.255.255.225
 172  0  -- 1728
--
172.255.255.255
 172  21  0  1  -- 7390
--
172.255.84.255
 172  0  8  -- 3768

您要重新声明 token:

        char *token = NULL;  // <-- here
        unsigned long value;
        int finalv;
        char ipaddress[16];
        char token[]=".";    // <-- and here

然后,在代码的后面,您对应该在哪个上下文中使用哪个 token 感到困惑。这在这里特别明显:

token = strtok( NULL,token);

...第一个标记可能是指针,第二个标记是数组。

请注意,我什至对它进行了编译感到有点惊讶,但是你的编译器至少没有警告你吗?

编辑:在 "updated" 代码中,

fp = fopen(LOGFILE, token);

tokenNULL 时执行,这会导致未定义的行为。你是说

fp = fopen(LOGFILE, "w");

?

改变

token = strtok( NULL,token);

token = strtok(NULL,".");

PS: 因为你每秒调用这个函数几百次,最好在函数外打开和关闭文件

不是循环 strtok()
int a=0, b=0, c=0, d=0 ;
int value ;
sscanf( ip, "%d.%d.%d.%d", &a, &b, &c, &d );
value = ( ( a * 255 + b ) * 255 + c ) * 255 + d ;
finalv = value % 9999

我认为应该给你同样的答案。 (尽管正如评论中指出的那样,255s 可能意味着 256)。