/* * Copyright 2023-2024 the original author or authors. * * 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 * * https://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 xyz.zhouxy.plusone.commons.util; import java.util.Optional; import java.util.OptionalDouble; import java.util.OptionalInt; import java.util.OptionalLong; import javax.annotation.Nullable; import com.google.common.annotations.Beta; /** * OptionalTools * *
* 提供一些 Optional 相关的方法 * * @author ZhouXY * @since 1.0.0 * @see Optional * @see OptionalInt * @see OptionalLong * @see OptionalDouble */ public class OptionalTools { /** * 将包装类 {@link Integer} 转为 {@link OptionalInt}(not null)。 *
* 包装类为 {@code null} 表示值的缺失,转为 {@link OptionalInt} 后,由 * {@link OptionalInt#empty()} 表示值的缺失。 *
* * @param value 包装对象 * @return {@link OptionalInt} 实例 */ public static OptionalInt optionalOf(@Nullable Integer value) { return value != null ? OptionalInt.of(value) : OptionalInt.empty(); } /** * 将 {@code Optional
* {@code Optional
* 包装类为 {@code null} 表示值的缺失,转为 {@link OptionalLong} 后,由 * {@link OptionalLong#empty()} 表示值的缺失。 *
* * @param value 包装对象 * @return {@link OptionalLong} 实例 */ public static OptionalLong optionalOf(@Nullable Long value) { return value != null ? OptionalLong.of(value) : OptionalLong.empty(); } /** * 将 {@code Optional
* {@code Optional
* 包装类为 {@code null} 表示值的缺失,转为 {@link OptionalDouble} 后,由 * {@link OptionalDouble#empty()} 表示值的缺失。 *
* * @param value 包装对象 * @return {@link OptionalDouble} 实例 */ public static OptionalDouble optionalOf(@Nullable Double value) { return value != null ? OptionalDouble.of(value) : OptionalDouble.empty(); } /** * 将 {@code Optional
* {@code Optional