C中带\ 0的字符串的长度

时间:2019-03-17 12:28:53

标签: c input strlen

我将用户的输入读为:

scanf("%[^\n]", message); 

现在我初始化char消息[100] ="";,在另一个函数中,我需要找出消息中输入的长度,我很容易用strlen()来完成它,不幸的是,当我这样做时,它不能正常工作稍后在终端

echo -e "he\0llo" | .asciiart 50 

它将读取整个输入,但strlen仅返回长度2。

还有其他方法可以找出输入的长度吗?

1 个答案:

答案 0 :(得分:0)

根据定义 strlen 停在空字符上

读取字符串后,您必须计算/读取EOF和/或换行符,而不是计算空字符

如评论中所述,%n允许获取读取的字符数,例如:

#include <stdio.h>

int main()
{
  char message[100] = { 0 };
  int n;

  if (scanf("%99[^\n]%n", message, &n) == 1)
    printf("%d\n", n);
  else
    puts("empty line or EOF");
}

编译和执行:

pi@raspberrypi:/tmp $ gcc -g c.c
pi@raspberrypi:/tmp $ echo "" | ./a.out
empty line or EOF
pi@raspberrypi:/tmp $ echo -n "" | ./a.out
empty line or EOF
pi@raspberrypi:/tmp $ echo -e "he\0llo" | ./a.out
6
pi@raspberrypi:/tmp $ 

如您所见,无法区分空行和EOF(即使查看 errno

您也可以使用ssize_t getline(char **lineptr, size_t *n, FILE *stream);

#include <stdio.h>
#include <stdlib.h>

int main()
{
  char *lineptr = NULL;
  size_t n = 0;
  ssize_t sz = getline(&lineptr, &n, stdin);

  printf("%zd\n", sz);

  free(lineptr);
}

但在这种情况下,可能的换行符已获得并计数:

pi@raspberrypi:/tmp $ gcc -pedantic -Wextra -g c.c
pi@raspberrypi:/tmp $ echo -e "he\0llo" | ./a.out
7
pi@raspberrypi:/tmp $ echo -e -n "he\0llo" | ./a.out
6
pi@raspberrypi:/tmp $ echo "" | ./a.out
1
pi@raspberrypi:/tmp $ echo -n "" | ./a.out
-1