.plugins.json-stream.3.0.1.source-code.LazyTemplate.txt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of json-stream Show documentation
Show all versions of json-stream Show documentation
This plugin allows you to easily convert Speedment entities into JSON.
/**
*
* Copyright (c) 2006-2016, Speedment, Inc. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License"); You may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.speedment.common.lazy.specialized;
{$1}
import static java.util.Objects.requireNonNull;
import java.util.function.Supplier;
/**
* Generic lazy initialization class. The supplier must produce a non-null
* value.
*
* This class is thread safe. The Supplier is guaranteed to be called exactly
* one time following one or several calls to
* {@link #getOrCompute(java.util.function.Supplier) } by any number of
* threads.
*
* @author Per Minborg
*/
public final class Lazy{$0} {
private volatile {$0} value;
private Lazy{$0}() {
}
public {$0} getOrCompute(Supplier<{$0}> supplier) {
// With this local variable, we only need to do one volatile read
final {$0} result = value;
return result == null ? maybeCompute(supplier) : result;
}
private synchronized {$0} maybeCompute(Supplier<{$0}> supplier) {
if (value == null) {
value = requireNonNull(supplier.get());
}
return value;
}
public static Lazy{$0} create() {
return new Lazy{$0}();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy