C++ What is the earliest undefined behavior can manifest itself?

前端 未结 5 1349
臣服心动
臣服心动 2021-01-17 19:48

I\'m aware that undefined behavior can potentially cause anything, which makes any program containing UB potentially meaningless. I was wondering if there is any way to iden

相关标签:
5条回答
  • 2021-01-17 20:06

    I think it depends on the type of undefined behavior. Things that would affect something like structure offsets could cause undefined behavior, which would show up any time code that touches that structure is executed.

    In general, however, most undefined behavior happens at run time, meaning only if that code is executed will the undefined behavior occur.

    For example, an attempt to modify a string literal has undefined behavior:

    char* str = "StackOverflow";
    memcpy(str+5, "Exchange", 8);    // undefined behavior
    

    This "undefined behavior" will not take place until the memcpy executes. It will still compile into perfectly sane code.

    Another example is omitting the return from a function with a non-void return type:

    int foo() {
        // no return statement -> undefined behavior.
    }
    

    Here, it is at the point at which foo returns that the undefined behavior occurs. (In this case, on x86, whatever happened to be in the eax register is the resultant return value of the function.)

    Many of these scenarios can be identified by enabling the a higher level of compiler error reporting (eg. -Wall on GCC.)

    0 讨论(0)
  • 2021-01-17 20:07

    while it is "undefined behaviour", given a particular compiler, it will have a predictable behavior of some sort. But because it is undefined, on different compilers, it may result in that behavior occurring at any point of the complilation / runtime

    0 讨论(0)
  • 2021-01-17 20:07

    which makes any program containing UB potentially meaningless

    Not quite right. A program can't "contain" UB; when we say "UB" that is short for: the program's behaviour is undefined. All of it!

    So the program is not just potentially, but actually, meaningless, from the start.

    [intro.execution]/5: A conforming implementation executing a well-formed program shall produce the same observable behavior as one of the possible executions of the corresponding instance of the abstract machine with the same program and the same input. However, if any such execution contains an undefined operation, this International Standard places no requirement on the implementation executing that program with that input (not even with regard to operations preceding the first undefined operation).

    0 讨论(0)
  • 2021-01-17 20:08

    "Undefined behavior" means that the language definition doesn't tell you what your program will do. That's a very simple statement: no information. You can speculate all you like about what your implementation may or may not do, but unless your implementation documents what it does, you're only guessing. Programming isn't about guessing; it's about knowing. If the behavior of your program is undefined, fix it.

    0 讨论(0)
  • 2021-01-17 20:10

    As your code somewhat demonstrates, undefined behavior is almost always a condition of runtime state at the time the behavior is attempted. A slight modification of your code can make this painfully obvious:

    void causeUndefinedBehavior()
    {
       //any code that causes undefined behavior
       //every time it is run
       char* a = nullptr;
       *a;
    }
    
    
    int main()
    {
     srand(time(NULL));
     //code before call
     //...
     if (rand() % 973 == 0)
        causeUndefinedBehavior();
     //code after call
     //...
    }
    

    You could execute this a thousand times or more and never trip the UB execute-condition. that doesn't change the fact the function itself is clearly UB, but detecting it at compile time in context of the invoker is not trivial.

    0 讨论(0)
提交回复
热议问题