理解argList构造函数时出现问题

Problems understanding argList constructor

本文关键字:问题 argList 构造函数 理解      更新时间:2023-10-16

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

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]调用重载运算符方法[]。我真的不明白这里到底发生了什么,也许我在遗漏什么?

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

让我们看一个例子:

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

如果所有命令行参数以破折号开头,则该条件将检查这些参数。因此,对于-bar、-foo、-3是正确的,但对于baz和32则不然。