- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
请忽略那里的日本人。
我尝试使用以下代码计算从 stdin 输入的字符串的长度。但它没有按预期工作:
#include <stdio.h>
int main(int argc, const char *argv[]) {
char str[100];
printf("文字列を入力してください:"); // Please enter a string:
fgets(str,99,stdin);
int n = 0;
while (str[n++] != '\0');
printf("文字列の長さは%dです\n", n); // The length of the string is %d\n
return 0;
}
例如,如果我输入
glacious
,我会得到
n=10
,我希望它是
n=8
。
n++
会在
str[n++] != '\0'
得到评估后增加 n,并且
\0
是附加到每个字符串的默认字符。但不知何故,这对我来说没有意义。我知道我可以通过在最后添加
n-=2
来达到我的目的,但我真的很想了解这里发生了什么。提前谢谢了!
最佳答案
“我尝试计算从 stdin 输入的字符串的长度”...“我知道我可以通过在末尾添加 n-=2 来达到我的目的,但我真的很想了解这里发生了什么。”
fgets() 的文档包括以下内容:
"...reads a line from the specified stream and stores it into the string pointed to by str. It stops when either (n-1) characters areread, the newline character is read, or the end-of-file is reached,whichever comes first."
fgets(str,99,stdin);
例如:
if( fgets (str, sizeof str, stdin) != NULL )
{
...
剖析以下内容:给定用户输入值:
"glacious"
,
str
在内存中看起来像这样:
|g|l|a|c|i|o|u|s|\n|\0|?|...|?|
0 1 2 3 4 5 6 7 8 9 10 99
int n = 0;
while(str[n++] != '\0');
迭代:
n at start n at finish
n==0
, str[0]
( g
) != \0
, n++
, n==1
n==1
, str[1]
( l
) != \0
, n++
, n==2
n==2
, str[2]
( a
) != \0
, n++
, n==3
n==3
, str[3]
( c
) != \0
, n++
, n==4
n==4
, str[4]
( i
) != \0
, n++
, n==5
n==5
, str[5]
( o
) != \0
, n++
, n==6
n==6
, str[6]
( u
) != \0
, n++
, n==7
n==7
, str[7]
( s
) != \0
, n++
, n==8
n==8
, str[8]
( \n
) != \0
, n++
, n==9
n==9
, str[9]
( \0
) == \0
, n++
, n==10
n
的最终后增量,将其总数带入
10
以假设用户输入仅为
8
字符。
\n
和最后的后增量(对于
\0) account for the additional value to
n`。总而言之,问题只是调整您的期望以考虑缓冲区中的所有字符,包括您看不到的字符。
n
的计数值并不等同于测量
str
的字符串长度,为此,惯用方法 (
strlen() ) 将产生 9. 给定
definition of a C string ,以下显示了查看
str
的每种相应方法的不同结果,假设初始化:
char str[100] = {0};
而
str
的内容是:
"glacious\n"//null terminator is implied
//method to calculate n in discussion above
// //yields n == 10
int len = strlen(str); //yields n == 9
//after using strcspn()
str[strcspn(str, "\n")] = 0;
len = strlen(str); //yields n == 8
size_t size = sizeof str; //yields size == 100
顺便说一句,如果目标是计算条目的数量,并且可以使用替代方法,请考虑简化该方法......
char str[100];
printf("文字列を入力してください:");
fgets(str,99,stdin);
int n = 0;
while(str[n++] != '\0');
printf("文字列の長さは%dです\n", n);
return 0;
使用这个将在看到
\n
(换行符)或
EOF
(
-1
)(
#define
中的
stdio.h
)时打破循环,从而得到正确的用户输入计数(减去换行符):
int count = 0;
printf("Please enter a string:");
int c = fgetc(stdin);
while(( c != '\n') && (c != EOF))
{
count++; //only increments when c meets criteria
fputc(c, stdout);
c = fgetc(stdin);
}
printf("\n\nThe length of the string is: %d\n", count);
return 0;
关于c - 使用 while(str[n++]! ='\0' ) 计算字符串的长度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65525738/
你信吗?我有一个这样的循环(请原谅任何错误,我不得不大量编辑大量信息和变量名称,相信我它有效)。 ...旧示例已删除,请参见下面的代码... 如果我将那些中间的 str = "Blah\(odat.c
我正在做一个本地测试来比较 C# 中 String 和 StringBuilder 的 Replace 操作性能,但是对于 String 我使用了以下代码: String str = "String
我想知道为什么str += "A"和 str = str + "A"有不同的表现。 在实践中, string str = "cool" for(int i = 0; i approximately
我有一个类型列表 [("['106.52.116.101']", 1), ("['45.136.108.85']", 1)] 并想将其转换为 [('106.52.116.101', 1), ('45.
我有一个类型列表 [("['106.52.116.101']", 1), ("['45.136.108.85']", 1)] 并想将其转换为 [('106.52.116.101', 1), ('45.
我正在遍历 HashMap并通过一些本地变量中的模式匹配将值放入其中。 委托(delegate)者 fn lyrics_no_bottles(song_template:&mut String){
如果字符串(短语)中只有元音,它(对我而言)说True;否则说 False。我不明白为什么它总是返回 False,因为 (x >= x) 总是返回 True。我感谢任何人检查此查询的解决方案。 (st
我有代码以某种方式转换字符串引用,例如取第一个字母 trait Tr { fn trim_indent(self) -> Self; } impl Tr for &'a str { f
我正在学习指针,这是我的代码。我定义了一个指向 char(实际上是字符串)的指针 *str 和一个指向 int *a 的指针,它们的定义方式相同。我认为 str 和 a 都应该是一个地址,但是当我试图
为什么我会收到错误消息?我已经正确添加了类型,对吗? Invalid index type "str" for "Union[str, Dict[str, str]]"; expected type
你知道下面两个函数是否等价吗? function validate(str) { return ( ['null','','undefined'].indexOf(str) [v, valida
我正在解决这里的 Dataquest 问题:https://app.dataquest.io/m/293/data-cleaning-basics/5/removing-non-digit-chara
我有一个字符串列表,如下所示: ["A TB", "A-R TB", "B TB", "B-R TB", "C TB", "C-R TB"...] 但字符串的顺序是随机的。我如何编写一个将元素配对的函
我正在尝试将此函数从使用 split 改为使用 str.extract (正则表达式)。 def bull_lev(x): spl = x.rsplit(None, 2)[-2].strip(
给定这样的数据结构: [{'a':1, 'b': 2}, {'c':3 }, {'a':4, 'c':9}, {'d':0}, {'d': 0, 'b':6}] 目标是解析数据以产生: {'a': 2
给定这样的数据结构: [{'a':1, 'b': 2}, {'c':3 }, {'a':4, 'c':9}, {'d':0}, {'d': 0, 'b':6}] 目标是解析数据以产生: {'a': 2
s = 'someString' s = QTreeWidgetItem(s) print(s.text(0)) # 0 being 'column' 输出: 's' 如果我对另一
黑白有什么区别: function(char* str ) function(char* str[] ) function(char str[] ) 它们是如何被调用的(通过什么类型的string/c
我试过谷歌搜索但找不到准确的答案,所以请允许我尝试在这里提问。如果问题看起来不合适,请告诉我,我会删除它。 在 JS 中,您可以通过三种不同的方式编写特定的内置功能: 字符串长度 str.toStri
我有这段代码(我的 strlen 函数) size_t slen(const char *str) { size_t len = 0; while (*str) {
我是一名优秀的程序员,十分优秀!