From 6bd335c7382c0da8486e94d253dffa28525ceec7 Mon Sep 17 00:00:00 2001 From: Sam Anthony Date: Mon, 18 Nov 2024 10:35:22 -0500 Subject: reliable multicast: avoid receiving duplicate messages --- src/main/java/derms/net/rmulticast/Message.java | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'src/main/java/derms/net/rmulticast/Message.java') diff --git a/src/main/java/derms/net/rmulticast/Message.java b/src/main/java/derms/net/rmulticast/Message.java index 329b62c..b4749a3 100644 --- a/src/main/java/derms/net/rmulticast/Message.java +++ b/src/main/java/derms/net/rmulticast/Message.java @@ -4,7 +4,12 @@ import java.io.Serializable; import java.net.InetAddress; class Message implements Serializable { + /* Used as a salt in the hash function. Allows different messages to have + * different IDs, even if they have the same payload. */ + private static int seq = 1; + T payload; + int salt; // Used in hash function. Allows messages to have unique IDs, even if they have the same payload. InetAddress sender; MessageID[] acks; // IDs of messages that this message positively acknowledges. MessageID[] nacks; // IDs of messages that this message negatively acknowledges. @@ -15,6 +20,7 @@ class Message implements Serializable { */ Message(T payload, InetAddress sender, MessageID[] acks, MessageID[] nacks) { this.payload = payload; + this.salt = seq++; this.sender = sender; this.acks = acks; this.nacks = nacks; @@ -26,7 +32,7 @@ class Message implements Serializable { @Override public int hashCode() { - return payload.hash(); + return payload.hash() * salt; } @Override -- cgit v1.2.3