一个有错的文章但是仍然有很强的学习点的文章

32 篇文章 0 订阅

原帖链接不让贴

一个建立线程时常见的问题:invalid conversion from `void*' to `void*(*)(void*)

写程序,出错误,在CSDN博客上看到了前辈写的文章。

作者:futuredaemon in BUPT

void main_thread ( void *ptr )
{
char *message1 = "Thread 1";
char *message2 = "Thread 2";
pthread_t thread3, thread4;
int iret3, iret4;

iret3 = pthread_create(&thread3, NULL, (void *)&print_message_function, (void *) message1);
iret4 = pthread_create(&thread4, NULL, (void *)&print_message_function, (void *) message2);

}

void print_message_function( void *ptr )
{
     char *message;
     message = (char *) ptr;
     printf("%s \n", message);
}

以上这段代码在用g++编译是会有如下错误:
invalid conversion from `void*' to `void*(*)(void*)

我们注意在Posix定义建立线程函数的原型:


extern int pthread_create (pthread_t *__restrict __threadp,
                           __const pthread_attr_t *__restrict __attr,
                           void *(*__start_routine) (void *),
                           void *__restrict __arg) __THROW;
这个call中的第三个参数是载入一个函数,这个函数有一个参数可以传入,返回一个 通用指针。

我们再来看看原来函数中是怎样调用这一原型的,基本上就是类似一下的调用方式:
(void *)&main_thread 
这个表达式的含义:取一个指向函数main_thread的指针,然后将其转换为一个通用指针。

这就是说显然上述两个事情并非同一个事情,故而正确的调用方式是

iret3 = pthread_create(&thread3, NULL, print_message_function, (void *) message1);
处理函数的定义如下:
void* print_message_function( void *ptr )

值得注意的是在gcc编译时不会出错,但是用g++就会有问题,究其原因就是C语言编译器允许隐含性的将一个通用指针转换为任意类型的指针,而C++不允许。

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/gnuhpc/archive/2009/07/18/4358620.aspx

按照这个方法 ,还是不行 G++编译的时候一直说错误。 最后在群里一个前辈说 把函数前面加上EXTERN C ,强制按照C格式编译,就行了

函数: extern "C" void * sendDataToserver ( void *ptr )

调用: pthread_mutex_init (&mutex,NULL);
        ret=pthread_create(&sendData,NULL,sendDataToserver,NULL);
        if ( ret != 0)
        {
        printf("create thread error\n");
        return 0;
        }

就可以了,以后写程序的时候要多多总结了。


虽然文中有些点不对,但是却对我理解pthread及C与C++很有帮助,如果有朋友也发现了错误,欢迎一起探讨,看我们的思路是否正确;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值