我想在我的類中包含指向成員函數的表。 MS C++(Visual Studio 2015)編譯器抱怨類中_requests表的初始值設定項以及std :: bind的用法。編譯器的錯誤消息不是非常有幫助的:如何聲明指向類初始化程序中成員函數的指針並調用這些指針?
1> d:\ TEMP \ win32project1 \ win32project1 \ source1.cpp(59):錯誤C3867: 'TLV :: parse_read':非標準語法;使用 '&' 創建一個指針 構件
1> d:\ TEMP \ win32project1 \ win32project1 \ source1.cpp(62):錯誤C3867: 'TLV :: parse_write':非標準語法;使用 '&' 創建一個指針 到構件
1> d:\ TEMP \ win32project1 \ win32project1 \ source1.cpp(40):錯誤C2440: '初始化':無法從「STD轉換:: _粘合劑& >」到 '的std ::函數'
1> d:\ TEMP \ win32project1 \ win32project1 \ source1.cpp(40):注意:沒有 構造可以採取源類型或構造函數重載 分辨率爲曖昧
放置一個安培沙在表中的日常名稱前面只是改變了錯誤的非法操作上綁定的成員函數
#include <cstdint>
#include <functional>
#include <vector>
#include <iostream>
using namespace std;
enum TLV_TYPE : uint32_t
{
tlv_type_read,
tlv_type_write
};
typedef struct
{
TLV_TYPE type;
uint32_t length;
} TLV_RECORD, *pTLV_RECORD;
typedef function <uint32_t (const TLV_RECORD& Record)> pTLV_PARSER;
typedef struct
{
TLV_TYPE type;
pTLV_PARSER parse_routine;
} TABLE, *pTABLE;
class tlv
{
public:
tlv()
{
};
~tlv()
{
};
uint32_t start_parse (const TLV_RECORD& Record)
{
pTLV_PARSER parser = std::bind (_requests [0].parse_routine, this, placeholders::_1);
parser (Record);
return 0;
};
protected:
uint32_t parse_read (const TLV_RECORD& Record)
{
cout << "parse read: type " << Record.type << endl;
return 0;
}
uint32_t parse_write (const TLV_RECORD& Record)
{
cout << "parse write: type " << Record.type << endl;
return 0;
}
const TABLE _requests [2] =
{
{tlv_type_read, parse_read},
{tlv_type_write, parse_write},
};
}; // End of class tlv
int main()
{
tlv foo;
TLV_RECORD rec = {tlv_type_read, 4};
foo.start_parse (rec);
return 0;
}
'{tlv_type_read,parse_read}'應'{tlv_type_read,&parse_read}'和同上,用於下面的行,閉嘴前兩個編譯器警告。 – cdhowie
*「編譯器的錯誤消息不是非常有用:」* - Visual Studio 2015? ...與十年前C++編譯器產生的錯誤消息相比,這是一個非常有用的錯誤消息。 – WhiZTiM