【问题标题】:Problems understanding argList constructor理解 argList 构造函数的问题
【发布时间】:2013-11-25 20:41:59
【问题描述】:

目前我正在分析下面的构造函数:

Foam::argList::argList
372 (
373  int& argc,       // argc of main 
374  char**& argv,    // argv of main
375  bool checkArgs,
376  bool checkOpts
377 )
378 :   //Initializing
379  args_(argc), //stringList args_ with size argc                        
380  options_(argc)  //HashTable<string> options_ with size argc
381 {
382  // Check if this run is a parallel run by searching for any parallel option
383  // If found call runPar which might filter argv
384  for (int argI = 0; argI < argc; ++argI)
385  {
386  if (argv[argI][0] == '-') //argv is array of pointers    //HERE 
387  {                         //inline const Foam::string& Foam::argList::operator[]
                               //(const label index) const
                               //{
                               //return args_[index];
                               //}

388  const char *optionName = &argv[argI][1];   //Adressenzuordnung
389 
390  if (validParOptions.found(optionName))
391  {
392  parRunControl_.runPar(argc, argv);
393  break;
394  }
395  }
396  }

我对第 386 行有疑问:

argv 应该是一个指针数组,作为 main(...) 的参数。使用 argv[argI] 我访问 argv 的元素 argI 并使用 [0] 调用重载的运算符方法 []。我真的不明白这里到底发生了什么,也许我误解了什么?

【问题讨论】:

  • 它不是一个指针数组。它显然是指向声明中的指针的指针。只是你可以索引一个指针(实际上,你不能索引一个数组本身)。
  • @chris:如果我看一下 char *argv[] 的一般定义,对我来说似乎是一个指针数组。此外,在许多教程中,它也被描述为一个 pinters 数组。
  • 您的函数采用char **&amp;,而不是char *[],但这并不重要,因为看起来像数组的参数实际上是指针。

标签: c++ arrays pointers constructor argv


【解决方案1】:

正如您所提到的,argv 是一个字符 **。 argv[x][y] 表示第 x 个指针的第 y 个元素。更具体地说,该行的重点是检查命令行参数是否以破折号开头。它与运算符重载无关,它是对指针数组的简单访问。

我们来看一个例子:

./a.out -bar -foo baz 32 -3

条件检查所有命令行参数是否以破折号开头。因此,对于 -bar、-foo、-3 是正确的,但对于 baz 和 32 是错误的。

【讨论】:

  • 所以 if 条件是检查我们是否已经到达命令行参数中程序后面的第一个参数?
猜你喜欢
  • 1970-01-01
  • 2011-10-29
  • 1970-01-01
  • 1970-01-01
  • 2011-04-22
  • 1970-01-01
  • 2011-08-23
  • 2021-04-05
  • 1970-01-01
相关资源
最近更新 更多