- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想要 std::shared_ptr<std::tuple<MyClass, std::mutex>>
.
std::mutex
既不可复制也不可移动。如何初始化?
最佳答案
两个参数的简单解决方案是 std::pair
和 std::piecewise_construct
。
std::tuple
缺少它。我认为这是一个缺陷。
如果我们想要 tuple
(比如超过 2 个参数),我们可以使用一些可怕的代码来实现,因为“可以做到”的值有限。
template<class T>
struct placement_shared_helper {
std::aligned_storage_t<sizeof(T),alignof(T)> data;
T* get() { return reinterpret_cast<T*>(&data); }
template<class F>
void construct( F&& f ) {
std::forward<F>(f)((void*)&data);
}
// dangerous if construct throws:
~placement_shared_helper(){ get()->~T(); }
};
template<class T, class F>
std::shared_ptr<T> make_placement_shared( F&& f ) {
auto r1 = std::make_shared<placement_shared_helper<T>>();
r1->construct( std::forward<F>(f) );
return {r1->get(), r1}; // aliasing constructor
}
这需要您传入一个函数对象,当传递一个具有足够大小和对齐方式的 void*
时,它将在指向的存储中构造您的类型。
您可以提高 placement_shared_helper
的异常安全性,但这是工作而且我很懒。考虑从构造和 std::terminate
中捕获任何异常。
对于下一部分,我们作弊。这违反了标准,因为我们采用未初始化的内存并将其解释为元组以获取元组存储其对象的偏移量。糟糕的程序员。
template<class Dest, std::size_t...Is, class...Args>
void placement_construct( std::index_sequence<Is...>, Dest* here, std::tuple<Args...> args ) {
new((void*)here) Dest( std::get<Is>(args)... );
}
template<class Dest, class...Args>
void placement_construct( Dest* here, std::tuple<Args...> args ) {
return placement_construct( std::index_sequence_for<Args...>{}, here, std::move(args) );
}
template<class Dest, std::size_t...Is, class...Tuples>
void placement_construct_tuple( std::index_sequence<Is...>, void* here, Tuples... tuples ) {
using discard=int[];
(void)discard{0,(void(
placement_construct( &std::get<Is>(*(Dest*)here), std::move(tuples) )
),0)...};
}
template<class Dest, class...Tuples>
void placement_construct_tuple( void* here, Tuples... tuples ) {
placement_construct_tuple<Dest>( std::index_sequence_for<Tuples...>{}, here, std::move(tuples)... );
}
这假设一个元组只是在特定位置的一堆构造对象。我们获取我们的元组形内存块并依次构建它的每个元素。如果抛出异常,就会发生坏事;您可能想 try catch 终止。
make_placement_shared
采用一个函数,该函数采用 void*
并构造您的对象。
placement_construct_tuple
采用一组元组,并使用它们依次构造元组中的每个对象。
auto r = make_placement_shared<std::tuple<MyClass, std::mutex>>(
[&](void* here) {
placement_construct_tuple<std::tuple<MyClass, std::mutex>>(here,
std::forward_as_tuple( args_to_construct_MyClass_go_here ),
std::make_tuple() // no args for mutex
);
}
);
并排除拼写错误和未定义的行为,完成。
关于c++ - 如何将 std::mutex 与其他一些类放在 std::tuple 中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36428450/
我有一个包含文件名 和文件路径 的元组列表。我想找到重复的 filename(但 filepath 可能不同),即文件名相同但 filepath 可能不同的元组。 元组列表示例: file_info
我有一个像这样定义的变量 auto drum = std::make_tuple ( std::make_tuple ( 0.3f , Ex
我有一个包含几个字段的自定义结构,我想在快速 switch 语句中对其进行模式匹配,这样我就可以通过将其中一个字段与另一个字段进行比较来自定义匹配正则表达式。 例如鉴于这种结构: struct MyS
我有一种动态元组结构: template //Should only be tuples class DynamicTuple { vector data; //All data is st
这个问题在这里已经有了答案: What and When to use Tuple? [duplicate] (5 个答案) 关闭 8 年前。 我正在查看 Tuple 的在线示例,但我没有看到任何理
在我的项目中我有很多坐标要处理,在二维情况下我发现(cons x y)的构造比(list x y)快和 (vector x y)。 但是,我不知道如何将 cons 扩展到 3D 或更进一步,因为我没有
我有以下 Scala 代码: def f(x: Int, y: Int): Option[String] = x*y match { case 0 => None case n =>
我的直觉告诉我,在一般情况下,只有宏或复杂类型的体操才能解决这个问题。 Shapeless 或 Scalaz 可以在这里帮助我吗?这是 N=2 问题的具体实例,但我正在寻找的解决方案适用于所有合理的
为什么这段 Scala 代码是这样的: class Test { def foo: (Int, String) = { (123, "123") } def bar: Unit
我是 python 和 pygame 的新手,我正在尝试学习向量和类的基础知识,但在这个过程中我搞砸了,而且我在理解和修复标题中的错误消息方面苦苦挣扎。 这是我的 Vector 类的代码: impor
我正在编写一个程序来打开和读取一个 txt 文件,并在每一行中循环。将第 2 列和第 4 列中的值相乘并将其分配给第 5 列。 A 500.00 A 84.15 ? B 648.80 B 77.61
我知道还有其他几个问题提出了完全相同的问题,但是当我运行时: 导入命令 从 pyDes 导入 * def encrypt(data, password,): k = des(password,
我有一个元组列表,内容如下: >>>myList [(), (), ('',), ('c', 'e'), ('ca', 'ea'), ('d',), ('do',), ('dog', 'ear', '
给定一个 boost::tuple 和 std::tuple,你如何在它们之间进行转换? 也就是说,您将如何实现以下两个功能? template boost::tuple asBoostTuple(
我无法初始化 std::tuple来自 std::tuple 的逐元素元素兼容类型。为什么它不像 boost::tuple 那样工作? #include #include template st
我是 Storm 的新手并且我正在尝试找出如何编写一个 bolt 测试来测试子类 BaseRichBolt 中的 execute(Tuple tuple) 方法。 问题是 Tuple 似乎是不可变的,
如果我有如下元组列表: [('a', 'b'), ('c', 'd'), ('a', 'b'), ('b', 'a')] 我想删除重复的元组(在内容和内部项目顺序方面重复)以便输出为: [('a',
我编写了一个简单的脚本来模拟基于每用户平均收入 (ARPU)、利润率和客户保持客户的年数 (ltvYears) 的客户生命周期值(value) (LTV)。下面是我的脚本。它在“ltvYears =
以下是我的代码,它是一组元组:。输出:设置([(‘A’,20160129,36.44),(‘A’,20160104,41.06),(‘A’,20160201,37.37)])。如何将另一个元组(‘A’
我用以下代码编写了一个程序: import pandas as pd import numpy as np from typing import Tuple def split_data(self,
我是一名优秀的程序员,十分优秀!