由于某种原因,当我输入/bin/echo
后再输入enter时,strlen在这里说14应该是10。我似乎不知道为什么。
char buffer[BUF_SIZE]; // BUF_SIZE = 100
ssize_t readIn = read(STDIN_FILENO, &buffer, BUF_SIZE);
printf("strlen=%lu\n", strlen(buffer));
与/
字符有关吗?
编辑:
这是当我一次遍历一个字符时缓冲区输出的内容:
#0: c=/ / hex=2f
#1: c=b / hex=62
#2: c=i / hex=69
#3: c=n / hex=6e
#4: c=/ / hex=2f
#5: c=e / hex=65
#6: c=c / hex=63
#7: c=h / hex=68
#8: c=o / hex=6f
#9: c=
/ hex=a
#10: c= / hex=5
#11: c=? / hex=ffffff90
#12: c=? / hex=ffffffff
#13: c= / hex=7f
答案 0 :(得分:7)
strlen()
用于确定字符串的长度。在C语言中, string 的末尾带有 null字符,否则它不是字符串。除非读取的数据包含空字符,否则它不是字符串。
相反,请使用read()
的返回值来确定读取的长度。要打印ssize_t
,请转换为宽型,例如long long
或intmax_t
(更好),因为ssize_t
缺少指定的打印说明符。 1 2
注意:因为不需要&
,所以将其从缓冲区中删除。
char buffer[BUF_SIZE]; // BUF_SIZE = 100
// ssize_t readIn = read(STDIN_FILENO, &buffer, BUF_SIZE);
ssize_t readIn = read(STDIN_FILENO, buffer, BUF_SIZE);
// printf("strlen=%lu\n", strlen(buffer));
printf("length = %lld\n", (long long) readIn);
// or
printf("length = %jd\n", (intmax_t) readIn);
1 Linux Programmer's Manual确实具有“ z:以下整数转换对应于size_t
或
ssize_t
参数”,因此其中的代码可以使用printf("length = %zd\n", readIn);
2 POSIX允许使用更宽的类型或signed analog of size_t
。
答案 1 :(得分:4)
问题在于read
不会在buffer
中放入空终止符。如果您使用valgrind
运行程序,则几乎可以肯定会看到有关无效读取的错误,因为buffer
未初始化。
您有几种选择:
read
,而是会自动添加空终止符的东西。read
,但手动添加空终止符。 buffer[readIn] = '\0'
是一个幼稚的解决方案(缺少错误和边界检查)。buffer
初始化为空终止符。如果您输入的内容大于BUF_SIZE
,此功能将无效。请注意。