Is there a reason on not allowing lambdas to deduce the return type if it contains more than one statement?

前端 未结 4 552
情话喂你
情话喂你 2020-12-20 20:43

Taken from the C++0x FDIS (n3290):

If a lambda-expression does not include a lambda-declarator, it is as if the lambda-declarator were (). If a lambda

相关标签:
4条回答
  • 2020-12-20 21:05

    Why doesn't the standard allow the compiler to analyse the compound-statement and determine the return type based on the first found return statement?

    In my opinion, reasons are inheritance, implicit typecast to void* and 0 typecasted to int, which makes it difficult for compiler implementers to deduce type from the first return statement. See the below examples:

    // "B" is a derived by "D"
    int main(){
      auto l = []{
        return (D*)(...);  // should it be "D*" (derived)
        // computation
        return (B*)(...);  // no it should be "B*" (base)
      }
    }
    

    Second,

    int main(){
      auto l = []{
        return (int*)(...);  // should it be "int*"
        // computation
        return (void*)(...);  // no it has to be "void*"
      }
    }
    

    Third one,

    int main(){
      auto l = []{
        return 0;  // should it be "int"
        // computation
        return (double)(...); // no it has to be "double"
      }
    }
    

    Also there is one more reason related to giving a compilation error message, when two unrelated return are found:

    int main(){
      auto l = []{
        return TYPE1;
        // computation
        return TYPE2;
      }
    }
    

    Now, question would arise that what useful compiler message should be printed to user ? The error message has to be only for one of the return statements. Which return to choose ?

    0 讨论(0)
  • 2020-12-20 21:08

    There's no technical reason for this. IIRC it was already implemented by the GCC C++ maintainer and he said it's trivial to implement.

    The committee is very conservative about accepting features into the Standard so they went with this simple form of deduction and will later hopefully accept a more powerful form. See the reason for rejection on US 30 comment.

    DR 975 is already marked "ready" so chances are good it will be accepted.

    0 讨论(0)
  • 2020-12-20 21:11

    I guess it's because of this kind of code :

    void foo( bool k )
    {
        auto call= [](){ if( k ) return 42; else return 'c'; };  // what is the return type?
        call();
    }
    

    Here the return type could be int or char. As each one of those types is implicitely convertible to the other, that's too ambiguous for the compiler to guess what is the return type. So to avoid confusion or to avoid the compiler implementation to decide witch type it should be, the comitee simply tell that this should produce an error( a diagnostic) allowing the programmer to specify wich type was required.

    So it's just to make sure compilers will not compile code that is too ambiguous to allow return type guessing.

    0 讨论(0)
  • 2020-12-20 21:25

    I believe this is not a restriction but an allowance to leave out -> decltype(expression) when the body is just return expression. It is pretty obvious what the return type is in that case.

    Your suggestion requires a lot more work for the compilers and a lot more rules for us, the programmers. Does it buy us much?

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