虽然mdl开发不支持多线程,如果不涉及mdl的API还是可以使用多线程的,比如QT的UI部分和SQL部分都可以启用多线程。Qt的和Boost的thread都可以使用。
比较纠结的是二者之间的便捷性不同。习惯了随意使用function启动一个线程,就像用windows API那样,Qt就不是那么方便。Qt的多线程必须从Qthread继承并实现run函数,调用start函数就可以启动线程,有点绕。
#include <iostream>
#include <boost/thread.hpp>
#include <boost/thread/mutex.hpp>
#include <boost/thread/xtime.hpp>
using namespace boost;
using namespace std;
boost::mutex io_mu;
void print(int x,std::string str)
{
// io互斥量,去掉此行io输出会不正确
mutex::scoped_lock lock (io_mu);
std::cout << str << x << std::endl;
}
int main(int argc, char* argv[])
{
thread t0 (&print, 10,"thread t0 : ");
thread t1 (&print, 11,"thread t1 : ");
thread t2 (&print, 12,"thread t2 : ");
t0.join ( );
t1.join ( );
t2.join ( );
return 0;
}用Boost实现QThread的形式,采用类内部的函数调用,与QThread调用方式极相似:
class qprinter : public QThread
{
QString m_str;
public:
qprinter(QString str):m_str(str){}
virtual void run ( )
{
for (int i = 0; i != 5; ++i)
{
boost::mutex::scoped_lock lock (io_mu);
std::cout << m_str.toLatin1 ( ).data ( ) << i << std::endl;
}
}
};
class BoostbaseThread
{
public:
virtual void run ( ) = 0;
void start ( )
{
boost::thread t (&BoostbaseThread::run, this);
t.join ( );
}
};
class bprinter : public BoostbaseThread
{
std::string m_str;
public:
bprinter (std::string str) :m_str (str) {}
virtual void run ( )
{
for (int i = 0; i != 5; ++i)
{
boost::mutex::scoped_lock lock (io_mu);
std::cout << m_str << i << std::endl;
}
}
};
int main (int argc, char* argv [])
{
QApplication app (argc, argv);
qprinter printA ("A : ");
qprinter printB ("B : ");
printA.start ( );
printB.start ( );
bprinter printC ("C : ");
bprinter printD ("D : ");
printC.start ( );
printD.start ( );
return app.exec();
}QThread是参照Java的多线程进行设计的,对于支持全局函数的C++完全没必要这么玩。用类来封装还是太啰嗦了吧。

本文探讨了在不使用mdl API的情况下,Qt和Boost两种库在多线程编程上的应用。虽然Qt的UI和SQL部分可以利用多线程,但其线程创建相比Boost更显繁琐,需要继承QThread并实现run函数。而Boost则允许更直观地通过函数启动线程,提供了更便捷的多线程实现。
2107

被折叠的 条评论
为什么被折叠?



