-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Open
Labels
Description
Code Path: confignode/src/main/java/org/apache/iotdb/confignode/manager/PartitionManager.java

Creating a new Random object each time a random value is needed is inefficient and may produce numbers which are not random depending on the JDK. For better efficiency and randomness, create a single Random, then store, and reuse it.
The Random() constructor tries to set the seed with a distinct value every time. However there is no guarantee that the seed will be random or even uniformly distributed. Some JDK will use the current time as seed, which makes the generated numbers not random at all.
This rule finds cases where a new Random is created each time a method is invoked.