我有一个字节数组,其中包含事件 ID 和一些 ID 的事件数据: {0x1, 0x2, 0x32}//例如,0x1 - eventId,0x2 - 它的数据,0x32 - 另一个事件 ID。
为了解析它并创建 Event 对象,我创建了几个二进制函数,它们知道如何解释事件数据字节和一个以事件 ID 作为键并以指向 std::binary_function 的指针作为值的映射:
map<uint8_t, SspProtocol::EventDataParser*>
SspProtocol::EventDataParser 在哪里:
typedef unsigned char uint8_t; // declared in file stdint.h
[...]
class SspProtocol {
typedef std::binary_function<const std::vector<uint8_t>*, std::vector<uint8_t>::const_iterator*, Event> EventDataParser;
[...]
}
当我尝试调用这个仿函数时出现编译器错误:
vector<SspProtocol::Event> SspProtocol::poll() {
vector<uint8_t> data = sendCommand(POLL);
vector<Event> events;
const vector<uint8_t>& const_data = data; // (*)
for (vector<uint8_t>::const_iterator i = const_data.begin(); i != const_data.end();) {
map<uint8_t, SspProtocol::EventDataParser*>& parsers = Event::eventParser();
EventDataParser& parser = *parsers[*i]; // (**)
Event event = parser(&const_data, &i); // (***)
events.push_back(event);
}
return events;
}
我在行 (*) 上遇到错误:
error: no match for call to
‘(protocols::ssp::SspProtocol::EventDataParser
{aka std::binary_function<const std::vector<unsigned char>*,
__gnu_cxx::__normal_iterator<const unsigned char*,
std::vector<unsigned char> >*, protocols::ssp::SspProtocol::Event>
}) (const std::vector<unsigned char>*,
std::vector<unsigned char>::const_iterator*)’
为什么我的 g++ 编译器使用 __gnu_cxx::__normal_iterator* 而它为什么与 const_iterator* 不兼容?我该怎么办?
P.S.:我特别在行 () 上添加了 const 引用,以使第一个模板参数具有 const-qualifier 并且我还划分了仿函数调用并从映射中获取仿函数(参见行 ( *)). 这告诉我错误出在仿函数调用上,它没有连接到 map 和 auto_ptr。
P.P.S.:这是一个示例事件解析器:
class SspProtocol::EventWithoutDataParser
: public SspProtocol::EventDataParser {
bool ackEvent_;
public:
EventWithoutDataParser(bool ackEvent = false) : ackEvent_(ackEvent) {}
Event operator()(const vector<uint8_t>* data, vector<uint8_t>::const_iterator* i) {
Event event(*(*i));
++(*i);
return event;
}
bool ackEvent() const { return ackEvent_; }
};
最佳答案
查找 std::binary_function ( http://en.cppreference.com/w/cpp/utility/functional/binary_function ) 的文档。它是二进制函数的基类,除了记录参数类型和返回类型外什么都不做。它没有定义实际的 operator() (a,b) 所以显然它不能在这个类型的实例/指针上调用。相反,请尝试使用
std::function<Event(const std::vector<uint8_t>*, std::vector<uint8_t>::const_iterator*)>
按值(不是按指针,它已经是一种高级函数指针)来存储您的解析器函数。可以检查 std::function 是否为空并调用。
关于c++ - binary_function,调用时出现编译器错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22343994/