我必须在 Java 中生成一个唯一编号(对于我运行代码的机器),以便在 C++ 中它可以对应于uint32_t
. 一般来说,其他 C++ 程序应该能够正确地读取这个唯一的数字作为uint32_t
. 我在一个字节数组中发送这个信息,其他 C++ 程序正在反序列化它以获得这个数字。到目前为止,我无法在 C++ 程序中更改此数字的数据类型。
private static final AtomicInteger clientId = new AtomicInteger(0);
// will be called many time when the program is running after initialization
public static int getClientId() {
int counter = clientId.incrementAndGet();
return counter == Integer.MAX_VALUE ? 0 : counter;
}
// called only once at startup
public static void setClientId(final int counter) {
clientId.addAndGet(counter == Integer.MAX_VALUE ? 0 : counter);
}
所以我想出了上面的代码。在应用程序启动(初始化阶段)期间,我的setClientId
方法只会被调用一次:
- 如果这台机器是第一次运行代码,就像它是一台新机器,那么我将传递
0
给setClientId
方法。 - 如果这台机器已经在运行代码但我们重新启动了服务器,那么我将在数据库中查找这台机器最后保存的值是什么(因为我们也每隔几分钟将这个值保存在 db 中),然后我将传递它方法的价值
setClientId
。
然后稍后当我的程序运行时(在初始化之后),它将继续调用getClientId
方法来给我实际的唯一 clientId。
这是为我的机器生成uint32_t
用于 C++ 程序的唯一 ID 的正确方法吗?我还确保如果值达到Integer.MAX_VALUE
然后将其设置为 0 并重新开始。我必须这样做吗?或者我也可以为此取负值uint32_t
?
基本上,我想为我的机器生成一个唯一编号,该编号应始终对应于uint32_t
. 如果机器是新机器,我们可以从数字 0 开始(bcoz 当我们在数据库中查找这台机器的值时,不会有任何值,所以我们将从 0 开始)但是如果机器之前已经运行过这段代码,然后从数据库中最后保存的值开始。