2

我在一种方法中有这样的东西

    autoPtr<LESModel> LESModel::New   
 95 (
 96  const volVectorField& U,
 97  const surfaceScalarField& phi,
 98  transportModel& transport,
 99  const word& turbulenceModelName
100 )
101 {
     ...
122  dictionaryConstructorTable::iterator cstrIter =                       
123  dictionaryConstructorTablePtr_->find(modelType);
     ...
143  return autoPtr<LESModel>      
144  (
145  cstrIter()(U, phi, transport, turbulenceModelName)
146  ); 
147  }

如果我是对cstrIter的,是一个类的变量dictionaryConstructorTable::iterator(虽然找不到这个类)并且从第 143 行开始,autoPtr<LesModel>调用构造函数并返回结果。因此,构造函数后面的括号autoPtr<LESModel>应该是参数,并且由于 cstrIter 是一个变量,我想知道变量后面的两个括号是什么意思。也许我误读了什么?

4

3 回答 3

8

C++ 支持“运算符重载”,这意味着您可以定义支持诸如a + b. 这通过使用名称定义函数来实现,例如operator+. 当可重载运算符与用户定义的类型一起使用时,C++ 会查找具有这些特殊名称的函数,如果找到合适的函数,则将运算符视为对该函数的函数调用。

可以重载的运算符之一是函数调用运算符。operator()当您使用对象名称时,将调用一个名为的成员函数,就好像它是一个函数一样:

struct S {
  void operator() (void) {
    std::cout << "Hello, World!\n";
  }
};

int main() {
  S s;
  s(); // prints "Hello, World!\n"
}

它看起来像dictionaryConstructorTable::iterator重载函数调用运算符并返回一些也重载函数调用运算符(或仅使用内置运算符)的类型。

用普通的成员函数替换函数调用运算符的使用可能会使发生的事情更清楚:

return autoPtr<LESModel>( cstrIter.foo().bar(U, phi, transport, turbulenceModelName)); 
于 2013-11-12T20:19:57.257 回答
2

这看起来像 OpenFOAM,它有自己的哈希表实现。

如果您查看 src/OpenFoam/containers/HashTable/HashTable/HashTable.H 的第 454 行(至少在我的副本中),您会发现iterator重载operator()operator*返回对迭代器当前引用值的引用。

为了澄清一点,C++ 允许您重载许多用于提供特定于域的功能的运算符。例如,这允许vector.add(otherVector)使用“明显的”语法糖vector + otherVector代替。不利的一面是,显而易见的东西并不总是那么明显,正如这个问题所表明的那样。

于 2013-11-12T20:38:16.927 回答
1

这种建设

cstrIter()(U, phi, transport, turbulenceModelName)

意味着首先使用默认构造函数创建一个 cstrIter 类型的临时对象

cstrIter()

之后,函数调用运算符用于此对象

cstrIter()(U, phi, transport, turbulenceModelName)

更清楚的是,您可以通过以下方式重写表达式

cstrIter obj;
obj(U, phi, transport, turbulenceModelName);
于 2013-11-12T20:32:53.600 回答