Can sizeof nested twice ever be a dependent expression?

后端 未结 1 2048
时光取名叫无心
时光取名叫无心 2021-02-13 01:14

I noticed that gcc 5.0 rejects the following code, while clang 3.6 accepts it.

template
struct I
{
    typedef int Type;
};

template

        
相关标签:
1条回答
  • 2021-02-13 01:40

    I'm using a post-N4296 draft.

    typedef I<sizeof(sizeof(T))>::Type Type;
    

    typename is required if the nested-name-specifier I<..> depends on a template parameter [temp.res]/5. So, is I<..> dependent?

    [temp.dep.type]/9 A type is dependent if it is

    • [...]
    • (9.7) a simple-template-id in which either the template name is a template parameter or any of the template arguments is a dependent type or an expression that is type-dependent or value-dependent, or [...]

    I<..> is a simple-template-id, the template argument is an expression. Is this expression sizeof(sizeof(T)) type-dependent or value-dependent?

    The expression sizeof(sizeof(T)) can be broken down into the following expressions:

    expression           form
    ===============================================
                  T      type-id
           sizeof(T)     sizeof ( type-id )
          (sizeof(T))    ( expression )
    sizeof(sizeof(T))    sizeof unary-expression
    

    T is not an expression, but I'll leave it in the list for later. A note on the parentheses: A primary-expression can be a parenthesized (general) expression. A unary-expression can be a postfix-expression which can be a primary-expression, hence it can be parenthesized, too.

    A parenthesized expression (X) is dependent if X is dependent:

    [temp.dep.expr]/1 Except as described below, an expression is type-dependent if any subexpression is type-dependent.

    [temp.dep.constexpr]/1 Except as described below, a constant expression is value-dependent if any subexpression is value-dependent.

    In general, sizeof expressions are never type-dependent, because they always produce a value of type std::size_t:

    [temp.dep.expr]/4 Expressions of the following forms are never type-dependent (because the type of the expression cannot be dependent):

    [...]
    sizeof unary-expression
    sizeof ( type-id )
    

    However, the value they yield can be dependent on a template parameter:

    [temp.dep.constexpr]/2 Expressions of the following form are value-dependent if the unary-expression or expression is type-dependent or the type-id is dependent:

    sizeof unary-expression
    sizeof ( type-id )
    
    expression           form                       value-dep?   type-dep?
    =======================================================================
                  T      type-id                    no           yes
           sizeof(T)     sizeof ( type-id )         yes          no
          (sizeof(T))    ( expression )             yes          no
    sizeof(sizeof(T))    sizeof unary-expression    no           no
    

    Since T is type-dependent, sizeof(T) becomes value-dependent. However, since (sizeof(T)) is not type-dependent, sizeof(sizeof(T)) is not dependent at all.

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