- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我一直试图理解 std::nullopt_t
的基本原理不允许是DefaultConstructible
在 C++17(它被引入的地方)及更高版本中,并在此过程中克服了一些编译器差异混淆。
考虑以下违反规范的(它是 DefaultConstructible
)实现 nullopt_t
:
struct nullopt_t {
explicit constexpr nullopt_t() = default;
};
这是 C++11 和 C++14(无用户提供的 ctor)中的聚合,但不是 C++17(
explicit
ctor)和 C++20(用户声明的 ctor)中的聚合.
struct S {
constexpr S() {}
S(S const&) {}
S& operator=(S const&) { return *this; } // #1
S& operator=(nullopt_t) { return *this; } // #2
};
int main() {
S s{};
s = {}; // GCC error: ambiguous overload for 'operator=' (#1 and #2)
}
这在 C++11 到 C++20 中被 GCC(各种版本,比如 v11.0)拒绝,但在 C++11 到 C++ 中被 Clang(比如 v12.0)和 MSVC(v19.28)接受C++20。
nullopt_t
(如上)是一个聚合,而它 nullopt_t
的复制列表初始化#2
处的复制赋值运算符所需的对象可行,最佳答案
为什么是 nullopt_t
必须是 DefaultConstructible
首先?nullopt_t
的规范要求不得为 DefaultConstructible
回想起来,可以说是一个基于标签类型的一些 LWG 和 CWG 混淆的错误,并且这种混淆的解决仅在 std::optional
之后才出现。是 brought in from the Library Fundamentals TS Components .
首先,nullopt_t
的当前 (C++17, C++20) 规范, [optional.nullopt]/2 , 需要 [ 重点矿]:
Type
nullopt_t
shall not have a default constructor or an initializer-list constructor, and shall not be an aggregate.
[...] In particular,
optional<T>
has a constructor withnullopt_t
as a single argument; this indicates that an optional object not containing a value shall be constructed.
variant
、
any
和
optional
的同构界面),其中一篇论文是介绍
std::optional
的一部分, 有一个关于
nullopt_t
的讨论, 一般的标签类型和
DefaultConstructible
需求 [
重点矿]:
No default constructible
While adapting
optional<T>
to the newin_place_t
type we foundthat we cannot anymore usein_place_t{}
. The authors don't considerthis a big limitation as the user can usein_place
instead. It needsto be noted that this is in line with the behavior ofnullopt_t
asnullopt_t{}
fails as no default constructible. Howevernullptr_t{}
seems to be well formed.Not assignable from
{}
After a deeper analysis we found also that the old
in_place_t
supportedin_place_t t = {};
. The authors don't consider this a big limitation as we don't expect that a lot of users could use this and the user can usein_place
instead.in_place_t t;
t = in_place;It needs to be noted that this is in line with the behavior of
nullopt_t
as the following compile fails.nullopt_t t = {}; // compile fails
However
nullptr_t
seems to be support it.nullptr_t t = {}; // compile pass
To re-enforce this design, there is an pending issue 2510-Tag types should not be
DefaultConstructible
Core issue 2510.
DefaultConstructible
[
重点矿]:
(LWG) 2510. Tag types should not be
DefaultConstructible
[...]
Previous resolution [SUPERSEDED]:
[...] Add a new paragraph after 20.2 [utility]/2 (following the header synopsis):
- -?- Type
piecewise_construct_t
shall not have a default constructor. It shall be a literal type. Constantpiecewise_construct
shall be initialized with an argument of literal type.
DefaultConstructible
的方式解决。 ,如
explicit
就足够了[
重点矿]:
(CWG) 1518. Explicit default constructors and copy-list-initialization
[...]
Additional note, October, 2015:
It has been suggested that the resolution of issue 1630 went too far in allowing use of explicit constructors for default initialization, and that default initialization should be considered to model copy initialization instead. The resolution of this issue would provide an opportunity to adjust that.
Proposed resolution (October, 2015):
Change 12.2.2.4 [over.match.ctor] paragraph 1 as follows:
[...] For direct-initialization
or default-initialization, the candidate functions are all the constructors of the class of the object being initialized. [...]
explicit
还暗示该类型不是聚合,这反过来是 LWG Core Issue 2510 的最终解决方案(基于 CWG Core Issue 1518 的最终解决方案)
(LWG) 2510. Tag types should not be
DefaultConstructible
[...]
Proposed resolution:
[...] In 20.2 [utility]/2, change the header synopsis:
// 20.3.5, pair piecewise construction
struct piecewise_construct_t { explicit piecewise_construct_t() = default; };
constexpr piecewise_construct_t piecewise_construct{};[...]
std::optional
的提案中。 ,可以说是疏忽,我想声明
nullopt_t
不必是
DefaultConstructible
, 只是,与其他标签类型一样,它应该有一个用户声明的
explicit
构造函数,它禁止它作为空括号复制列表初始化的候选对象,因为它不是一个聚合,并且唯一的候选构造函数是
explicit
.
S& operator=(nullopt_t)
赋值运算符不适用于赋值
s = {};
, 作为空括号
{}
将需要聚合初始化或复制列表初始化来创建
nullopt_t
(临时)对象。
nullopt_t
,但是(通过惯用的标签实现:我上面的实现),根据
P0398R0 (解决了 CWG 核心问题 1518),既不是聚合,也不是其默认构造函数参与复制列表初始化(来自空括号)。
SUSPENDED
2015 年 6 月 15 日,在 CWG 核心问题 1630 的决议更改之前(“问题 1630 的决议走得太远了”)。现在根据来自此问答的 ping 重新打开票证。
关于c++ - 来自空括号的不明确复制分配的编译器差异,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67469039/
我有一个应用程序,它会抛出 GKSession 并在各种条件下(连接超时、 session 失败等)创建一个新的 GKSession。不过,我遇到了内存泄漏问题,并且有时会在重新连接几次循环后崩溃。
比如我在宿主代码中有一个浮点指针 float *p 是否可以确定他指向的内存类型(设备/主机)? 最佳答案 在 UVA system 中, 运行时 API 函数 cudaPointerGetAttri
我已将项目转换为 .Net 4.0 并且以下代码不起作用: typeof(RuntimeTypeHandle).GetMethod("Allocate", BindingFlags.Instance
当我声明 char ch = 'ab' 时,ch 只包含 'b',为什么它不存储 'a'? #include int main() { char ch = 'ab'; printf("%c"
我对 Disk Sector 和 Block 有疑问。扇区是一个单位,通常为 512 字节或 1k、2k、4k 等取决于硬件。文件系统 block 大小是一组扇区大小。 假设我正在存储一个 5KB 的
假设我有 8 个人和5000 个苹果。 我想将所有苹果分发给所有 8 个人,这样我就没有苹果了。 但每个人都应该得到不同数量 将它们全部分发出去的最佳方式是什么? 我是这样开始的: let peopl
我正在构建的网站顶部有一个搜索栏。与 Trello 或 Gmail 类似,我希望当用户按下“/”键时,他们的焦点就会转到该搜索框。 我的 JavaScript 看起来像这样: document.onk
我有一小段代码: if (PZ_APP.dom.isAnyDomElement($textInputs)){ $textInputs.on("focus", function(){
我观察到以下行为。 接受了两个属性变量。 @property (nonatomic, retain) NSString *stringOne; @property (nonatomic, assign
我正在解决这样的问题 - 实现一个计算由以下内容组成的表达式的函数以下操作数:“(”、“)”、“+”、“-”、“*”、“/”。中的每个数字表达式可能很大(与由字符串表示的一样大)1000 位)。 “/
我有一组主机和一组任务。 每个主机都有 cpu、mem 和任务容量,每个任务都有 cpu、mem 要求。 每个主机都属于一个延迟类别,并且可以与具有特定延迟值的其他主机通信。 每个任务可能需要以等于或
该程序的作用:从文件中读取一个包含 nrRows 行和 nrColomns 列的矩阵(二维数组)。矩阵的所有元素都是 [0,100) 之间的整数。程序必须重新排列矩阵内的所有元素,使每个元素等于其所在
世界!我有个问题。今天我尝试创建一个代码,它可以找到加泰罗尼亚语号码。但是在我的程序中可以是长数字。我找到了分子和分母。但我不能分割长数字!此外,只有标准库必须在此程序中使用。请帮帮我。这是我的代码
我确定我遗漏了一些明显的东西,但我想在 Objective C 中创建一个 NSInteger 指针的实例。 -(NSInteger*) getIntegerPointer{ NSInteger
这个问题在这里已经有了答案: Difference between self.ivar and ivar? (4 个答案) 关闭 9 年前。
我如何将 v[i] 分配给一系列整数(v 的类型是 vector )而无需最初填充 最佳答案 你的意思是将 std::vector 初始化为一系列整数? int i[] = {1, 2, 3, 4,
我想寻求分配方面的帮助....我把这个作业带到了学校......我必须编写程序来加载一个 G 矩阵和第二个 G 矩阵,并搜索第二个 G 矩阵以获取存在数第一个 G 矩阵的......但是,当我尝试运行
我必须管理资源。它基本上是一个唯一的编号,用于标识交换机中的第 2 层连接。可以有 16k 个这样的连接,因此每次用户希望配置连接时,他/她都需要分配一个唯一索引。同样,当用户希望删除连接时,资源(号
是否有任何通用的命名约定来区分已分配和未分配的字符串?我正在寻找的是希望类似于 us/s 来自 Making Wrong Code Look Wrong ,但我宁愿使用常见的东西也不愿自己动手。 最佳
我需要读取一个 .txt 文件并将文件中的每个单词分配到一个结构中,该结构从结构 vector 指向。我将在下面更好地解释。 感谢您的帮助。 我的程序只分配文件的第一个字... 我知道问题出在函数 i
我是一名优秀的程序员,十分优秀!