[英]How can I write to cout with blocking?
我到处都在寻找示例,并查看了C ++手册(通过示例,我学得最好)。
我需要的是一种可以通过阻塞并发分配来写出标准的方法。
建议我使用“受保护的cout”,但我不知道这是什么意思。 最初,我一直在使用C的写操作,但是这样做会损失一些点。
我想到的其他解决方案是使用信号量来保护cout,因此它一次只能打印一个线程。 但是我感觉到那里有C ++内置的...
帮助将不胜感激。 而且,请不要在没有给出示例的情况下将我链接到http://www.cplusplus.com/上的任何内容。 我是C ++的新手,如果我是cplusplus.com上的api专业人员,我不会问这个问题。
编辑:更多信息有关我的问题。 不允许使用C ++ 11。 我不允许任何第三方图书馆。 所以提振是不行的。 必须在其上执行的机器是Unix机器。
最终编辑:itwasntpete最接近正确答案,但是我不能选择评论。 信号量是我必须走的路。 @Casey是的,我正在使用教授编写的第3方库,该库为我们简化了并发。 但是我们不允许使用其他库。 通常,尝试帮助的人更容易做到这一点。 抱歉!
我认为流没有内置任何同步。 在C ++ 03中,cout甚至不一定是线程安全的。 在c ++ 11中,它是但仍未同步。
看到这个问题: cout是同步的/线程安全的吗?
C ++ 11支持线程,否则您可以使用与操作系统有关的线程,或者更简单的方法可能是诸如boost的库,它以统一的方式支持线程。
提升: http : //www.boost.org/doc/libs/1_38_0/doc/html/thread.html
C ++ 11: http : //en.cppreference.com/w/cpp/thread
这是一些应该执行您想要的代码。 您需要将其与boost_thread-mt和pthread链接,例如gcc -pthread test.cpp -o test -lboost_thread-mt
您必须对其进行调整以使其与线程库一起使用,而不是与Boost一起使用。
#include <iostream>
#include <boost/thread/mutex.hpp>
#include <boost/thread/thread.hpp>
class Debug {
private:
static boost::mutex mutex;
std::ostream &os;
public:
Debug(std::ostream &os) : os(os)
{
mutex.lock();
}
~Debug()
{
mutex.unlock();
}
template<typename T> friend const Debug& operator<<(const Debug &d, const T& x)
{
d.os << x;
return d;
}
friend const Debug& operator<<(const Debug &d, std::ostream& (*x)(std::ostream&))
{
d.os << x;
return d;
}
};
boost::mutex Debug::mutex;
using namespace std;
using boost::thread;
void f(int i)
{
Debug(cout) << "This is " << i << " a test" << endl;
}
int main()
{
thread t1(f, 1);
thread t2(f, 2);
thread t3(f, 3);
t1.join();
t2.join();
t3.join();
return 0;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.