如何将带小数的变量分配给它的行为与实际小数的行为方式不同?

时间:2013-06-20 08:47:53

标签: c kernighan-and-ritchie

棘手的一行是char longest[]数组初始化。如果我把它设置为(char longest[lim]),那么在EOF之后返回给我的字符串长于lim,所以我认为它不会以这种方式工作。但是,如果我明确地将10放在那里(char longest[10]) - 它按预期工作,并且只返回line的10个第一个字符。

在这种情况下,int lim = 10; char longest[lim]char longest[10]之间的区别是什么

#include <stdio.h>
#define MAXLINE 1000 //maximum input line size
//#define LIM 10

int getline(char line[], int maxline);
void copy(char to[], char from[]);

//print longest input line
main()
{
    int lim=10;


    int len; //current line length
    int max; //maximum length seen so far
    char line[MAXLINE]; //current input line
    char longest[lim]; //longest line saved here

    max = 0;
    while ((len = getline(line, MAXLINE)) > 0)
    {
        if (len > max)
        {
            max = len;
            copy(longest, line);
        }
    }
    if (max > 0) //there was a line
    {
        printf("Length: %d\n", max);
        printf("First %d characters of line: %s", lim, longest);
    }
    return 0;
}

//getline: read a line into s, return length
int getline(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';
return i;
}

//copy: copy 'from' into 'to'; assume to is bigh enough
void copy(char to[], char from[])
{
int i;

i = 0;
    while ((to[i] = from[i]) != '\0')
    {
        ++i;
    }
}

2 个答案:

答案 0 :(得分:1)

type name[10]是固定数组声明。

type name[exp]是可变长度数组。

每次遇到此声明(在块中)时都会执行分配来自C99可变长度数组。尺寸在形成后固定。

因此,案例的行为,例如在示例代码中访问数组边界之外是 undefined

答案 1 :(得分:0)

如果您为数组写了一个太长的值,则会出现“未定义的行为”。任何事情都可能发生。你的程序可能会崩溃,或者它可能会默默地做错误的事情,或者甚至可能看起来有效。更改程序中的任何其他内容都可以改变发生的情况。

这也是一个安全漏洞 - 如果攻击者可以控制写入的值,他们可能会让您的程序执行任何他们想要的操作。

简短版本:在将字符串写入数组之前,必须确保它适合。