C++对象析构函数的多种调用方式

Various ways of calling C++ object destructor

C++ 对象可以使用析构函数调用语法显式析构(对于非class 类型伪析构)。但看起来除了普遍接受的语法外,几乎所有现代编译器都支持自己调用析构函数的方式:

using T = int;
const int x = 1;
int main() { 
    x.~T();             //ok everywhere
    x.~int();           //#1: ok in MSVC only
    x.~auto();          //#2: ok in GCC only
    x.~decltype(x)();   //#3: ok in Clang and MSVC only
}

除了适用于所有编译器的x.~T(),至少还有3个其他选项,demo:https://gcc.godbolt.org/z/895bd9T5c

根据标准,选项 #1、#2 或 #3 中的任何一个是否合法,或者它们都只是相应编译器的 extensions/bugs?

语法不允许 (1) 和 (2),所以它们是非法的。
(参见 [expr.prim.id.dtor] -> id-expression -> unqualified-id -> type-name。)

虽然语法确实允许 (3) (... -> unqualified-id -> decltype-specifier),但我在 [expr.prim.id.dtor] 中没有看到任何不允许在此使用 decltype 的内容情景.

我尝试了几种不同的方法(使 T 成为 class 类型,使 x 从属,等等),但在所有情况下,GCC 都拒绝了 ~decltype(...)。我假设这是一个 GCC 错误。