C++ самый неприятный анализ снова

Взято непосредственно с http://herbsutter.com/2013/05/09/gotw-1-solution/

В то время как widget w(); для меня понятно, я понятия не имею, как приведенный ниже код может быть объявлением функции?

// same problem (gadget and doodad are types)
//
widget w( gadget(), doodad() );  // pitfall: not a variable declaration

Как это возможно?

2 ответа

Решение

В объявлении функции аргументы типа массив распадаются на указатели на первый элемент, аргументы типа функция распадаются на указатель функции, поэтому сигнатура будет:

widget w( gadget(*)(), doodad(*)() );

То есть функция, которая принимает в качестве первого аргумента указатель на функцию, не имеющую аргументов и возвращающую gadget, который принимает в качестве второго аргумента указатель на функцию, не имеющую аргументов и возвращающую doodad и что сама функция возвращает widget

Есть еще более интересные или запутанные случаи, такие как:

// assume 'x' is a variable defined somewhere:
widget w(gadget(x));

Как это можно интерпретировать как объявление функции? Я имею в виду, x переменная, верно? Ну, при объявлении переменной вы можете добавить дополнительные скобки, так gadget x; а также gadget (x); оба объявляют одну и ту же переменную x, То же самое относится к аргументам функции, поэтому приведенный выше код выглядит как объявление функции, которая принимает первый аргумент с именем x типа gadget и возвращает widget...

Это функция, которая получает две функции, которая возвращает gadget а также doodad и ни один из них не получает аргументов.

Пример, который хорошо компилируется.

#include <iostream>
class widget{};
class gadget{};
class doodad{};
gadget a(){}
doodad b() {};
widget w( gadget(), doodad() ){
}
int main() {
    w(a,b);
    return 0;
}

http://ideone.com/YjZK9Y

Другие вопросы по тегам