class Node {
unsigned int id_; // node id - 160 bits
RoutingTable table; // node routing table
+ unsigned int find_node_success = 0; // Number of find_node which have succeeded.
+ unsigned int find_node_failed = 0; // Number of find_node which have failed.
public:
simgrid::s4u::CommPtr receive_comm = nullptr;
void* received_msg = nullptr;
- unsigned int find_node_success = 0; // Number of find_node which have succeeded.
- unsigned int find_node_failed = 0; // Number of find_node which have failed.
explicit Node(unsigned int node_id) : id_(node_id), table(node_id) {}
Node(const Node&) = delete;
Node& operator=(const Node&) = delete;
- unsigned int getId() { return id_; }
+ unsigned int getId() const { return id_; }
bool join(unsigned int known_id);
- void sendFindNode(unsigned int id, unsigned int destination);
- unsigned int sendFindNodeToBest(const Answer* node_list);
+ void sendFindNode(unsigned int id, unsigned int destination) const;
+ unsigned int sendFindNodeToBest(const Answer* node_list) const;
void routingTableUpdate(unsigned int id);
Answer* findClosest(unsigned int destination_id);
bool findNode(unsigned int id_to_find, bool count_in_stats);
void randomLookup();
void handleFindNode(const Message* msg);
+ void displaySuccessRate() const;
};
-}
+} // namespace kademlia
// identifier functions
unsigned int get_id_in_prefix(unsigned int id, unsigned int prefix);
unsigned int get_node_prefix(unsigned int id, unsigned int nb_bits);