Подтвердить что ты не робот

Самый неприятный синтаксический анализ

Я получил код здесь.

class Timer {
 public:
  Timer();
};

class TimeKeeper {
 public:
  TimeKeeper(const Timer& t);

  int get_time()
  {
      return 1;
  }
};

int main() {
  TimeKeeper time_keeper(Timer());
  return time_keeper.get_time();
}

По внешнему виду он должен получить ошибку компиляции из-за строки:

TimeKeeper time_keeper(Timer());

Но это происходит только при наличии return time_keeper.get_time();.

Почему эта строка даже имеет значение, компилятор обнаружит двусмысленность в конструкции time_keeper(Timer() ).

4b9b3361

Ответ 1

Это связано с тем, что TimeKeeper time_keeper(Timer()); интерпретируется как объявление функции, а не как определение переменной. Это само по себе не является ошибкой, но когда вы пытаетесь получить доступ к члену get_time() time_keeper (который является функцией, а не экземпляром TimeKeeper), ваш компилятор терпит неудачу.

Вот как ваш компилятор просматривает код:

int main() {
  // time_keeper gets interpreted as a function declaration with a function argument.
  // This is definitely *not* what we expect, but from the compiler POV it okay.
  TimeKeeper time_keeper(Timer (*unnamed_fn_arg)());

  // Compiler complains: time_keeper is function, how on earth do you expect me to call
  // one of its members? It doesn't have member functions!
  return time_keeper.get_time();
}