Предупреждение компилятора (уровень 1) C4930

"прототип": прототипная функция не вызывается (это определение переменной предназначено?)

Компилятор обнаружил неиспользуемый прототип функции. Если прототип был предназначен в качестве объявления переменной, удалите открытые или закрытые скобки.

Следующий пример приводит к возникновению ошибки C4930:

// C4930.cpp
// compile with: /W1
class Lock {
public:
   int i;
};

void f() {
   Lock theLock();   // C4930
   // try the following line instead
   // Lock theLock;
}

int main() {
}

C4930 также может возникать, если компилятор не может различать объявление прототипа функции и вызов функции.

Следующий пример приводит к возникновению ошибки C4930:

// C4930b.cpp
// compile with: /EHsc /W1

class BooleanException
{
   bool _result;

public:
   BooleanException(bool result)
      : _result(result)
   {
   }

   bool GetResult() const
   {
      return _result;
   }
};

template<class T = BooleanException>
class IfFailedThrow
{
public:
   IfFailedThrow(bool result)
   {
      if (!result)
      {
         throw T(result);
      }
   }
};

class MyClass
{
public:
   bool MyFunc()
   {
      try
      {
         IfFailedThrow<>(MyMethod()); // C4930

         // try one of the following lines instead
         // IfFailedThrow<> ift(MyMethod());
         // IfFailedThrow<>(this->MyMethod());
         // IfFailedThrow<>((*this).MyMethod());

         return true;
      }
      catch (BooleanException e)
      {
         return e.GetResult();
      }
   }

private:
   bool MyMethod()
   {
      return true;
   }
};

int main()
{
   MyClass myClass;
   myClass.MyFunc();
}

В приведенном выше примере результат метода, который принимает нулевые аргументы, передается в качестве аргумента конструктору неименованной переменной локального класса. Вызов может быть несообщлен путем именования локальной переменной или префикса вызова метода с экземпляром объекта вместе с соответствующим оператором указателя на член.