是否可以在C++类中使用信号?

Pab*_*ero 31 c++ signal-handling

我正在做这样的事情:

#include <signal.h>

class myClass {
public: 
    void myFunction () 
    {
        signal(SIGIO,myHandler);
    }

    void myHandler (int signum)
    {
        /**
        * Handling code
        */
    }

}
Run Code Online (Sandbox Code Playgroud)

我正在使用gcc在Ubuntu上工作.

但它不会编译.它抱怨:

错误:类型的参数void (MyClass::)(int)不一致void (*) (int)

有线索吗?或者也许只是我不能在课程中使用信号?信号是否仅允许在C中?

错误消息是近似翻译,因为我的编译器不是英文.

Luc*_*lle 40

signal的第二个参数应该是一个指向接受int并返回void的函数的指针.你传递给signal的是指向成员函数的指针,该成员函数接受int并返回void(其类型为void (myClass::*)(int)).我可以看到三种可能性来克服这个问题:

1 - 你的方法myHandler可以是静态的:这很好,让它静止

class myClass 
{
  public:
    void myFunction () 
    {
        signal(SIGIO, myClass::myHandler);
    }

    static void myHandler (int signum)
    {
        // handling code
    }
};
Run Code Online (Sandbox Code Playgroud)

2 - 您的方法不应该是静态的:如果您计划仅使用一个实例的信号,则可以创建一个私有静态对象,并编写一个简单地在此对象上调用该方法的静态方法.有点像

class myClass 
{
  public:
    void myFunction () 
    {
        signal(SIGIO, myClass::static_myHandler);
    }

    void myHandler (int signum)
    {
        // handling code
    }

    static void static_myHandler(int signum)
    {
        instance.myHandler(signum);
    }

  private:
    static myClass instance;
};
Run Code Online (Sandbox Code Playgroud)

3 - 但是,如果您计划在多个实例中使用信号,事情将变得更加复杂.也许解决方案是将每个要在静态向量中操作的实例存储起来,并在每个实例上调用方法:

class myClass
{
  public:
    void myFunction () // registers a handler
    {
        instances.push_back(this);
    }

    void myHandler (int signum)
    {
        // handling code
    }

    static void callHandlers (int signum) // calls the handlers
    {
        std::for_each(instances.begin(), 
                      instances.end(), 
                      std::bind2nd(std::mem_fun(&myClass::myHandler), signum));
    }
  private:
    static std::vector<myClass *> instances;
};
Run Code Online (Sandbox Code Playgroud)

在某个地方,打一个电话

signal(SIGIO, myClass::callHandlers);
Run Code Online (Sandbox Code Playgroud)

但我认为如果你最终使用最后的解决方案,你应该考虑改变你的处理设计:-)!

  • 我尝试了#2 以及解决方案,但由于对“myClass::instance”的未定义引用而遇到了相同的问题。我确实将 myClass 更改为我正在使用的类。我了解 c++,但这个问题让我陷入困境。 (2认同)

Jør*_*sen 9

要传递指向方法的指针,它必须是静态方法,您必须指定类名.

试试这个:

class myClass {
  void myFunction () 
  {
    signal(SIGIO, myClass::myHandler);
  }

  static void myHandler (int signum)
  {
     // blabla
  }
};
Run Code Online (Sandbox Code Playgroud)

您还应该阅读Baget提供的链接,C++ FAQ中第33.2段.