What are the consequences of ignoring: warning: unused parameter

前端 未结 8 762
闹比i
闹比i 2020-12-29 23:48

I am working on a C++ project and I noticed that we have a number of warnings about unused parameters.

What effect could it have if these warnings are ignored?

相关标签:
8条回答
  • 2020-12-30 00:03

    It means you wrote a function that takes a parameter but doesn't use the parameter. It's harmless but it might indicate bugs in some cases.

    Generally you can silence this warning by removing the parameter name, leaving it anonymous, but that may not be desirable depending on why the parameter is not being used.

    I'd suggest you turn off the warning if it is making it harder to find the real problems.

    0 讨论(0)
  • 2020-12-30 00:04

    None. except [EDIT]: as others have pointed out, You could have an unassigned output parameter.

    You should clean them up, because on many occasions I have seen developers ignore important warnings that were 'hidden' in amongst a large number of warnings, and they were so used to seeing warnings they never paid any attention to them. I try to have zero warnings at all times, and set compiler warnings to the maximum level.

    0 讨论(0)
  • 2020-12-30 00:06

    That depends of if you intended to use the paramater. E.g.

    const int Size = 12; // intended for use in some other function
    
    char* MakeBuffer(int size)
    {
       return new char[Size];
    }
    

    In this code 'size' is unused, and instead the constant 'Size' is being used. So the warning will highlight problems of this type for you.

    However, if you never indented to use the parameter then it should just be removed from the method signature. Unless you need to match a signature for a virtual method, or function pointer, if that's the case then you don't have the option to remove it.

    0 讨论(0)
  • 2020-12-30 00:07

    If you have a whole lot of unimportant warnings that are not important to you, you may overlook the important warning about the line of code that you just wrote that is hiding in the middle of them.

    0 讨论(0)
  • 2020-12-30 00:15

    In C++ you can have default arguments:

    int sum(int first, int second=0){   // should not give warning
        return first+first;
    }
    

    You can also have extra argument:

    int sum(int first, int second){     // should give warning
        first *= 2;
        return first;
    }
    

    If you have a parameter you're not using and it's not defaulted, you should get a warning because you're asking the program to pass extra values to the stack that are never referenced, and therefore is doing more work than it should.

    Maybe it means you forgot part of the function logic, too.

    0 讨论(0)
  • 2020-12-30 00:17

    The function with an unused parameter may have a real bug in the following cases:

    1. There is an output parameter, which is not being assigned or written into, resulting in undefined value for the caller.

    2. One of parameters is a callback function pointer, which you must invoke and forget to do so. May happen if there is a lot of #ifdefs in the function.

    3. You declare a local variable with the same name that shadows a parameter and subsequently use the wrong value down in the function.

    Not using an input parameters may be harmless, but you can reduce the noise to see useful warnings by marking unused input parameters explicitly in the beginning of the function by casting it to void (works for both C and C++):

    (void)param1;
    

    Or,

    #define UNUSED(expr) do { (void)(expr); } while (0)
    ...
    
    void foo(int param1, int param2)
    {
        UNUSED(param2);
        bar(param1);
    }
    

    Or omit parameter name (C++ only):

    void foo(int param1, int /*param2*/)
    {
        bar(param1);
    }
    
    0 讨论(0)
提交回复
热议问题