`
mfcai
  • 浏览: 404732 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

mingw无法编译多线程程序的问题及解决

阅读更多
在linux环境下,用gedit+gcc方式学习一段时间的c语言,发现自己越来越佩服linux的牛人了。
居然不用IDE也能开发代码。我做不到,所以有回到了windows的怀抱。

mingw是windows版本的gnu c/c++工具集 主要包括编译器gcc,连接器make,调试器gdb
Eclipse是很好用的开发Java的IDE,CDT的全称是C/C++ Development Tools,是使Eclipse能够支持C/C++开发的插件。
本人使用的开发环境如下:
win7+eclipse +MinGW + CDT

本文的目的:
1)使用eclipse、MingW独构建Windows版的c/c++开发环境
2)编译并调通了一个多线程的程序
eclipse、MingW的安装此处不做重点。


1、配置C/C++开发环境
右击我的电脑,点属性->高级->环境变量。然后:
1)在PATH里加入C:\MinGW\bin
2)新建LIBRARY_PATH变量,值设为C:\MinGW\lib,这是标准库的位置。
3)新建C_INCLUDE_PATH变量,值设为C:\MinGW\include。
4)新建CPLUS_INCLUDE_PATH变量,值为C:\MinGW\include\c++\3.4.2;C:\MinGW\include\c++\3.4.2\mingw32;C:\MinGW\include\c++\3.4.2\backward;C:\MinGW\include


2、设置eclipse的环境变量
Eclipse的Project->Properties->C/C++ Build->Environment中去查看对应的PATH变量
主要是看有没有添加一个包含MinGW的bin目录的PATH变量。这个变量在创建工程的时候一般会自动添加。
但如果没有正确设置PATH变量,编译的时候就会报错说不能运行g++或者gcc。

3、设置多线程动态链接库
Project->Properties->C/C++Build->Settings->Tool Settings->GCC C++ Linker->Libraries
添加Libraries (-l): lpthread

4、一个简单的线程池的例子

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/types.h>
#include <pthread.h>
#include <assert.h>

typedef struct worker
{
  
    void *(*process) (void *arg);
    void *arg;
    struct worker *next;


} CThread_worker;


typedef struct
{
pthread_mutex_t queue_lock;
pthread_cond_t queue_ready;

     CThread_worker *queue_head;
    int shutdown;
     pthread_t *threadid;
  
    int max_thread_num;
  
    int cur_queue_size;


} CThread_pool;


int pool_add_worker (void *(*process) (void *arg), void *arg);
void *thread_routine (void *arg);


static CThread_pool *pool = NULL;
void
pool_init (int max_thread_num)
{
     pool = (CThread_pool *) malloc (sizeof (CThread_pool));


     pthread_mutex_init (&(pool->queue_lock), NULL);
     pthread_cond_init (&(pool->queue_ready), NULL);

     pool->queue_head = NULL;

     pool->max_thread_num = max_thread_num;
     pool->cur_queue_size = 0;

     pool->shutdown = 0;
     pool->threadid =
         (pthread_t *) malloc (max_thread_num * sizeof (pthread_t));
    int i = 0;
    for (i = 0; i < max_thread_num; i++)
     {
         pthread_create (&(pool->threadid[i]), NULL, thread_routine,
                 NULL);
     }
}


int
pool_add_worker (void *(*process) (void *arg), void *arg)
{
  
     CThread_worker *newworker =
         (CThread_worker *) malloc (sizeof (CThread_worker));
     newworker->process = process;
     newworker->arg = arg;
     newworker->next = NULL;

     pthread_mutex_lock (&(pool->queue_lock));
  
     CThread_worker *member = pool->queue_head;
    if (member != NULL)
     {
        while (member->next != NULL)
             member = member->next;
         member->next = newworker;
     }
    else
     {
         pool->queue_head = newworker;
     }


     assert (pool->queue_head != NULL);


     pool->cur_queue_size++;
     pthread_mutex_unlock (&(pool->queue_lock));
  
     pthread_cond_signal (&(pool->queue_ready));
    return 0;
}


int
pool_destroy ()
{
    if (pool->shutdown)
        return -1;
     pool->shutdown = 1;

     pthread_cond_broadcast (&(pool->queue_ready));
  
    int i;
    for (i = 0; i < pool->max_thread_num; i++)
         pthread_join (pool->threadid[i], NULL);
     free (pool->threadid);


  
     CThread_worker *head = NULL;
    while (pool->queue_head != NULL)
     {
         head = pool->queue_head;
         pool->queue_head = pool->queue_head->next;
         free (head);
     }
  
     pthread_mutex_destroy(&(pool->queue_lock));
     pthread_cond_destroy(&(pool->queue_ready));

     free (pool);
  
     pool=NULL;
    return 0;
}


void * thread_routine (void *arg)
{
     printf ("starting thread 0x%x\n", pthread_self ());
    while (1)
     {
         pthread_mutex_lock (&(pool->queue_lock));
      
        while (pool->cur_queue_size == 0 && !pool->shutdown)
         {
             printf ("thread 0x%x is waiting\n", pthread_self ());
             pthread_cond_wait (&(pool->queue_ready), &(pool->queue_lock));
         }


      
        if (pool->shutdown)
         {
          
             pthread_mutex_unlock (&(pool->queue_lock));
             printf ("thread 0x%x will exit\n", pthread_self ());
             pthread_exit (NULL);
         }


         printf ("thread 0x%x is starting to work\n", pthread_self ());


      
         assert (pool->cur_queue_size != 0);
         assert (pool->queue_head != NULL);

      
         pool->cur_queue_size--;
         CThread_worker *worker = pool->queue_head;
         pool->queue_head = worker->next;
         pthread_mutex_unlock (&(pool->queue_lock));


      
         (*(worker->process)) (worker->arg);
         free (worker);
         worker = NULL;
     }
     pthread_exit (NULL);
}


   // 下面是测试代码

void * myprocess (void *arg)
{
     printf ("threadid is 0x%x, working on task %d\n", pthread_self (),*(int *) arg);
     _sleep (1);
    return NULL;
}


int main (int argc, char **argv)
{
     pool_init (3);

  
    int *workingnum = (int *) malloc (sizeof (int) * 10);
    int i;
    for (i = 0; i < 10; i++)
     {
         workingnum[i] = i;
         pool_add_worker (myprocess, &workingnum[i]);
     }
  
     _sleep (5);
  
     pool_destroy ();


     free (workingnum);
    return 0;
}


5、问题及解决方法
1)build project时出现“Error launching builder (make -k all )”
先将C:\MinGW\bin底下的
mingw32-make.exe更名为make.exe,因为在Eclipse使用时它预设会抓系统里make这个文件名而不是mingw32-make.

2)build project时出现“launch failed,binary not found”
报错是因为没有指定编译器。为了让CDT能够采用MinGW进行编译,需要在 Eclipse 中进行设定
方法一:去Window->Preferences->C/C++->New CDT project wizard->Makefile Project下,找到 Binary Parser 取消 Elf Parser 改选 PE Windows Parser。或是其他编译器,看具体情况而定,
当然你也可以指定GNU ELF Parser。
方法二:去projrct -> properties -> c/c++ build -> settings ->Binary Parser下设置一下,比如使用GNU Elf Parser


3)undefined reference to 'pthread_create'
   undefined reference to 'pthread_join'
问题原因:
pthread 库不是 Linux 系统默认的库,由于Mingw下没有带,所以在项目中设置多线程动态链接库,也不管用。
ftp://sourceware.org/pub/pthreads-win32/pthreads-w32-2-8-0-release.exe
解开pthreads-w32-2-8-0-release.exe,把Pre- built.2中的libpthreadGC2.a改名为libpthread.a复制到c:\mingw\lib目录,
pthread.h复制到c: \mingw\include目录即可解决


本文欢迎转载,转载请注明作者与出处
作者:流星
出处:http://blog.sina.com.cn/staratsky
0
0
分享到:
评论

相关推荐

    MinGW 支持多平台、多语言编译以及原始编译的强大软件

    Mingw是“Windows最低限度GNU”的缩写,是本机Microsoft Windows应用程序的最低限度开发环境。 Mingw提供了一套完整的开源...此外,线程应用程序必须附带一个可自由分配的线程支持dll,作为mingw本身的一部分提供)。

    mingw-std-threads-master

    替代MinGW GCC thread 头文件的库,解决c++11及以上版本,在window下引用thread头文件不能正常编译的问题 适用人群:window 下c++开发 mingw-std-threads-master介绍 mingw-std-threads-master是一个为MinGW...

    mingw-std-threads:Windows上的MinGW GCC当前仍缺少标准线程实现

    MinGW GCC当前仍缺少标准C ++ 11线程类的实现。 目标Windows版本 此实现应与Windows XP(无论Service Pack)或更高版本一起使用。 该库会自动(在编译时)检测到目标Windows版本,并选择一个利用可用Windows功能的...

    boost 1.62 windows mingw gcc 5.3静态库

    windows 上由mingw 5.3编译成的boost 1.62支持多线程的静态库,方便大家使用

    java8stream源码-MultimediaTools-mingw-w64:用于编译许多多媒体实用程序的脚本和补丁,包括FFmpeg,以及

    Perl,多线程版本 ...而且,如果你使用我的一些脚本在线观看电视, Python m3u8 模块(从管理员提示运行“pip install m3u8”) 安装程序为某些设施设置了某些环境变量以使其正常工作。 FONTCONFIG_FILE=f

    WebSocket网络通信调试工具V1.1增强版.rar

    QT C++ WebSocket网络通信调试工具V1.1增强版,多线程,服务端+客户端二合一,博文地址...6、下载的压缩包内已包含编译并打包好的可执行程序,win32 + mingw编译,若无法打开请自行编译。

    CrashRpt_v.1.4.2_vs2008_also_ok

    1、windows多线程程序release版崩溃记录工具,便于该如何查找错误。 2、此工具主要用来配置windbug工具,一种排查程序发布版本崩溃这种非常难处理的缺陷的方法,非常棒,amazing! 3、google crashrpt,编译链接程序时...

    qt环境使用日志库可编译为dll.rar

    qt 5.5.1 mingw32 win系统编译通过,下日志输出到文件中多线程,方便系统调试使用

    基于Qt设计的人脸检测系统(OpenCV3.4.7+MinGW-32位).zip

    为了提高系统效率和响应速度,项目采用了多线程的架构。其中,主UI线程负责刷新界面和显示人脸识别结果,使用户可以实时观察到人脸检测的效果。摄像头采集线程通过调用OpenCV的摄像头接口从摄像头捕获视频帧,并实时...

    JNI技术手册 c/c++调用java

    目录 I. 目录 1 II. java c/cpp互相调用实例(姊妹篇之一)——java调用c/cpp 4 ...八、 多线程调用 61 Java代码 61 命令行运行:javap -s -p MyTest ,输出: 62 C代码testjava.c: 62 编译: 65 运行结果: 65

    chibios 源码 rtos

    时钟,I/O通道以及其他硬件资源在Win32处理器上模拟,应用程序代码不需要考虑这些问题。有可用的MinGW范例。 不需要内存分配,所有内核结构均是静态的并且通过声明来分配。 可选的,线程安全的堆分配子系统。 可...

    VernamTunnel:使用 Vernam 加密的 TCP 隧道

    具有 Vernam 密码加密的跨平台多线程 TCP 隧道。 您可以使用此软件启用对网络中私人服务的远程访问。 编译示例 在 *nix 操作系统中为 *nix 编译: $ make clean $ make 在 Windows 的 *nix 操作系统中编译: $ ...

    eclipse 开发c/c++

    Cygwin 的备用解决方案是 Minimalist GNU for Windows(MinGW)(请参阅 参考资料以获得链接)。 该工具是一组可免费获取、自由分发的特定于 Windows 的头文件和导入库,这些头文件和导入库与 GNU 工具集(它们允许...

    cyOS:这是一个莫得时间快要弃坑的操作系统

    基于timer的多线程切换 使用clion+qemu调试代码 3种timer(APIC PIT RTC) 获取系统时间 实现grub引导 todo-list 近期 读取grub数据 scanf函数 长期 完善文件系统 交互界面 malloc 依赖软件 xmake 用做构建系统 ...

    ECMAScript:GodotEngine的Javascript绑定

    Color等)的运算符覆盖TypeScript支持使用Worker API的多线程支持对所有godot API的完整代码完成支持,包括信号和枚举使用在Visual Studio Code中进行调试下载您可以从尝试预编译的二进制文件您还可以从获取具有最新...

    MSHV:MSHV业余无线电软件-开源

    编译:MinGw建议使用GCC 7.3.0线程模型posix。 QT5.6.3库。 IDE建议使用QDevelop 0.29。 源代码中包含所有其他库。 向K1JT Joe Taylor和WSJT Development Group致谢。 WSJT-X和相关程序的算法,源代码,外观和协议...

    exchange:Bigram交换算法

    评估可以在多个线程中并行进行。 使用词类和类词统计信息来提高效率。 每行假定一个句子。 如果语料库中不存在句子,则将开始和结束标记( 和&lt;/s&gt; )添加到每行。 困惑度值包括句子结尾符号。 更多细节: Martin...

Global site tag (gtag.js) - Google Analytics