communication_socket_base.h 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. /*
  2. * communication_socket_base 通信模块的基类,
  3. * 用户从这个基类继承, 初始化之后, 便可以自动进行通信
  4. * 重载解析消息和封装消息,
  5. *
  6. *Thread_safe_list<Binary_buf*> 使用 Binary_buf , 而不是string
  7. * 主要是为了支持直接发送数字0
  8. *
  9. *
  10. * */
  11. #ifndef __COMMUNICATION_SOCKET_BASE__HH__
  12. #define __COMMUNICATION_SOCKET_BASE__HH__
  13. #include <nnxx/message>
  14. #include <nnxx/socket.h>
  15. #include <nnxx/bus.h>
  16. #include <glog/logging.h>
  17. #include "../error_code/error_code.h"
  18. #include "../tool/binary_buf.h"
  19. #include "../tool/thread_safe_list.h"
  20. #include "../tool/thread_condition.h"
  21. #include "../communication/communication.pb.h"
  22. #include "../communication/communication_message.h"
  23. #include "../message/message_base.pb.h"
  24. #define COMMUNICATION_PARAMETER_PATH "../setting/communication.prototxt"
  25. class Communication_socket_base
  26. {
  27. //通信状态
  28. enum Communication_statu
  29. {
  30. COMMUNICATION_UNKNOW =0, //通信状态 未知
  31. COMMUNICATION_READY =1, //通信状态 正常
  32. COMMUNICATION_FAULT =3, //通信状态 错误
  33. };
  34. public:
  35. Communication_socket_base();
  36. Communication_socket_base(const Communication_socket_base& other)= delete;
  37. Communication_socket_base& operator =(const Communication_socket_base& other)= delete;
  38. ~Communication_socket_base();
  39. public://API functions
  40. //初始化 通信 模块。如下三选一
  41. virtual Error_manager communication_init();
  42. //初始化 通信 模块。从文件读取
  43. Error_manager communication_init_from_protobuf(std::string prototxt_path);
  44. //初始化 通信 模块。从protobuf读取
  45. Error_manager communication_init_from_protobuf(Communication_proto::Communication_parameter_all& communication_parameter_all);
  46. //初始化
  47. virtual Error_manager communication_init(std::string bind_string, std::vector<std::string>& connect_string_vector);
  48. //bind
  49. virtual Error_manager communication_bind(std::string bind_string);
  50. //connect
  51. virtual Error_manager communication_connect(std::vector<std::string>& connect_string_vector);
  52. //connect
  53. virtual Error_manager communication_connect(std::string connect_string);
  54. //启动通信, run thread
  55. virtual Error_manager communication_run();
  56. //反初始化 通信 模块。
  57. virtual Error_manager communication_uninit();
  58. public://get or set member variable
  59. void set_analysis_cycle_time(unsigned int analysis_cycle_time);
  60. void set_encapsulate_cycle_time(unsigned int encapsulate_cycle_time);
  61. protected:
  62. //mp_receive_data_thread 接受线程执行函数,
  63. //receive_data_thread 内部线程负责接受消息
  64. void receive_data_thread();
  65. //检查消息是否有效, 主要检查消息类型和接受者, 判断这条消息是不是给我的.
  66. virtual Error_manager check_msg(Communication_message* p_msg);
  67. //mp_analysis_data_thread 解析线程执行函数,
  68. //analysis_data_thread 内部线程负责解析消息
  69. void analysis_data_thread();
  70. //遍历接受链表, 解析消息,
  71. Error_manager analysis_receive_list();
  72. //检查执行者的状态, 判断能否处理这条消息, 需要子类重载
  73. virtual Error_manager check_executer(Communication_message* p_msg);
  74. //处理消息, 需要子类重载
  75. virtual Error_manager execute_msg(Communication_message* p_msg);
  76. //mp_send_data_thread 发送线程执行函数,
  77. //send_data_thread 内部线程负责发送消息
  78. void send_data_thread();
  79. //mp_encapsulate_data_thread 封装线程执行函数,
  80. //encapsulate_data_thread 内部线程负责封装消息
  81. void encapsulate_data_thread();
  82. //定时封装发送消息, 一般为心跳和状态信息, 需要子类重载
  83. virtual Error_manager encapsulate_send_data();
  84. public:
  85. //封装消息, 需要子类重载
  86. virtual Error_manager encapsulate_msg(std::string message);
  87. //封装消息, 需要子类重载
  88. virtual Error_manager encapsulate_msg(Communication_message* p_msg);
  89. protected://member variable
  90. //通用的网络编程接口, 默认使用总线模式, (网状结构)
  91. nnxx::socket m_socket { nnxx::SP, nnxx::BUS };
  92. std::mutex m_mutex; //m_socket的锁
  93. //通信状态
  94. Communication_statu m_communication_statu; //通信状态
  95. //接受模块,
  96. Thread_safe_list<Communication_message*> m_receive_data_list; //接受的list容器
  97. std::thread* mp_receive_data_thread; //接受的线程指针
  98. Thread_condition m_receive_condition; //接受的条件变量
  99. std::thread* mp_analysis_data_thread; //解析的线程指针
  100. Thread_condition m_analysis_data_condition; //解析的条件变量
  101. unsigned int m_analysis_cycle_time; //自动解析的时间周期
  102. //发送模块,
  103. Thread_safe_list<Communication_message*> m_send_data_list; //发送的list容器
  104. std::thread* mp_send_data_thread; //发送的线程指针
  105. Thread_condition m_send_data_condition; //发送的条件变量
  106. std::thread* mp_encapsulate_data_thread; //封装的线程指针
  107. Thread_condition m_encapsulate_data_condition; //封装的条件变量
  108. unsigned int m_encapsulate_cycle_time; //自动封装的时间周期
  109. private:
  110. };
  111. #endif //__COMMUNICATION_SOCKET_BASE__HH__