C++:自定义数据类型向量错误的队列

C++: Queue of custom data type vector error

本文关键字:错误 队列 向量 定义数据类型 C++      更新时间:2023-10-16

我正在使用自定义类型向量的线程安全队列。 它显示以下错误。我不确定我在这里错过了什么。

错误 C2664 'std::vector>::vector(std::vector<_Ty,std::allocator<_Ty>> &&,const _Alloc &( noexcept((':无法将参数 2 从 'int' 转换为 'const std::allocator<_Ty> 和 '

#include <mutex>
#include <condition_variable>
#include <queue>
#include <memory>
#include <iostream>
#include <thread>
template<typename T>
class threadsafe_queue
{
private:
mutable std::mutex mut;
std::queue<T> data_queue;
std::condition_variable data_cond;
public:
threadsafe_queue()
{}
threadsafe_queue(threadsafe_queue const& other)
{
std::lock_guard<std::mutex> lk(other.mut);
data_queue = other.data_queue;
}
void push(T new_value)
{
std::lock_guard<std::mutex> lk(mut);
data_queue.push(new_value);
data_cond.notify_one();
}
void wait_and_pop(T& value)
{
std::unique_lock<std::mutex> lk(mut);
data_cond.wait(lk, [this] {return !data_queue.empty(); });
value = data_queue.front();
data_queue.pop();
}
std::shared_ptr<T> wait_and_pop()
{
std::unique_lock<std::mutex> lk(mut);
data_cond.wait(lk, [this] {return !data_queue.empty(); });
std::shared_ptr<T> res(std::make_shared<T>(data_queue.front()));
data_queue.pop();
return res;
}
bool try_pop(T& value)
{
std::lock_guard<std::mutex> lk(mut);
if (data_queue.empty)
return false;
value = data_queue.front();
data_queue.pop();
}
std::shared_ptr<T> try_pop()
{
std::lock_guard<std::mutex> lk(mut);
if (data_queue.empty())
return std::shared_ptr<T>();
std::shared_ptr<T> res(std::make_shared<T>(data_queue.front()));
data_queue.pop();
return res;
}
bool empty() const
{
std::lock_guard<std::mutex> lk(mut);
return data_queue.empty();
}
};
class cp_data
{
public:
int num;
double time;
cp_data(int a, double b)
{
num = a;
time = b;
}
};
int main() {
std::vector<cp_data> data(1,2);
threadsafe_queue<std::vector<cp_data>> temp_queue;
temp_queue.push(data);
system("pause");
}

vector 没有构造函数将其参数转发到它所持有的数据类型以创建单个元素。

但是,您可以使用std::initializer_list构造函数通过执行以下操作传入一个对象(如果需要,也可以传入多个对象(:

改变

std::vector<cp_data> data(1,2);

std::vector<cp_data> data{{1,2}};

或者,您可以在语法上更明确地创建cp_data对象:

std::vector<cp_data> data{cp_data(1,2)};

{1,2}创建cp_data对象,然后通过外部{...}创建的std::initializater_list将对象传递给向量的构造函数

直播: https://godbolt.org/g/s2AwJU

作为旁注,vector::emplace_back确实像您的代码尝试构造对象一样工作 - 它会将您的参数转发给cp_data的构造函数,以便创建一个对象以存储在向量中。