0

尝试编写一些简单的多线程服务器程序并最近遇到了该错误:

Server.cpp:64:64: 错误: 'void* (Server::)(void*)' 类型的参数不匹配'void* (*)(无效*)

这是我的代码中的一些行:

头文件:

class Server
{
public:
void establishConnection(const char * );
...

private:
void *listening(void *);
void *acceptingConnection(void *);
pthread_attr_t attrr;
}

cpp文件:

void Server:: establishConnection(const char *port_number )
{
...
  pthread_create(&listn, &attrr, Server::listening, (void*)socketfd);//pthread_t listn, socketfd is a socket destricptor(int)     
  pthread_join(listn, NULL);

}
void* Server::listening(void *arg)
{
  int socketfd = (int)arg;
  ...
}

通常,如果我在 cpp 文件而不是头文件中定义线程函数原型,它可以正常工作(当然没有 Server:: 定义)尝试了其他一些东西,例如 (void*)Server::listening、listening、(void*)listening但仍然没有工作。你能启发我吗?如何将方法参数传递给监听方法?

其次,我目前正在学习c++(已经知道C),在c++程序中使用一些C方法,char*数组而不是字符串,头文件是真的吗?比如string.h、stdlib.h、pthread.h?

4

2 回答 2

1

您可以阅读错误消息:

type ‘void* (Server::)(void*)’ does not match ‘void* (*)(void*)‘

因为Server::listening是 的非静态成员函数Server,并且指针非静态成员函数不可能转换为指向非成员函数的指针。

你必须制作你的Server::listening函数static,或者在课堂之外编写一个独立的函数Server

于 2013-05-31T07:23:42.917 回答
1

您需要创建一个包装函数pthread_create(),并从那里调用您的类方法。

class Server
{
...   
private:
int sock;
};

extern "C" void * server_listening (void *arg) {
    Server *s = static_cast<Server *>(arg);
    return s->listening();
}

void Server:: establishConnection(const char *port_number )
{
...
  this->sock = socketfd;
  pthread_create(&listn, &attrr, server_listening, this);
  pthread_join(listn, NULL);
}

包装函数上的extern "C"链接已经到位,因为pthread_create()它是一个 C 函数,并且需要一个带有 C 链接的函数指针。如果您的系统上的 C ABI 和 C++ ABI 不相同,这一点很重要。类的静态方法只能具有 C++ 链接。

于 2013-05-31T07:23:59.387 回答