即使我尝试在C中创建文件,也找不到文件时出现分段错误

我正在编写将文本附加到文件的代码。它fopen在开头使用,WriteToFile因此即使文件不存在,它也会创建它。

但是,当我根本没有输入文件时会发生什么?根本没有争论?只是./a.out

分段故障。

我不知道为什么,在我看来,我所做的一切都很好,以避免出现任何问题。

int main(int argc, char **argv)
{
    
    char file_name[30] = "file.txt";
    
    printf("%s",file_name); /* for debugging : doesn't print it */
    
    if (0 != argc)
    {
        strcpy(file_name, argv[1]);
    }
    
    WriteToFile(file_name);
    
}

或者(以防我真的无法将字符串文字放入 char 数组中):

char file_name[30];
    
    if (0 == argc)
    {
       strcpy(file_name, "file.txt");
    }
    else
    {
        strcpy(file_name, argv[1]);
    }

对于我得到的两种情况

Segmentation fault (core dumped)

回答

if (0 != argc)

argc值通常是(a)包括程序名称在内的参数计数。因此,running./a.outargc值为 1 而不是 0。而且,由于argv[argc]通常是NULL,取消引用它不会很好地结束:-)

如果要确保另一个参数可用,可以使用:

if (argc > 1) {            // Have both argv[0] AND argv[1].
    nowSafeToUse(argv[1]);
}

更详细地说,C11 标准规定:

如果声明了它们,则主函数的参数应遵守以下约束:

  • 的值argc应为非负。
  • argv[argc] 应为空指针。
  • 如果 的值argc大于零,则argv[0]通过argv[argc-1]inclusive的数组成员应包含指向字符串的指针,这些字符串在程序启动之前由主机环境赋予实现定义的值。目的是从托管环境中的其他地方向程序启动之前确定的程序提供信息。如果宿主环境无法提供大写和小写字母的字符串,则实现应确保以小写形式接收字符串。
  • 如果 的值argc大于零,则指向的字符串argv[0]表示程序名称;argv[0][0]如果程序名在宿主环境中不可用,则应为空字符。如果 的值argc大于 1,则argv[1]通过指向的字符串argv[argc-1]表示程序参数。
  • 数组指向的参数argcargv字符串argv应可由程序修改,并在程序启动和程序终止之间保留其最后存储的值。

关于这条线的旁白:

printf("%s",file_name); /* for debugging : doesn't print it */

如果这不是打印,可能是因为标准输出是行缓冲的(如果确定为交互式设备,则为默认值,否则为完全缓冲)。

通过n在最后不输出 a ,字符可能仍位于某个缓冲区中,准备写入。崩溃可能会在不刷新缓冲区的情况下终止进程。因此,一个简单的解决方案可能只是使用以下之一:

printf("%s",file_name);
puts(file_name);

作为另一一边,你会惹上麻烦,如果你输入文件名大于29个字符,因为它会溢出file_name,允许在年底为好。

更好的方法可能只是使用您的默认字符串或argv[1]直接使用(无需复制),例如:

int main(int argc, char **argv) {
    char *file_name = (argv > 1)
        ? argv[1]
        : "file.txt";
    printf("%sn", file_name); // for debugging : probably does print it :-)
    
    WriteToFile(file_name);
}

(a)标准没有要求,因为它允许特定于实现的差异,但这是通常的情况。具体来说,这句话:

...在程序启动之前由主机环境给出实现定义的值。目的是从托管环境中的其他地方向程序启动之前确定的程序提供信息。

几乎意味着它可以为所欲为:-)

可以在此处找到相关答案(尽管是非重复问题)。


以上是即使我尝试在C中创建文件,也找不到文件时出现分段错误的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>