在VS2015中使用easylogging++新增支援Unicode
- #define ELPP_UNICODE
- #include "easylogging++.h"
- INITIALIZE_EASYLOGGINGPP
- int main(int argc, char** argv)
- {
- /// 同時使用 START_EASYLOGGINGPP 才能使用Unicode
- START_EASYLOGGINGPP(argc, argv);
- LOG(INFO) << L"巨集定義演示。";
- system("pause");
- return 0;
- }
結果編譯器連結的時候報錯:
1>tijianji.obj : error LNK2001: 無法解析的外部符號 "public: virtual class std::basic_string<wchar_t,struct std::char_traits<wchar_t>,class std::allocator<wchar_t> > __thiscall el::base::DefaultLogBuilder::build(class el::LogMessage const *,bool)const " (
1>E:\__wang\workspace\Projects\tijianji\Debug\tijianji.exe : fatal error LNK1120: 1 個無法解析的外部命令
是巨集INITIALIZE_EASYLOGGINGPP裡面的class DefaultLogBuilder : public LogBuilder {
public:
base::type::string_t build(const LogMessage* logMessage, bool appendNewLine) const;
};引起的。報錯應該是string_t無法識別引起的,這個型別宣告是這樣的:
#if defined(ELPP_UNICODE)
# define ELPP_LITERAL(txt) L##txt
# define ELPP_STRLEN wcslen
# if defined ELPP_CUSTOM_COUT
# define ELPP_COUT ELPP_CUSTOM_COUT
# else
# define ELPP_COUT std::wcout
# endif // defined ELPP_CUSTOM_COUT
typedef wchar_t char_t;
typedef std::wstring string_t;
typedef std::wstringstream stringstream_t;
typedef std::wfstream fstream_t;
typedef std::wostream ostream_t;
#else
# define ELPP_LITERAL(txt) txt
# define ELPP_STRLEN strlen
# if defined ELPP_CUSTOM_COUT
# define ELPP_COUT ELPP_CUSTOM_COUT
# else
# define ELPP_COUT std::cout
# endif // defined ELPP_CUSTOM_COUT
typedef char char_t;
typedef std::string string_t;
typedef std::stringstream stringstream_t;
typedef std::fstream fstream_t;
typedef std::ostream ostream_t;
#endif // defined(ELPP_UNICODE)
我明明都定義了巨集#define ELPP_UNICODE為什麼還是無法解析?
最後靈機一動把ELPP_UNICODE新增到“前處理器定義”裡面,結果就連結通過了。