热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

友善之臂的qtopia2.2.0加入多线程支持

本文章基于友善之臂提供的arm版本的qtopia2.2.0和x86版本的qtopia2.2.0,前提是系统中已经安装好交叉编译器。要实现多线程,主要是要获得带多线程支持的动态链接库libqte-

本文章基于友善之臂提供的arm版本的qtopia2.2.0和x86版本的qtopia2.2.0,前提是系统中已经安装好交叉编译器。
要实现多线程,主要是要获得带多线程支持的动态链接库libqte-mt.so.2,libqte-mt.so.2需要通过编译qt获得,下面是编译libqte-mt.so.2的方法(arm和x86版本方法类似,一起叙述)。
1) 将友善之臂提供的qt源码解压,按照友善之臂手册利用build-all脚本完成一次编译。

arm版本解压后的路径为:/opt/ARM/arm-qtopia/

x86版本解压后的路径为:/opt/ARM/x86-qtopia/

2) arm 版本执行如下命令:
cd  /opt/ARM/arm-qtopia/qtopia-2.2.0-FriendlyARMsource  setQteEnv
cd qt2
make clean
echo yes | ./configure -embedded -no-xft -qconfig qpe -depths 16,32 -system-jpeg -qt-zlib -qt-libpng -gif -no-g++-exceptions -no-qvfb -xplatform linux-arm-g++ -tslib –thread

x86版本执行如下命令:

cd  /opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM
source setQteEnv
cd qt2
make clean
echo yes|./configure -embedded -no-xft -qconfig qpe -depths 16,32 -system-jpeg -gif -thread
3) 上面的步骤执行后会在qt2目录下产生 src-mt.mk文件。

用编辑器将其内容的最后一行”cd src; $(MAKE) clean“删除或注释掉;

SHELL=/bin/sh

src-mt:
cd src; $(MAKE) 'QT_THREAD_SUFFIX=-mt'
'QT_LFLAGS_MT=$$(SYSCONF_LFLAGS_THREAD) $$(SYSCONF_LIBS_THREAD)'
'QT_CXX_MT=$$(SYSCONF_CXXFLAGS_THREAD) -DQT_THREAD_SUPPORT'
'QT_C_MT=$$(SYSCONF_CFLAGS_THREAD) -DQT_THREAD_SUPPORT'
cd examples/guithreads; $(MAKE) 'QT_THREAD_SUFFIX=-mt'
'QT_LFLAGS_MT=$$(SYSCONF_LFLAGS_THREAD) $$(SYSCONF_LIBS_THREAD)'
'QT_CXX_MT=$$(SYSCONF_CXXFLAGS_THREAD) -DQT_THREAD_SUPPORT'
'QT_C_MT=$$(SYSCONF_CFLAGS_THREAD) -DQT_THREAD_SUPPORT'
cd examples/semaphores; $(MAKE) 'QT_THREAD_SUFFIX=-mt'
'QT_LFLAGS_MT=$$(SYSCONF_LFLAGS_THREAD) $$(SYSCONF_LIBS_THREAD)'
'QT_CXX_MT=$$(SYSCONF_CXXFLAGS_THREAD) -DQT_THREAD_SUPPORT'
'QT_C_MT=$$(SYSCONF_CFLAGS_THREAD) -DQT_THREAD_SUPPORT'
cd src; $(MAKE) clean
4)执行如下命令:
make  src-mt

5)如果在如上编译过程中提示 qtextcodec.cpp 编译错误,将 /opt/ARM/new-qtopia/arm-qtopia/qtopia-2.2.0-FriendlyARM/qt2/src/tools/qtextcodec.cpp 改成下面的代码:( 2148-2180 行)
#define QT_NO_EUCJPCODEC
#ifndef QT_NO_EUCJPCODEC
(void)new QEucJpCodec;
#endif
#define QT_NO_SJISCODEC
#ifndef QT_NO_SJISCODEC
(void)new QSjisCodec;
#endif
#define QT_NO_JISCODEC
#ifndef QT_NO_JISCODEC
(void)new QJisCodec;
#endif
#define QT_NO_EUCKRCODEC
#ifndef QT_NO_EUCKRCODEC
(void)new QEucKrCodec;
#endif
#define QT_NO_GBKCODEC
#ifndef QT_NO_GBKCODEC
(void)new QGbkCodec;
#endif
#define QT_NO_BIG5CODEC
#ifndef QT_NO_BIG5CODEC
(void)new QBig5Codec;
#endif
#define QT_NO_RTLCODEC
#ifndef QT_NO_RTLCODEC
(void)new QArabicCodec;
(void)new QHebrewCodec;
#endif
#define QT_NO_TSCIICODEC
#ifndef QT_NO_TSCIICODEC
(void)new QTsciiCodec;
#endif

6)对于arm版本,在/opt/ARM/arm-qtopia/qtopia-2.2.0- FriendlyARM/qtopia/lib目录下生成所期待的libqte-mt.so.2.3.12文件,将libqte-mt.so.2.3.12 改为libqte-mt.so.2,放入开发板/lib文件夹下。
x86版本需要修改/etc/ld.so.conf如下,并执行ldconfig指令。如果不修改的话,在后面的程序执行过程中,会提示找不到libqte-mt.so.2动态链接库。

include ld.so.conf.d/*.conf
/opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM/qtopia/lib
/opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM/qt2/lib

下面以一个例子来说明如何使用多线程编程。
创建如下文件:
example.pro   //项目文件main.cpp      //main函数文件
example.cpp //例子程序
example.h //例子程序头文件
arm-build //编译arm版本可执行文件的脚本
x86-build //编译x86版本可执行文件的脚本
run //在x86上运行程序的脚本
example.pro
CONFIG		+= qtopiaappCONFIG		-= buildQuicklaunchCONFIG          += qt warn_on release threadDESTDIR	         = $(PWD)HEADERS	+= example.hSOURCES	+= example.cppSOURCES	+= main.cppTARGET   = exampleunix:LIBS += -lm -L/lib 

main.cpp

#include 
#include
#include
#include

#include "example.h"

int main(int argc,char *argv[])
{
QPEApplication a(argc,argv);

ExampleThread myThread;
myThread.start();

return a.exec();
}

example.cpp
#include "example.h"ExampleThread::ExampleThread(){}ExampleThread::~ExampleThread(){}void ExampleThread::run(){	while(1)	{		printf("example\n");		sleep(1);	}}
example.h
#ifndef EXAMPLE_H#define EXAMPLE_H#include #include #include #include #include #include #include #include #include class Q_EXPORT ExampleThread : public QObject,public QThread{Q_OBJECTsignals:    void	ExampleSignal();public:	ExampleThread();	~ExampleThread();protected:virtual void run();};#endif //EXAMPLE_H
arm-build
#!/bin/bashsource /opt/ARM/arm-qtopia/qtopia-2.2.0-FriendlyARM/setQpeEnv qmake -spec /opt/ARM/arm-qtopia/qtopia-2.2.0-FriendlyARM/qtopia/mkspecs/qws/linux-arm-g++ -o Makefile *.pro make cleanmake
x86-build
#!/bin/bashsource /opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM/setQpeEnv qmake -o Makefile -spec /opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM/qtopia/mkspecs/qws/linux-generic-g++ *.pro make cleanmake
run
#!/bin/shexport ApplicatiOnDir=$PWD/opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM/qt2/bin/qvfb -width 320 -height 240 -depth 16 &#export CAMERA_DEVICE=/dev/video1#qtopia-2.2.0-FrinedlyARM/qt2/bin/qvfb -width 640 -height 480 -depth 16 &cd /opt/ARM/x86-qtopia/qtopia-2.2.0-FriendlyARM/qtopia/imagemkdir root 2>/dev/null || trueexport HOME=$PWD/rootcd opt/Qtopiaexport PATH=$PWD/bin:$PATHexport LD_LIBRARY_PATH=$PWD/lib:$LD_LIBARAY_PATHexport QTDIR=$PWDexport QPEDIR=$PWDexport KDEDIR=$PWD/../kdesleep 3$ApplicationDir/example -qws

arm-build,x86-build,run三个脚本添加可执行权限,运行
./x86-build./run
如果能够不停的输出example,则表示x86版本添加多线程支持成功

执行arm-build,编译成arm版本的程序,复制到开发板上执行,如果也能输出example,表示arm版本添加多线程支持成功
( 为使qt支持输出调试信息到串口,修改 /bin/qtopia 文件最后一行为 exec $QPEDIR/bin/qpe 1>/dev/ttySAC0  2>/dev/null)

推荐阅读
author-avatar
蓝紫藤田_835
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有