欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++反射的一種實(shí)現(xiàn)方法詳解

 更新時(shí)間:2019年06月02日 10:54:06   作者:一張狗2.0  
這篇文章主要給大家介紹了關(guān)于C++反射的一種實(shí)現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

一、注冊(cè)輔助類

ClassRegistry:模板函數(shù),用于data、module、contextdata的注冊(cè),其中的函數(shù)解析:

create_object:從RegistryMap里找到傳入name對(duì)應(yīng)的RegistryNode(RegistryNode保存了名字和構(gòu)造函數(shù)),調(diào)用構(gòu)造函數(shù)返回。

register_class:用傳入的name和constructor注冊(cè)RegistryMap,只在Register的構(gòu)造函數(shù)里面調(diào)用,后面會(huì)在ClassRegister<IData> DataRegister、ClassRegister<IModule> ModuleRegister、ClassRegister<IContextData> ContextDataRegister用到。RegistryMap里面的數(shù)據(jù)是從register_class這個(gè)方法插入數(shù)據(jù)進(jìn)去的,后面會(huì)在IMPLEMENT_XXX中調(diào)用到這個(gè)。

fill_name_array:找到RegistryMap里面注冊(cè)的name,插入傳入?yún)?shù)。

二、使用到的宏定義

2.1 data

REGISTER_DATA:聲明構(gòu)造data_class的函數(shù) __construct_##name##_data() ,其中調(diào)用了data_calss的構(gòu)造函數(shù);
聲明獲取class的get_##name,函數(shù)體的get_data從 sign_data_map里面獲取到對(duì)應(yīng)的IData

#define REGISTER_DATA(data_class, name)          \
 inline ::wmf::IData* __construct_##name##_data() { return new data_class; } \
 namespace wmf {                \
 namespace internal {              \
 inline data_class* get_##name() { return get_data<data_class>(#name); }  \
 }                   \
 } // wmf::internal

IMPLEMENT_DATA:調(diào)用DataRegister的構(gòu)造函數(shù)。聲明變量__##name##_module_register,這里會(huì)將輸入的name和構(gòu)造函數(shù)__construct_##name##_data注冊(cè)到RegistryMap中;

#define IMPLEMENT_DATA(name)        \
 ::wmf::internal::DataRegister __##name##_module_register( \
  #name, __construct_##name##_data)

使用:

在需要用到的.cpp文件的的.h文件的位置調(diào)用REGISTER_DATA,聲明構(gòu)造函數(shù)和獲取data的get_xxx函數(shù)。

在每個(gè)service的cpp文件視線中調(diào)用IMPLEMENT_DATA,注入RegistryMap。

在每個(gè)service的cpp文件的InitInjection中,INJECT_DATA_MODULE_DEPENDENCY把這個(gè)詞典注入到module中。

2.2 module

REGISTER_MODULE:聲明__construct_#name##_module(),返回new module_class;

聲明獲取class的get_##name,函數(shù)體里面返回ModuleMap中保存的對(duì)象(cast_module從ModuleMap里面找到其對(duì)應(yīng)的對(duì)象,如果找不到,則從RegisterMap里面找到其構(gòu)造函數(shù),并調(diào)用create_object之后插入ModuleMap,并返回新建的對(duì)象(RegisterMap里面的數(shù)據(jù)從IMPLEMENT_XXX來的))

#define REGISTER_MODULE(module_class, name)    \
 inline ::wmf::IModule* __construct_##name##_module() { \
 return new module_class;        \
 }              \
 namespace wmf {          \
 namespace internal {         \
 inline module_class* get_##name(::wmf::Context& ctx) { \
 return ctx.cast_module<module_class>(#name);   \
 }              \
 }              \
 } // wmf::internal

IMPLEMENT_MODULE:聲明__##name##_module_register變量,以插入RegistryMap。

#define IMPLEMENT_MODULE(name)        \
 ::wmf::internal::ModuleRegister __##name##_module_register( \
  #name, __construct_##name##_module)

使用:

在新增module的.h文件最后調(diào)用REGISTER_MODULE聲明了在IMPLEMENT_MODULE中會(huì)用到的構(gòu)造函數(shù),以及聲明了從ModuleMap中獲取其對(duì)象的get_xxx函數(shù)。

在service的最后調(diào)用IMPLEMENT_MODULE,把module注冊(cè)到RegistryMap中。

2.3 context data

REGISTER_CONTEXT_DATA:聲明__construct_##name##_context_data(),新建data_class;

聲明獲取class的get_##name,函數(shù)體里面通過name查找到ContextDataMap保存的名字簽名對(duì)應(yīng)的IContextData,轉(zhuǎn)換為data_class返回。

#define REGISTER_CONTEXT_DATA(data_class, name)           \
 inline ::wmf::IContextData* __construct_##name##_context_data() { \
  return new data_class;                     \
 }                                 \
 namespace wmf {                          \
 namespace internal {                       \
 inline data_class* get_##name(const ::wmf::Context& ctx) {    \
  return ctx.cast_context_data<data_class>(#name);        \
 }                                 \
 }                                 \
 } // wmf::internal

IMPLEMENT_CONTEXT_DATA:聲明__##name##_context_data變量,這里會(huì)將輸入的name和構(gòu)造函數(shù)__construct_##name##_context_data注冊(cè)到RegistryMap中;

#define IMPLEMENT_CONTEXT_DATA(name)              \
 ::wmf::internal::ContextDataRegister __##name##_context_data( \
   #name, __construct_##name##_context_data)

2.4 index_data

DECLARE_INDEX_DATA:N for name, VT for VersionIndex 類型。聲明類型C為用類型VT組裝,path、name、desc用N組裝的VIAdaptor類型。

#define DECLARE_INDEX_DATA(VT, C, N)                    \
 extern const char __index_##N##_path[];                  \
 extern const char __index_##N##_name[];                  \
 extern const char __index_##N##_desc[];                  \
 typedef wmf::VIAdaptor<argument_type<void(VT)>::type, __index_##N##_path, \
             __index_##N##_name, __index_##N##_desc>      \
   C

DEFINE_INDEX_DATA:N for name,這里是聲明一堆string變量,用于data的path、name、desc。

#define DEFINE_INDEX_DATA(N)            \
 const char __index_##N##_path[] = #N "_path";   \
 const char __index_##N##_name[] = #N "_name";   \
 const char __index_##N##_desc[] = #N "_desc";   \
 DEFINE_string(N##_path, "", "index " #N " path"); \
 DEFINE_string(N##_name, "", "index " #N " name"); \
 DEFINE_string(N##_desc, "index_" #N, "index " #N " desc")

2.5 injection

DEFINE_INJECTION:定義一個(gè)把object_ref變量設(shè)置為class_type*類型的傳入變量的函數(shù)。

#define DEFINE_INJECTION(injection_name, class_type, object_ref) \
 void set_##injection_name(class_type* module) { object_ref = module; }

INJECT_OBJECT_OBJECT_DEPENDENCY:調(diào)用object_to這個(gè)對(duì)象的set_##injection_name方法,傳入?yún)?shù)是object_from的引用。結(jié)合DEFINE_INJECTION就是把object_from設(shè)置到object_to這個(gè)對(duì)象里面。

#define INJECT_OBJECT_OBJECT_DEPENDENCY(injection_name, object_from, \
                    object_to)          \
 (object_to).set_##injection_name(&(object_from))

INJECT_MODULE_DEPENDENCY:在上下文context中找到module_from的變量,注入到同一個(gè)上下文的module_from里面。

#define INJECT_MODULE_DEPENDENCY(injection_point, context, module_from, \
                 module_to)               \
 ::wmf::internal::get_##module_to(context)->set_##injection_point(   \
   ::wmf::internal::get_##module_from(context));

INJECT_DATA_MODULE_DEPENDENCY:把data注入到通過上下文context獲取的module_to中。

#define INJECT_DATA_MODULE_DEPENDENCY(injection_point, context, data, \
                   module_to)           \
 ::wmf::internal::get_##module_to(context)->set_##injection_point(  \
   ::wmf::internal::get_##data());

INJECT_MODULE_OBJECT_DEPENDENCY:通過上下文context獲取的module_from注入到object_to中。

#define INJECT_MODULE_OBJECT_DEPENDENCY(injection_point, context, module_from, \
                    object_to)               \
 (object_to).set_##injection_point(                      \
   ::wmf::internal::get_##module_from(context));

INJECT_OBJECT_MODULE_DEPENDENCY :object_from注入到通過上下文獲取的module_to中。

#define INJECT_OBJECT_MODULE_DEPENDENCY(injection_point, context, object_from, \
                    module_to)               \
 ::wmf::internal::get_##module_to(context)->set_##injection_point(      \
   &(object_from))

使用:

在上下文相關(guān)的session中調(diào)用INJECT_MODULE_DEPENDENCY、INJECT_DATA_MODULE_DEPENDENCY;

INJECT_MODULE_DEPENDENCY用于把session相關(guān)的信息(比如session_docs、request、response)注入到module中,module的意思是這個(gè)請(qǐng)求需要過的模塊名。

INJECT_DATA_MODULE_DEPENDENCY用于把data注入到module中。

三、總結(jié)

3.1 新增一個(gè)module

在新增module的.h文件最后調(diào)用REGISTER_MODULE聲明了在IMPLEMENT_MODULE中會(huì)用到的構(gòu)造函數(shù),以及聲明了從ModuleMap中獲取其對(duì)象的get_xxx函數(shù)。

在service的最后調(diào)用IMPLEMENT_MODULE,把module注冊(cè)到RegistryMap中。

在上下文相關(guān)的session中調(diào)用INJECT_MODULE_DEPENDENCY、INJECT_DATA_MODULE_DEPENDENCY;

INJECT_MODULE_DEPENDENCY用于把session相關(guān)的信息(比如session_docs、request、response)注入到module中,module的意思是這個(gè)請(qǐng)求需要過的模塊名。

INJECT_DATA_MODULE_DEPENDENCY用于把data注入到module中。

3.2 代碼回顧

ClassRegistry用于給第二項(xiàng)的一堆宏使用。module于類的映射關(guān)鍵在于RegistryMap,新增一個(gè)module的時(shí)候,服務(wù)會(huì)去RegistryMap里面找名字對(duì)應(yīng)的構(gòu)造函數(shù)。RegistryMap里面的數(shù)據(jù)是在IMPLEMENT_MODULE的時(shí)候注入進(jìn)來的name和類的對(duì)應(yīng)關(guān)系。配置文件里面配的是module的鏈條,比如需要過AModule,BModule,這時(shí)候就在init的時(shí)候把所有module都插進(jìn)去,然后在schedule_impl里面調(diào)用每個(gè)module的run函數(shù)。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • VS2022實(shí)現(xiàn)VC++打包生成安裝文件圖文詳細(xì)歷程

    VS2022實(shí)現(xiàn)VC++打包生成安裝文件圖文詳細(xì)歷程

    本文主要介紹了VS2022實(shí)現(xiàn)VC++打包生成安裝文件圖文詳細(xì)歷程,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C++雙線程調(diào)用網(wǎng)絡(luò)攝像頭與多線程調(diào)用多攝像頭同步執(zhí)行方法詳細(xì)講解

    C++雙線程調(diào)用網(wǎng)絡(luò)攝像頭與多線程調(diào)用多攝像頭同步執(zhí)行方法詳細(xì)講解

    這篇文章主要介紹了C++雙線程調(diào)用網(wǎng)絡(luò)攝像頭與多線程調(diào)用多攝像頭同步執(zhí)行方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-11-11
  • C語言中的指針新手初階指南

    C語言中的指針新手初階指南

    指針是C語言的靈魂,精華之所在,指針強(qiáng)大而危險(xiǎn),用得好是一大利器,用得不好是一大潛在危害,下面這篇文章主要給大家介紹了C語言中指針的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-10-10
  • c語言內(nèi)存泄露示例解析

    c語言內(nèi)存泄露示例解析

    從1988年著名的莫里斯蠕蟲 攻擊到有關(guān) Flash Player 和其他關(guān)鍵的零售級(jí)程序的最新安全警報(bào)都與緩沖區(qū)溢出有關(guān):“大多數(shù)計(jì)算機(jī)安全漏洞都是緩沖區(qū)溢出”,Rodney Bates 在 2004 年寫道
    2013-09-09
  • C++詳解如何實(shí)現(xiàn)單鏈表

    C++詳解如何實(shí)現(xiàn)單鏈表

    線性表的鏈?zhǔn)酱鎯?chǔ)又稱為單鏈表,它是指通過一組任意的存儲(chǔ)單元來存儲(chǔ)線性表中的數(shù)據(jù)元素。本文將用C++實(shí)現(xiàn)單鏈表,需要的可以參考一下
    2022-06-06
  • C++實(shí)現(xiàn)Dijkstra算法的示例代碼

    C++實(shí)現(xiàn)Dijkstra算法的示例代碼

    迪杰斯特拉算法(Dijkstra)是由荷蘭計(jì)算機(jī)科學(xué)家狄克斯特拉于1959年提出的,因此又叫狄克斯特拉算法。是從一個(gè)頂點(diǎn)到其余各頂點(diǎn)的最短路徑算法。本文將用C++實(shí)現(xiàn)Dijkstra算法,需要的可以參考一下
    2022-07-07
  • 詳解C語言中結(jié)構(gòu)體的自引用和相互引用

    詳解C語言中結(jié)構(gòu)體的自引用和相互引用

    這篇文章主要介紹了C語言中結(jié)構(gòu)體的自引用和相互引用,詳細(xì)解析了結(jié)構(gòu)體中指針的指向情況,需要的朋友可以參考下
    2016-04-04
  • VS2017中配置QT5.12.0的圖文教程

    VS2017中配置QT5.12.0的圖文教程

    本文主要介紹了VS2017中配置QT5.12.0的圖文教程,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • C++ 基于BFS算法的走迷宮自動(dòng)尋路的實(shí)現(xiàn)

    C++ 基于BFS算法的走迷宮自動(dòng)尋路的實(shí)現(xiàn)

    這篇文章主要為大家介紹了C++ 基于BFS算法實(shí)現(xiàn)走迷宮自動(dòng)尋路,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C++實(shí)現(xiàn)翻轉(zhuǎn)單詞順序

    C++實(shí)現(xiàn)翻轉(zhuǎn)單詞順序

    這篇文章給大家匯總介紹了C++實(shí)現(xiàn)翻轉(zhuǎn)單詞順序的三種方法,都非常的簡單,需要的朋友可以參考下
    2016-07-07

最新評(píng)論