001 /* 002 * Copyright (C) 2007 Google Inc. 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except 005 * in compliance with the License. You may obtain a copy of the License at 006 * 007 * http://www.apache.org/licenses/LICENSE-2.0 008 * 009 * Unless required by applicable law or agreed to in writing, software distributed under the License 010 * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express 011 * or implied. See the License for the specific language governing permissions and limitations under 012 * the License. 013 */ 014 015 package com.google.common.base; 016 017 import java.util.HashMap; 018 import java.util.Map; 019 020 /** 021 * This class provides default values for all Java types, as defined by the JLS. 022 * 023 * @author Ben Yu 024 */ 025 public final class Defaults { 026 private Defaults() {} 027 028 private static final Map<Class<?>, Object> DEFAULTS = new HashMap<Class<?>, Object>(16); 029 030 private static <T> void put(Class<T> type, T value) { 031 DEFAULTS.put(type, value); 032 } 033 034 static { 035 put(boolean.class, false); 036 put(char.class, '\0'); 037 put(byte.class, (byte) 0); 038 put(short.class, (short) 0); 039 put(int.class, 0); 040 put(long.class, 0L); 041 put(float.class, 0f); 042 put(double.class, 0d); 043 } 044 045 /** 046 * Returns the default value of {@code type} as defined by JLS --- {@code 0} for numbers, {@code 047 * false} for {@code boolean} and {@code '\0'} for {@code char}. For non-primitive types and 048 * {@code void}, null is returned. 049 */ 050 @SuppressWarnings("unchecked") 051 public static <T> T defaultValue(Class<T> type) { 052 return (T) DEFAULTS.get(type); 053 } 054 }