Uma instância desta classe é usada para gerar um fluxo de números pseudo-aleatórios. A classe usa uma semente de 48 bits, que é modificada usando uma fórmula congruencial linear. (Veja Donald Knuth, A Arte da Programação por Computador, Volume 2, Seção 3.2.1.)
Se duas instâncias de Random forem criadas com a mesma semente e a mesma sequência de chamadas de método for feita para cada uma, elas gerarão e retornarão sequências idênticas de números.
Para garantir essa propriedade, algoritmos específicos são especificados para a classe Random. As implementações de Java devem usar todos os algoritmos mostrados aqui para a classe Random, por uma questão de portabilidade absoluta do código Java.
No entanto, subclasses da classe Random podem usar outros algoritmos, desde que sigam os contratos gerais de todos os métodos.
Os algoritmos implementados pela classe Random usam um método utilitário protegido que em cada invocação pode fornecer até 32 bits gerados pseudo-aleatoriamente.
Muitos aplicativos acharão o método Math.random () mais simples de usar.
Instâncias de java.util.Random são thread-safe. No entanto, o uso simultâneo da mesma instância java.util.Random entre threads pode encontrar contenção e consequente baixo desempenho. Em vez disso, considere usar ThreadLocalRandom em designs multithread.
Instâncias de java.util.Random não são criptograficamente seguras. Em vez disso, considere usar o SecureRandom para obter um gerador de números pseudo-aleatórios criptograficamente seguro para uso por aplicativos sensíveis à segurança.
Essa classe existe desde a versão 1 do Java.
Fonte: https://docs.oracle.com/en/java/javase/14/docs/api/java.base/java/util/Random.html
Deixe um comentário