/******************************************************************************* * ============LICENSE_START==================================================== * * org.onap.aaf * * =========================================================================== * * Copyright © 2017 AT&T Intellectual Property. 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. * * ============LICENSE_END==================================================== * * * * ECOMP is a trademark and service mark of AT&T Intellectual Property. * * ******************************************************************************/ package com.att.inno.env.util; import java.lang.reflect.Constructor; import java.lang.reflect.InvocationTargetException; import java.util.Collections; import java.util.HashMap; import java.util.Map; import com.att.inno.env.APIException; import com.att.inno.env.Creatable; import com.att.inno.env.Env; import com.att.inno.env.LifeCycle; /** *
* * In addition to the Thread instance semantics, it compares when the object * was created versus the last "refresh(env)" call when getting, for the * thread, and if necessary to replace the created object, destroying the * previous.
* * In most cases, it's better to use the new "Pool" mechanism, as it deals with * gaining and returning resources on an as needed basis. This, however, remains * in the cases where specific Objects need to be retained to specific Threads.
*
* There is no way to do this kind of specialized behavior in ThreadLocal.
*
*
* @param
* public MyClass(Env env) {
* ...
* }
*
* @param clss
* @throws APIException
*/
public RefreshableThreadObject(Class