关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。
想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。
1年前关闭。
Improve this question
为什么以下片段中的 *str 仅被取消引用一次?它采用字符串 'a' 的第一个字符并不断增加这个值,直到它到达 ASCII 表的末尾,这与我在每次条件评估时取消引用它并导致无限循环的期望相反。即使取消引用从条件移动到循环体,这种行为也会改变。 GCC 7.4.0 版用于测试代码。
int getLen(char *str){
int count=0;
while((*str)++) {
count++;
}
return count;
}
int main(){
char s[]="abc";
printf("length is %d\n",getLen(s));
}
输出:
159
最佳答案
它被取消引用了 159 次,而不仅仅是一次。a
的ASCII值是 97
.如果你增加 159
次,你得到0
.(*str)++
不增加 str
, 它增加 str
中的第一个字符.
它不会增加它“直到它到达 ASCII 表的末尾”,它会增加直到它变成 0
.如果您的 char
type 是有符号的,这意味着它将它增加到该类型的最大值,然后从最小值(负值)增加到 0
.
通常,char
是有符号的和 8 位的。在这种情况下,它将增加到 127
,下一个值将是 -128
之后会不断增加,直到变成0
.
如果您想使用括号来清楚起见,请使用
while (*(str++))
{
count++;
}
那是一样的
while (*str++)
{
count++;
}
关于c++ - 为什么在 C/C++ 的这个 while 循环中解引用只发生一次?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58534502/