相关疑难解决方法(0)

具有可移动,不可复制参数的std :: thread

以下程序不构建VS11 beta,gcc 4.5或clang 3.1

#include <thread>
#include <memory>

int main() {
    std::unique_ptr<int> p;
    std::thread th([](std::unique_ptr<int>) {

    },std::move(p));
    th.join();
}
Run Code Online (Sandbox Code Playgroud)

这是因为参数类型不可复制,但实现尝试复制它.

据我所知,这个程序很好,应该可行.对std :: thread的要求似乎意味着可移动的,不可复制的参数应该在这里工作.具体来说,它表示可调用对象和每个参数应满足MoveConstructible要求,并且INVOKE(DECAY_COPY(std::forward<F>(f)),DECAY_COPY(std::forward<Args>(args))...)应该是一个有效的表达式.

在这种情况下,我认为表达式可以解决这样的问题:

template <class T> typename std::decay<T>::type decay_copy(T&& v)
{ return std::forward<T>(v); }

std::unique_ptr<int> p;
auto f = [](std::unique_ptr<int>) {};

decay_copy(f)(decay_copy(std::move(p)));
Run Code Online (Sandbox Code Playgroud)

我不认为这应该涉及到副本p.gcc至少可以编译这个表达式,虽然VS11没有.

  1. 我对要求是错误的,参数必须是可复制的吗?
  2. 对于复制参数的实现,标准是否在此问题上留有余地?
  3. 或者我尝试不符合的实现?

c++ multithreading rvalue-reference c++11

9
推荐指数
1
解决办法
2374
查看次数

使用 C++11 实现线程安全并使用临时对象通过引用传递

在阅读了Similar Question 中的答案后,我仍然在想为什么这个代码片段没有出现段错误。临时对象“数据”应该在离开作用域后被释放。但显然,“数据”并未公布。有人可以帮助我吗?谢谢

#include <iostream>
#include <string>
#include <thread>
using namespace std;

void thfunc(string &data)
{
    for (;;)
    {
        cout << data << endl;
    }
}

int main()
{
    {
        string data = "123";
        std::thread th1(thfunc, std::ref(data));
        th1.detach();
    }

    for (;;)
    {
        cout << "main loop" << endl;
    }

    return 0;
}

Run Code Online (Sandbox Code Playgroud)

类似问题

c++ multithreading reference thread-safety

2
推荐指数
1
解决办法
70
查看次数