Предупреждение компилятора (уровень 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();
}
В приведенном выше примере результат метода, который принимает нулевые аргументы, передается в качестве аргумента конструктору неименованной переменной локального класса. Вызов может быть несообщлен путем именования локальной переменной или префикса вызова метода с экземпляром объекта вместе с соответствующим оператором указателя на член.