为什么我们需要在C中的字符数组末尾添加’\ 0’(null)?

为什么我们需要在C中的字符数组末尾添加’\ 0’(null)? 我在K&R 2(1.9字符数组)中读到过它。 书中找到最长字符串的代码如下:

#include  #define MAXLINE 1000 int readline(char line[], int maxline); void copy(char to[], char from[]); main() { int len; int max; char line[MAXLINE]; char longest[MAXLINE]; max = 0; while ((len = readline(line, MAXLINE)) > 0) if (len > max) { max = len; copy(longest, line); } if (max > 0) printf("%s", longest); return 0; } int readline(char s[],int lim) { int c, i; for (i=0; i < lim-1 && (c=getchar())!=EOF && c!='\n'; ++i) s[i] = c; if (c == '\n') { s[i] = c; ++i; } s[i] = '\0'; //WHY DO WE DO THIS??? return i; } void copy(char to[], char from[]) { int i; i = 0; while ((to[i] = from[i]) != '\0') ++i; } 

我的问题是为什么我们将字符数组的最后一个元素设置为’\ 0’? 没有它,该程序工作正常…请帮助我…

您需要使用'\0'结束C字符串,因为这是库知道字符串结束位置的方式(在您的情况下,这是copy()函数所期望的)。

没有它,该程序工作正常……

没有它,你的程序有不确定的行为 。 如果程序碰巧做了你期望它做的事情,你就是幸运的(或者说,不幸的是,因为在现实世界中未定义的行为将选择在最不方便的情况下表现出来)。

在c“string”中表示以null结尾的字符数组。 将其与pascal字符串进行比较,这意味着最多255个字符,前面是一个表示字符串长度的字节(但不需要终止)。

每个appraoch都有它的优点和缺点。

特别是字符串指针指向没有长度已知的字符数组是NULL终止符将确定字符串长度的唯一方法。

关于链接上的 NULL终止的讨论很棒

因为C将字符串定义为由第一个空字符终止并包括第一个空字符的连续字符序列

基本上,C的作者可以选择将字符串定义为字符序列+字符串的长度,或者使用魔术标记来分隔字符串的结尾。

有关该主题的更多信息,我建议您阅读本文:

Poul-Henning Kamp 撰写的 “最昂贵的单字节错误” http://queue.acm.org/detail.cfm?id=2010365

你实际上已经在这里自己写了答案:

 void copy(char to[], char from[]) { int i; i = 0; while ((to[i] = from[i]) != '\0') ++i; } 

此函数中的循环将继续,直到它遇到数组中的’\ 0’。 如果没有终止零,则循环将继续执行未知数量的步骤,直到遇到零或无效的存储区域。

实际上,您不需要通过\ 0结束字符数组。 它是char *,或者需要由它结束的字符串的C表示。

对于数组,如果要将其传递给字符串(由char *表示,则必须在结束添加\ 0)。

另一方面,如果要将其作为char *处理,并且计划在其上使用char *函数,则需要在数组的末尾使用\ 0。

数组中的'\0'表示字符串的结尾,这意味着该字符后面的任何字符都不被视为字符串的一部分。这并不意味着它们不是字符数组的一部分。 也就是说,我们仍然可以通过索引来访问这些字符,但是当我们调用字符串相关的东西到这个字符数组时它们就不是它们的一部分。

要使字符串格式正确并且能够与字符串函数一起正常工作,它必须是以null结尾的字符数组。 如果没有NULL,当我们在字符数组上调用字符串函数时,程序会显示未定义的行为。 尽管我们大多数时候都可能对结果感到幸运,但它仍然是一种未定义的行为。

它是字符串终止符号,当遇到这种情况时,编译器会知道你的字符串已经结束。