- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在模板中,为什么必须在哪里以及为什么要将typename
和template
放在从属名称上?
无论如何,依赖名称到底是什么?
我有以下代码:
template <typename T, typename Tail> // Tail will be a UnionNode too.
struct UnionNode : public Tail {
// ...
template<typename U> struct inUnion {
// Q: where to add typename/template here?
typedef Tail::inUnion<U> dummy;
};
template< > struct inUnion<T> {
};
};
template <typename T> // For the last node Tn.
struct UnionNode<T, void> {
// ...
template<typename U> struct inUnion {
char fail[ -2 + (sizeof(U)%2) ]; // Cannot be instantiated for any U
};
template< > struct inUnion<T> {
};
};
typedef Tail::inUnion<U> dummy
行中。我相当确定
inUnion
是一个从属名称,而VC++恰好可以使它窒息。
template
来告诉编译器inUnion是一个模板ID。但是到底在哪里?然后是否应该假设inUnion是一个类模板,即
inUnion<U>
命名一个类型而不是一个函数?
最佳答案
(请参阅here also for my C++11 answer)
为了解析C++程序,编译器需要知道某些名称是否为类型。以下示例说明了这一点:
t * f;
t
的含义,以上内容可能会产生截然不同的解释。如果是类型,则它将是指针
f
的声明。但是,如果不是类型,它将是一个乘法。因此,C++标准在第(3/7)段中说:
Some names denote types or templates. In general, whenever a name is encountered it is necessary to determine whether that name denotes one of these entities before continuing to parse the program that contains it. The process that determines this is called name lookup.
t::x
引用模板类型参数,编译器将如何找出
t
引用的名称?
x
可以是一个静态的int数据成员,可以乘以,也可以是可以产生声明的嵌套类或typedef。
如果名称具有此属性-在知道实际的模板参数之前无法查找,则该名称称为从属名称(“取决于”模板参数)。
Let's wait until the user instantiates the template, and then later find out the real meaning of
t::x * f;
.
t::x
是从属名称,那么我们需要给它加上
typename
前缀,以告诉编译器以某种方式对其进行解析。标准在(14.6 / 2)中说:
A name used in a template declaration or definition and that is dependent on a template-parameter is assumed not to name a type unless the applicable name lookup finds a type name or the name is qualified by the keyword typename.
typename
,因为编译器可以使用模板定义中的适用名称查找来弄清楚如何解析结构本身-例如,当
T *f;
是类型模板参数时,使用
T
。但是要使
t::x * f;
成为声明,必须将其写为
typename t::x *f;
。如果省略关键字,并且名称被视为非类型,但是当实例化发现它表示类型时,编译器会发出通常的错误消息。有时,错误因此在定义时给出:
// t::x is taken as non-type, but as an expression the following misses an
// operator between the two names or a semicolon separating them.
t::x f;
typename
-因此,可以认为,已知非合格名称总是引用类型。
boost::function< int() > f;
boost::function
和
f
的任意定义:
namespace boost { int function = 0; }
int main() {
int f = 0;
boost::function< int() > f;
}
boost::function
与零(
int()
)进行比较,然后使用大于运算符将结果
bool
与
f
进行比较。但是,您可能知道,
boost::function
in real life是模板,因此编译器知道(14.2 / 3):
After name lookup (3.4) finds that a name is a template-name, if this name is followed by a <, the < is always taken as the beginning of a template-argument-list and never as a name followed by the less-than operator.
typename
相同的问题。如果在解析代码时我们还不知道名称是否是模板怎么办?根据
template
的指定,我们需要在模板名称之前插入
14.2/4
。看起来像:
t::template f<int>(); // call a function template
::
之后,而且可以出现在
->
或
.
之后。您也需要在其中插入关键字:
this->template f<int>(); // call a function template
T
)N
)(T)0
的转换)T[N]
是值相关的表达式或
N
是相关类型,则构造为
T
的类型是相关类型。有关详细信息,请参见
(14.6.2/1
)(用于依赖类型),
(14.6.2.2)
(用于类型依赖的表达式)和
(14.6.2.3)
(用于值依赖的表达式)。
T::x
,因此它也必须是从属名称(很幸运,从C++ 14开始,委员会已经开始研究如何解决这个令人困惑的定义)。
A name is a use of an identifier (2.11), operator-function-id (13.5), conversion-function-id (12.3.2), or template-id (14.2) that denotes an entity or label (6.6.4, 6.1)
operator +
和
operator type
形式。最后一种形式是
template-name <argument list>
。所有这些都是名称,按照标准中的常规用法,名称还可以包含限定符,该限定符表示应查找名称的 namespace 或类。
1 + N
不是名称,但
N
是名称。所有相关构造的子集即名称都称为相关名称。但是,函数名称在模板的不同实例中可能具有不同的含义,但是不幸的是,该通用规则没有捕获函数名称。
f((T)0)
中,
f
是从属名称。在标准中,这是在
(14.6.2/1)
处指定的。
typename
和
template
。您的代码应如下所示
template <typename T, typename Tail>
struct UnionNode : public Tail {
// ...
template<typename U> struct inUnion {
typedef typename Tail::template inUnion<U> dummy;
};
// ...
};
template
不一定总是出现在名称的最后部分。它可以出现在用作范围的类名的中间,如以下示例所示
typename t::template iterator<int>::value_type v;
typename
。假定给定的名称是类类型名称。对于基类列表和构造函数初始化器列表中的名称都是如此: template <typename T>
struct derive_from_Has_type : /* typename */ SomeBase<T>::type
{ };
template
之后使用::
,并且C++委员会said不能解决问题。 template <typename T>
struct derive_from_Has_type : SomeBase<T> {
using SomeBase<T>::template type; // error
using typename SomeBase<T>::type; // typename *is* allowed
};
关于c++ - 为什么必须在哪里放置 “template”和 “typename”关键字?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29744642/
语句 1: [2,4,6,7,8].each do |i| (i % 2 == 0) || (puts "Not even" && break) puts i end 声明 2: [2
我有一张正在显示的卡片,上面有一些信息。我想将其包装在SingleChildScrollView中,因为我还有更多项目要添加到卡中,但是当我这样做时,屏幕只是空白吗?我曾尝试将其作为根(脚手架主体)放
我有一个带有窗体的 View ,该窗体显示ViewModel中ObservableCollection中对象的数据。 ObservableCollection使我可以浏览数据。 ObservableC
如何将时间戳附加文件名放在HDFS中? hadoop fs -put topic_2018-12-15%2016:31:15.csv /user/file_structure/ 最佳答案 您只是在运行
我正在寻求一些帮助,以找出为什么以下叠加函数的运行时间会随着每次连续运行而增加。 据我所知,如果缓冲区中的文本保持不变,则运行时间应该是相同的——即,仅向左/向右移动光标应该不会增加运行时间(但它确实
我有一个事件指示器,它显示在中间。如何将其放置在 View 的左上角? var activityIndicator = UIActivityIndicatorView() func show() {
首先,我想提前感谢所有回答这个问题的人。非常感谢您的帮助。这是我第一次在这里发帖,所以如果我发帖不礼貌,请原谅我。 我的问题是关于方法原型(prototype)的: void copySubtree(
我正在开发一个应该是通用的应用程序,一个适用于 iPad 和 iPhone 的应用程序。我想让他们的界面尽可能相似。在 iPhone 应用程序中,我使用的是选项卡栏 Controller ,其中一个选
我目前正在使用 JS 开发 REST API,但遇到以下问题:该代码有效,但如果我尝试删除、放置或修补不存在的条目,它不会返回错误,但会打印成功消息。这是为什么?获取路由完美运行。 app.route
.a{ width:500px; height:500px; background:yellow; border: 3px dashed black; }
首先,请引用下图: 这基本上是我对布局的想法。 我想要的是: 内容 div 成为“主要焦点”,例如当浏览器 调整大小,它应该留在中间; 当浏览器被调整大小时,我希望这两个图像基本上 位于内容 div
我的应用程序需要使用内存映射并发访问数据文件。我的目标是使其在共享内存系统中可扩展。研究了内存映射文件库实现的源码,想不通: 在多个线程中从 MappedByteBuffer 中读取是否合法? get
我有一个 JDesktopPane 并希望以网格样式显示 JInternalFrames 而无需覆盖框架。框架的尺寸会有所不同,因此应动态分配它们的位置。我可以存储最后放置的框架的坐标,但可以移动、最
根据https://isocpp.org/wiki/faq/dtors#placement-new传递给placement-new的地址必须正确对齐。但它给出的例子似乎与此相矛盾。 char memo
我最近一直在查看 Illumos 源代码,发现了一些奇怪的东西。 在他们的源代码中,函数类型是这样写的: static int outdec64(unsigned char *out, unsigne
您好,我目前正在尝试在我的一张图片旁边放置一个图例,但我在放置时遇到了问题。 我想将图例放在图像的左侧或右侧。这是我当前的代码: .my-legend .legend-title { text-a
根据文档, print 之间的唯一区别和 say 似乎是后者添加了 "\n"(并使用 .gist 进行字符串化)。然而, perl6 -e 'print "del\b\b"' 打印“d”,有效地应用转
所以我试图将我的图像标志放在背景上,但我的背景突然被裁剪,出现了一半的黑屏。如图: 我的 main.dart 代码: import 'package:flutter/material.dart'; i
我正在使用 Azure DevOps 构建 python 轮。我想让它尽可能通用,以便团队中的每个人都可以使用相同的管道来构建自己的 python 轮并将它们部署在一些 databricks 工作区中
在构建标准(非 WordPress)网页时,我通常会在正文末尾之前加载所有 javascript 文件,然后包含页面特定 js 代码的部分。 WorPress 建议使用 wp_enqueue_scri
我是一名优秀的程序员,十分优秀!