Why does GCC not warn for unreachable code?

2019-02-21 09:34发布

I wonder why gcc (4.6.3) gives me no warning for the unreachable code in this example:

#include <stdio.h>

int status(void)
{
    static int first_time = 1;

    if (first_time) {
        return 1;   
        first_time = 0; /* never reached */
    } else {
        return 0;   
    }     
}

int main(int argc, const char *argv[])
{
    printf("first call %d\n", status());
    printf("second call %d\n", status());
    return 0;
}

Note, the purpose of the faulty status() function was to maintain a status. I had expected to get a warning for this with -Wall. I tried also -Wunreachable-code, -Wextra, -pedantic and -ansi (as it was discussed here). Yet, none of those give me a warning.

It appears gcc silently removes the static variable assignment.

In my opinion gcc options -Wall -Werror should throw an error.

3条回答
Melony?
2楼-- · 2019-02-21 10:12

gcc 4.4 will give you warning. In the later versions of gcc this feature (Wunreachable-code) has been removed.

See here: http://gcc.gnu.org/ml/gcc-help/2011-05/msg00360.html

The -Wunreachable-code has been removed, because it was unstable: it relied on the optimizer, and so different versions of gcc would warn about different code. The compiler still accepts and ignores the command line option so that existing Makefiles are not broken. In some future release the option will be removed entirely.

Ian

查看更多
Ridiculous、
3楼-- · 2019-02-21 10:12

There is no mistake in your code.. You use return so the programme leave the function status and don't reached first_time = 0 but there is no mistake for gcc because the goal of a return is to not reached some part of code. An exemple:

int     main(int argc, char **argv)
{
   if (argc != 2)
       return (-1);
   //many code
   //many code
   //many code
   //many code
   //many code
   //many code
   //many code
   //many code
   //many code
}

So in this exemple the keyword return is use to stop the programme if a condition is bad ;)

查看更多
放我归山
4楼-- · 2019-02-21 10:20

gcc has dozens of passes -- to see them try compiling with switches like

-da -dAp -Wa,-a -fdump-ipa-all-all -fdump-tree-all-all -fdump-rtl-all-all

My guess is that some pass has done dead-code elimination before the pass designated to issue the warning in question. Which could reasonably be considered a bug, but likely the gcc team regard the warning more as a convenience than a moral commitment, and aren't motivated to do a lot of work to make it precise and complete. If you want to contribute, you could disable optimization passes one-by-one until you find the one preventing the warning, then file a bug report documenting the problem. If that isn't worth your time, maybe fixing it isn't worth their time. :-)

查看更多
登录 后发表回答