unique numbers : Java Glossary

unique numbers
A common problem in data processing is to assign unique numbers to things, people, parts, packages, accounts, programs, versions…

The traditional way to handle it is to have a central database the assigns numbers and increments a counter. The problem with is the central database may be inaccessible. Further the central database becomes a crucial bottleneck.

You can also have an in-ram unique number server with a thread safe access.

I suggest a partially decentralised variant in my Unique Number Server Student Project.

Another way to do it is to use large pseudorandom numbers and count on the improbability of two numbers being picked the same. This technique is fully decentralised approach. No communication between number assigners is needed. This is how java.util. UUID (Universally Unique Identifier) works.

Ticket Numbers

Let’s say you needed to assign ticket numbers. The easiest way is to have a central counter you increment to serve ascending integers. If you want a discourage counterfeiting ticket numbers, other than my making duplicates of actual tickets, you need to make the set of number you use sparce, so if someone randomly picks a number it will be an invalid number. You want a simple mathematical way of knowing if a number is valid.

There are two simple algorithms.

Learning More

Oracle’s Javadoc on UUID class : available:

CMP homejump to top You can get the freshest copy of this page from: or possibly from your local J: drive (Java virtual drive/mindprod.com website mirror)
http://mindprod.com/jgloss/unique.html J:\mindprod\jgloss\unique.html
logo
Please email your , letters to the editor, errors, omissions, typos, formatting errors, ambiguities, unclear wording, broken/redirected link reports, suggestions to improve this page or comments to Roedy Green : feedback email. If you want your message, your name or email kept confidential, not considered for public posting, please explicitly specify that. Unless you state otherwise, I will treat your message as a letter to the editor that I may or may not publish in the feedback section. After that, it will be too late to retract it. If you disagree with something I said, please quote it and cite the web page where you found it, tell me why you think it is wrong, and, if possible, provide some supporting evidence. Threatening to kill me or spouting obscenities has yet to persuade me to change my mind.
mindprod.com IP:[65.110.21.43]
view BlogYour face IP:[38.107.179.211]
You are visitor number 8,806.