task_base.h 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. /*
  2. * Task_Base 是任务基类,用作不同的模块之间的通信载体。
  3. * 每一个模块创建一个任务子类,从Task_Base继承。
  4. * 然后任务子类自定义一些数据和读写数据的接口函数。
  5. * 然后在任务接受方实现 execute_task(Task_Base* p_laser_task)
  6. * */
  7. #ifndef TASK_BASE_H
  8. #define TASK_BASE_H
  9. #include <string>
  10. #include "../error_code/error_code.h"
  11. #include <chrono>
  12. //任务超时时间默认值10000ms,10秒
  13. #define TASK_OVER_TIME_DEFAULT 10000
  14. //任务类型
  15. enum Task_type
  16. {
  17. UNKNOW_TASK =0, //未知任务单//初始化,默认值
  18. LASER_MANGER_SCAN_TASK =1, //雷达管理模块的扫描任务,
  19. LASER_BASE_SCAN_TASK =2, //单个雷达的扫描任务,
  20. LOCATE_MANGER_TASK =3, //测量任务
  21. PLC_TASK =4, //上传PLC任务
  22. WJ_TASK,
  23. };
  24. //任务状态,如果任务故障,任务状态改为TASK_OVER,然后在m_task_error_manager 补充错误码。
  25. enum Task_statu
  26. {
  27. TASK_CREATED =0, //创建状态,默认值
  28. TASK_SIGNED =1, //已签收
  29. TASK_WORKING =2, //处理中
  30. TASK_OVER =3, //已结束
  31. TASK_ERROR =11, //任务错误
  32. //前面的状态由接收方选择, TASK_DEAD 则是发送方选择.
  33. TASK_DEAD =12, //当任务超时,发送方让任务死亡,
  34. };
  35. //任务单基类
  36. class Task_Base
  37. {
  38. protected:
  39. //不允许构造基类,只允许子类构造,(多态)
  40. Task_Base();
  41. public:
  42. ~Task_Base();
  43. //更新任务单
  44. //task_statu: 任务状态
  45. //statu_information:状态说明
  46. Error_manager update_statu(Task_statu task_statu,std::string statu_information="");
  47. //判断是否超时。返回true表示任务超时,返回false表示任务没有超时
  48. bool is_over_time();
  49. //判断是否结束, TASK_OVER TASK_ERROR TASK_DEAD 都算结束
  50. bool is_task_end();
  51. public:
  52. //获取 任务单id
  53. unsigned int get_task_id();
  54. //设置 任务单id
  55. // void set_task_id(unsigned int task_id) = delete;
  56. //获取 任务类型
  57. Task_type get_task_type();
  58. //设置 任务类型
  59. // void set_task_type(Task_type task_type) = delete;
  60. //获取 任务单状态
  61. Task_statu get_task_statu();
  62. //设置 任务单状态
  63. void set_task_statu(Task_statu task_statu);
  64. //获取 状态说明
  65. std::string get_task_statu_information();
  66. //设置 状态说明
  67. void set_task_statu_information(std::string task_statu_information);
  68. //获取 错误码,返回引用。
  69. Error_manager& get_task_error_manager();
  70. //设置 错误码
  71. void set_task_error_manager(Error_manager & error_manager);
  72. //比较覆盖错误码
  73. void compare_and_cover_task_error_manager(Error_manager & error_manager);
  74. //获取任务接收方
  75. void * get_tast_receiver();
  76. //设置任务接收方
  77. void set_tast_receiver(void * p_tast_receiver);
  78. //获取 任务创建的时间点
  79. std::chrono::system_clock::time_point get_task_start_time();
  80. //设置 任务创建的时间点
  81. void set_task_start_time(std::chrono::system_clock::time_point task_start_time);
  82. //获取 任务超时的时限
  83. std::chrono::milliseconds get_task_over_time();
  84. //设置 任务超时的时限
  85. void get_task_over_time(std::chrono::milliseconds task_over_time);
  86. protected:
  87. unsigned int m_task_id; //任务id, 每次新建任务, 自动+1, 用于多任务的管理
  88. Task_type m_task_type; //任务类型,不允许中途修改
  89. Task_statu m_task_statu; //任务状态
  90. std::string m_task_statu_information; //任务状态说明
  91. void* mp_tast_receiver; //任务接收方,Task_Base并不分配和释放内存。
  92. //注:mp_tast_receiver是可选的,可以为NULL。如果为NULL,则需要task_command_manager去找到接收对象。
  93. std::chrono::system_clock::time_point m_task_start_time; //任务创建的时间点
  94. std::chrono::milliseconds m_task_over_time; //任务超时的时限
  95. //注:std::chrono::system_clock::now(); //获取当前时间
  96. //错误码,任务故障信息,任务输出
  97. Error_manager m_task_error_manager;
  98. };
  99. #endif //TASK_BASE_H