c++ - 如果您不知道传递的方法的确切类,如何将方法传递给类

标签 c++ function class pointers arduino

很抱歉不知道如何描述我的问题。我希望这个例子很清楚。

//My Arduino based device has a real time clock for which I use a library
#include <RTClib.h> 
RTC_DS3234  RTClock(PIN_CLOCK_CS); // uses SPI
DateTime dt = RTClock.now();
// I also have written a logging class which is a singleton
#include <Logger_SD.h>
Logger_SD::Instance()->initializeSD(PIN_SD_CS,PIN_CLOCK_CS,&dt);

所以我的记录器类现在在生成日志消息时使用指向 dt 的指针作为它的日期。不幸的是,每次调用记录器时,我都必须更新 dt 以使其具有正确的日期和时间。

dt = RTClock.now();
Logger_SD::Instance()->msgL(INFO,F("Setting Up MPU6050 Gyro."));

我想传递 RTClock.now() 方法,该方法总是将 DateTime 返回给 Logger_SD,这样它就可以获得自己该死的时间。不幸的是,RTC 有很多种。我本可以做到:

RTC_DS1307 RTClock(0x68); // Uses i2c
// or
RTC_DS3231 RTClock(0x68); // Also I2c, but does more.
// Lots more.
// then again...
DateTime dt;
dt = RTClock.now();
// I'd like to do something like:
DateTime myNow() return RTClock.now();
Logger_SD::Instance()->initializeSD(PIN_SD_CS,PIN_CLOCK_CS,&myNow);

这些都有一个返回 DateTime 的 now() 方法,但是我如何将 now() 方法传递给 Logger_SD 而不必为每个 RTC 对象类都设置一个特例?

如果有帮助的话,我的 Logger_SD.h 看起来有点像这样:

class Logger_SD {
    public: // I don't quite understand the mechanics here, but it works great.
        static Logger_SD* Instance(); 
        bool initializeSD(const uint8_t, const uint8_t disable_chip_select,DateTime* dt);
        void msgL(LOG_LEVEL logLevel,const __FlashStringHelper *format, ... );
        // ...
    private:
        Logger_SD(){};
        Logger_SD(Logger_SD const&){};
        Logger_SD& operator=(Logger_SD const&){};
        static Logger_SD* m_pInstance;
        DateTime    *_dt;
        // ...
};

我希望这已经很清楚了。

这是一个简单的例子:

class RTC1 {
  public:
    char  now() { return 'A';}
};
class RTC2 {
  public:
    char  now() { return 'B';}
};
class Logger {
  public:
    void ini(char f()) { logTime = &f ;} // this doesn't work
    char (*logTime)();
};
void setup(){
  Serial.begin(57600);
  RTC1 myRTC1;
  Logger myLogger;
  myLogger.ini(&myRTC1.now);
  Serial.println(MyLogger.logTime()); // Should print 'A'
  // now on a diffent kind of RTC for the same Logger
  RTC2 myRTC2;
  myLogger.ini(&myRTC2.now);
  Serial.println(MyLogger.logTime()); // Should print 'B'
}

最佳答案

myRTC1.now 无法转换为函数指针 - 它是类方法。您需要一个 myRTC1 实例来调用 now。你试图按原样做的事情是不可能的。

你可以做的是采用std::function:

class Logger {
public:
    using LogFunc = std::function<char()>; // any function that takes no 
                                          // args and returns a char

    template <typename F>
    void ini(F&& f) { logTime = std::forward<F>(f); }
    LogFunc logTime;
};

然后你可以这样分配:

Logger myLogger;
myLogger.ini(std::bind(&RTC1::now, myRTC1));
myLogger.ini([&]{ return myRTC2.now(); });

关于c++ - 如果您不知道传递的方法的确切类,如何将方法传递给类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28423387/

相关文章:

c++ - 暂时禁用特定版本 GCC 的警告

java - 在函数中取任何数值原始数组

javascript - 变量更新时变量参数发生变化的函数

Objective-C:访问声明为@private 的实例变量

c++ - 堆栈(数据结构)实现

c++ - QDir::rename() 用于 2 个不同的分区

C++:为什么在另一个函数中允许函数声明而不是函数定义?

jquery - 从 iframe 运行父 jquery

python - 循环遍历类实例列表

c++ - BOOST_STATIC_ASSERT_MSG - 缺少错误信息