什么时候 std::initializer_list 是微不足道的可构造的?
When is std::initializer_list trivially constructible?
在我看来,我认为当用于初始化std::initializer_list<T>
的类型Ts...
的对象可用于简单构造T
时,那么std::initializer_list<T>
可以从Ts...
中轻松构造,因为根据列表初始化,std::initializer_list<T>
的每个元素要么direct_initialized
要么copy_initialized
。
但是,我不确定我是否正确,所以我发布了这个。
这个问题本身没有意义。也就是说,您正在询问属性根本不适用的操作是否存在该属性。
6 个特殊成员函数(默认构造函数、复制/移动构造函数/赋值运算符和析构函数(可能很简单。但这些是唯一微不足道的事情,"琐碎"一词对此有明确的含义。
列表初始化不会执行任何这些操作。至少,不是直接的。
列表初始化initializer_list
的过程涉及创建一个临时数组,将大括号初始化列表中的值放入其中,并创建指向该数组的initializer_list
。这些都不是琐碎甚至有问题的操作,因此询问它们是否"琐碎"是没有意义的。
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- POCO::PostgreSQL:如何将std::vector支持添加到`Binder::bind`
- 使用一个考虑到std::map中键值的滚动或换行的键
- 为什么 std::atomic<std::string> 会给出微不足道的可复制错误?
- 什么时候 std::initializer_list 是微不足道的可构造的?
- STD ::可选的微不足道默认构造函数
- 如果 T1 和 T2 有,std::p air<T1,T2>不应该有微不足道的默认构造函数吗?