Joe Soltzberg

56%
Flag icon
With the new constructor in place, the previous attack will have no effect on the Period instance. Note that defensive copies are made before checking the validity of the parameters (Item 49), and the validity check is performed on the copies rather than on the originals. While this may seem unnatural, it is necessary. It protects the class against changes to the parameters from another thread during the window of vulnerability between the time the parameters are checked and the time they are copied. In the computer security community, this is known as a time-of-check/time-of-use or TOCTOU ...more
Joe Soltzberg
Also the validity check could have side-effects itself
Effective Java
Rate this book
Clear rating
Open Preview