c++ - 读取功能的段错误

标签 c++ segmentation-fault stack-smash

我在使用 Stack Smash Protection 时遇到了一些严重的问题,现在我收到了一个新错误 - 段错误 -。我认为这与 linux 具有一些特殊保护这一事实密切相关。谁能解释一下为什么我会在这种特殊情况下出现段错误?

vector<const char*> Words;
void read(){
    FILE* a;
    char s[100];
    a = fopen("text.txt", "r");
    while (!feof(a))
    {
        fgets(s, 100, a);
        char *newAlloc = new char[strlen(s)];
        strcpy(newAlloc, s);
        Words.push_back(newAlloc);
    }
    fclose(a);
}

更新:我尝试了所有的解决方案并修改了代码,但问题仍然存在,所以我尝试将代码简化为:

#include<iostream>
#include<stdio.h>

int main()
{

 FILE* a;
 a=fopen("text.txt", "r");
 fclose(a);

 }

它仍然在 fopen 行给我错误。(这在我正在解决的练习中是强制性的)- 我正在使用 Ubuntu 15.10 和 QT Creator 以及 GCC 编译器。

更新:解决了。我想问题是因为我没有给出 fopen 的完整路径。我是 ubuntu 的新手。显然有一些不同。

 char * a = "/home/codrinz/text.txt";
 FILE * file = fopen(a, "r");

最佳答案

我看到了几个问题。

  1. 不要使用 while (!foeof(a))。参见 Why is “while ( !feof (file) )” always wrong? .

  2. 您没有为单词分配足够的内存。结果,您最终使用了不应该使用的内存。这会导致未定义的行为。

使用:

while (fgets(s, 100, a))
{
   char *newAlloc = new char[strlen(s) + 1];  // Add +1 for the terminating null character.
   strcpy(newAlloc, s);
   Words.push_back(newAlloc);
}

关于c++ - 读取功能的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36436092/

相关文章:

c++ - 如何在单击时动态创建多个控件

c++ - Xcode 推断命名空间?

c++ - 处理删除命令期间出现段错误

c - 相同值的不同 Int 值?

c - 缓冲区溢出 - 普通用户的 SegFaults

c - 当我访问超出我分配的内存时,为什么我没有收到堆栈粉碎错误?

c++ - std::get 以元组作为成员的自己的类

c++ - 当 `delete` 使用非虚析构函数处理基类时,Clang 和 GCC 会做什么?

c - 进行指针操作时出现段错误(核心已转储)

c - 如何在结构数组中初始化和动态分配一个 int 指针成员?