Lazily check for root, avoids unnecessary errors & resources
Motivation: io.netty.util.internal.PlatformDependent.isRoot() depends on the IS_ROOT field which is filled in during class initialization. This spawns processes and consumes resources, which are not generally necessary to the complete functioning of that class. Modifications: This switches the class to use lazy initialization this field inside of the isRoot() method using double-checked locking (http://en.wikipedia.org/wiki/Double-checked_locking). Result: The first call to isRoot() will be slightly slower, at a tradeoff that class loading is faster, uses fewer resources and platform errors are avoided unless necessary.
This commit is contained in:
parent
4e09c305ab
commit
47319d3cfc
@ -60,7 +60,7 @@ public final class PlatformDependent {
|
||||
|
||||
private static final boolean IS_ANDROID = isAndroid0();
|
||||
private static final boolean IS_WINDOWS = isWindows0();
|
||||
private static final boolean IS_ROOT = isRoot0();
|
||||
private static volatile Boolean IS_ROOT;
|
||||
|
||||
private static final int JAVA_VERSION = javaVersion0();
|
||||
|
||||
@ -114,6 +114,13 @@ public final class PlatformDependent {
|
||||
* {@code false} if on Windows.
|
||||
*/
|
||||
public static boolean isRoot() {
|
||||
if (IS_ROOT == null) {
|
||||
synchronized (PlatformDependent.class) {
|
||||
if (IS_ROOT == null) {
|
||||
IS_ROOT = isRoot0();
|
||||
}
|
||||
}
|
||||
}
|
||||
return IS_ROOT;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user