ByteXiaoTang
ByteXiaoTang
data:image/s3,"s3://crabby-images/06f53/06f531f181d052e25aa61d20c890f22d1ba374d0" alt="image" i may not understand why _unicast_flag is false, then send_unicast_offer_service.
data:image/s3,"s3://crabby-images/c5342/c5342d4b369ccf7d0b8c290a43abbee8921d054e" alt="image" suggest not use condition_variable wait_for which will affect by system time change
data:image/s3,"s3://crabby-images/286b0/286b08c0b1aca85cb9ebf25af1d74447a0514bf7" alt="image" found_service_msg should change to false when find one
in sd, check_ipv4_address function, two static should be removed. data:image/s3,"s3://crabby-images/ac85b/ac85b23883cd8f13f1707d63b91816f6413f5b64" alt="image" because i meet one problem. although i can not understand why. data:image/s3,"s3://crabby-images/88ab8/88ab8799a291e5e126523a478bbfce1cce7319c2" alt="image"
data:image/s3,"s3://crabby-images/59dbb/59dbb79ff2bd952868d5cb54e285565e8fe8c6d9" alt="image" here, we get port error, but we still use its_value, the value we may not expect.
Fdubs跨域是点对点服务通信,中间的nameserver只做了服务发现。缺陷在于服务太多时,通信效率会降低,尤其是在服务提供者提供服务,订阅者偏多时。这就是服务网关存在的意义。 对比vsomeip,跨域通信都经过stub中转,订阅单位基于ip, 订阅量会大幅降低,配合field机制,通信量会少许多。虽然链路好像会长一点。 但经过比对测试,在5ms通信以下级别,fdbus通信负载比vsomeip负载大的多。
the CBaseLoopTimer may has problem. 程序有需求,消息来时创建timer指针,得到回复之后就delete指针。 这样来回new和delete大概几百次之后,就会引起程序cordump.
data:image/s3,"s3://crabby-images/ea367/ea3676c03879fdc8713e4ece57f0fb33380fc1ee" alt="image" data:image/s3,"s3://crabby-images/c6efb/c6efb860eb0a9be0d704a1af03bf2538a6130cb7" alt="image" use condition_variable which use steady time also may affect by system time change
msg_ref为智能指针,但是被捕获切换线程处理,好像已经被删除,为空。 后来只能如下处理,将其中的值先取出,赋给buffer CBaseMessage *msg = castToMessage(msg_ref); if (nullptr != msg) { std::shared_ptr buffer(std::make_shared()); buffer->assign((char *)(msg->getPayloadBuffer()), msg->getPayloadSize()); int32_t code = msg->code(); } });
sem_timedwait use CLOCK_REALTIME time, which may change when system time change. so timewait will have problem.