Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2118966
  • 博文数量: 249
  • 博客积分: 1305
  • 博客等级: 军士长
  • 技术积分: 4733
  • 用 户 组: 普通用户
  • 注册时间: 2011-12-17 10:37
个人简介

不懂的东西还有很多,随着不断的学习,不懂的东西更多,无法消灭更多不懂的东西,那就不断的充实自己吧。 欢迎关注微信公众号:菜鸟的机器学习

文章分类

全部博文(249)

文章存档

2015年(1)

2014年(4)

2013年(208)

2012年(35)

2011年(1)

分类: C/C++

2012-12-10 09:27:00

    对于pthread_create为创建线程传递参数的问题,先前只知道传递单个参数的方法,现在需要传递多个参数。

    对于新手的我比较纠结,因此,上网查找资料,发现CU里面的一个帖子(帖子地址后面给出)。

    下面把帖子中认为对自己有用的知识摘录下来,以后经常看看。

    帖子内容:
  
    1、传递int、short、char等,大小少于一个指针长度类型的,强制转换为(void*),然后在线程函数里转换回来即可;

    2、传递多个参数的时候,创建线程的函数内malloc()一个结构体,把参数都放进去,然后传指针。等线程函数结束后,在线程内部free();

    3、前面同2,但是在主线程中把子线程join回来,然后在主线程中free();

    但是,对于第二种情况,一个函数malloc(),另一个函数free(),感觉不爽;
       对于第三种情况,虽然做到同一个函数内申请释放了,但是子线程无法detach,且主线程必须等待所有子线程返回后才能退出,也不爽。
    
    有啥好办法没?

    下面是其中部分回复:

    1、对于C++,经常的做法是:线程函数是类的静态函数,传递的参数时类的成员;

    2、用外部变量(全局变量),定义成数组,然后每个线程编号做下标;也就是,传句柄/下标比传指针安全,可以多一次有效性检查;

    3、直接在创建函数里用临时变量创建一个结构也可以
       这种方法是错误的,创建函数启动线程后不会阻塞,直接就返回了,临时变量也就失效了,等新线程再访问该临时变量的地址,会遭遇野指针。

    4、关于传递多个参数,一种比较通用的方式是为pthread_create做一次函数包装,由包装函数完成一些琐碎的事情,下面举例说明扩展成3个参数的例子,之后调用my_thread_create()即可处理多于一个参数的例子。

  1. typedef void * (*FUNCALLBACK)(void * arg1, void * arg2, void * arg3);
  2. typedef stuct {
  3.    FUNCALLBACK callback;
  4.    void * arg1;
  5.    void * arg2;
  6.    void * arg3;
  7. } ARGS;

  8. void * sub_thread_entry(void * arg)
  9. {
  10.     ARGS args;
  11.     
  12.     /* retrieve args */
  13.     args.callback = ((ARGS *)arg)->callback;
  14.     args.arg1 = ((ARGS *)arg)->arg1;
  15.     args.arg2 = ((ARGS *)arg)->arg2;
  16.     args.arg3 = ((ARGS *)arg)->arg3;
  17.     free(arg);
  18.     
  19.     return args.callback(args.arg1, args.arg2, args.arg3);
  20. }

  21. int my_pthread_create(pthread_t *thread, const pthread_attr_t *attr,
  22.         FUNCALLBACK start_routine, void *arg1, void * arg2, void * arg3)
  23. {
  24.     ARGS * args;
  25.     
  26.     if (NULL == (args=(ARGS *)malloc(sizeof(ARGS))))
  27.         return -1;
  28.      
  29.     /* push args into buffer */
  30.     args->callback = start_routine;
  31.     args->arg1 = arg1;
  32.     args->arg2 = arg2;
  33.     args->arg3 = arg3;
  34.     
  35.     return pthread_create(pthread, attr, sub_thread_entry, args);
  36. }


     帖子地址:

     感谢各位提供的方法,谢谢。






   梦醒潇湘love
       2012-12-10 9:51
      
阅读(24300) | 评论(0) | 转发(2) |
给主人留下些什么吧!~~