C编程:使用getline后strcmp的意外结果

时间:2016-05-17 04:37:28

标签: c getline strcmp

我正在编写一个C程序,它将从stdin获取命令列表并执行它们。从stdin读入后使用strcmp我得到了意想不到的结果。

这是我的程序test_execvp.c

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/wait.h> 

int main(int argc, char const *argv[])
{
    char * line_buffer[100];
    size_t line_len;
    int cmd_count = 0;
    char * cmd_buffer[100][100];

   for( line_buffer[cmd_count] = NULL; getline(&line_buffer[cmd_count], &line_len, stdin) > 0; line_buffer[++cmd_count] = NULL)
   {
        line_buffer[cmd_count][strcspn(line_buffer[cmd_count], "\r\n")] = 0;
        int cmd = 0;
        while( (cmd_buffer[cmd_count][cmd] = strsep(&line_buffer[cmd_count], " ")) != NULL )
        {
            cmd++;
        }
    }


    printf("cmd_buffer[0][0]: \"%s\"\n", cmd_buffer[0][0]);
    printf("cmd_buffer[0][1]: \"%s\"\n", cmd_buffer[0][1]);
    printf("cmd_buffer[0][2]: \"%s\"\n", cmd_buffer[0][2]);
    printf("strcmp(cmd_buffer[0][1], \"-i\") == %d\n", strcmp(cmd_buffer[0][1], "-i") );
    printf("strcmp(cmd_buffer[0][1], \"-o\") == %d\n", strcmp(cmd_buffer[0][1], "-o") );

}

现在看到这个输出:

Emil@EMIL-HP ~/Emil
$ gcc test_execvp.c -o test_execvp

Emil@EMIL-HP ~/Emil
$ cat cmdfile2
./addone –i add.txt
./addone
./addone –o add.txt

Emil@EMIL-HP ~/Emil
$ ./test_execvp < cmdfile2
cmd_buffer[0][0]: "./addone"
cmd_buffer[0][1]: "–i"
cmd_buffer[0][2]: "add.txt"
strcmp(cmd_buffer[0][1], "-i") == 181
strcmp(cmd_buffer[0][1], "-o") == 181

我不明白这行:

printf("strcmp(cmd_buffer[0][1], \"-i\") == %d\n", strcmp(cmd_buffer[0][1], "-i") );

可以产生输出:

strcmp(cmd_buffer[0][1], "-i") == 181

如果行:

printf("cmd_buffer[0][1]: \"%s\"\n", cmd_buffer[0][1]);

产生输出:

cmd_buffer[0][1]: "–i"

2 个答案:

答案 0 :(得分:2)

如果strcmp是&#34; -i&#34;,那么BoxCenter-SphereCenter将返回0.但它不是。仔细观察,你会发现它是&#34; -i&#34;,这是一个不同的角色。 (它的长度和多字节。)

答案 1 :(得分:2)

您的文本文件包含-的一些unicode同形文字,而不是实际的-。这很清楚,因为181+'-'0xe2,是3字节字符的前导字节。