<无法读取内存> c++

<Unable to read memory> c++

本文关键字:c++ gt 内存 lt 读取      更新时间:2023-10-16

我正在尝试在控制台应用程序中运行此代码 vs 2013,但是当我运行代码时,出现以下错误:

-argv[1]    0x00000000 <NULL>   char *
<unable to read memory>

这是主要函数代码:

int main(int argc, char **argv)
{
    set_new_handler(memory_err);
     if (strcmp(argv[1], "lit") == 0) {
    // For Rules
    TransPar par;
    get_args(par, argc, argv);   // get arguments
    gen_rules(par);              // generate rules (really, just transactions)
  }
  else if (strcmp(argv[1], "seq") == 0) {
    // For Sequences
    SeqPar par;
    get_args(par, argc, argv);   // get arguments
    gen_seq(par);                // generate sequences
  }
  else if (strcmp(argv[1], "tax") == 0) {
    // For Rules with Taxonomies
    TaxPar par;
    get_args(par, argc, argv);   // get arguments
    gen_taxrules(par);           // generate rules (really, just transactions)
  }
  else if (strcmp(argv[1], "-version") == 0) {
    print_version();
    return 0;
  }
  else {
    cerr << "Synthetic Data Generation, ";
    print_version();
    cerr << "Usage:  " << argv[0] << " lit|tax|seq [options]n";
    cerr << "        " << argv[0] 
      << " lit|tax|seq -help     For more detailed list of optionsn";
    return 1;
  }
  return 0;
}

另外,我应该提到源代码是为Unix构建的,但我修改了它以赢得胜利。

在使用 argv[1] 之前,您需要检查是否argc >= 2。如果用户未提供任何参数,则您正在访问不存在的参数。

根据 C 和 C++ 标准,argv[argc] 保证是一个空指针,这就是你在这里看到的;你正在传递一个空指针strcmp()这导致了崩溃。(旁注:访问argv[argc + 1]是未定义的行为,因此在访问索引 2+ 时需要特别小心。