/* * Copyright (c) 1998, 2002, Oracle and/or its affiliates. All rights reserved. * ORACLE PROPRIETARY/CONFIDENTIAL. Use is subject to license terms. * * * * * * * * * * * * * * * * * * * * */ /* * Licensed Materials - Property of IBM * RMI-IIOP v1.0 * Copyright IBM Corp. 1998 1999 All Rights Reserved * */ package com.sun.corba.se.impl.util; import java.util.Stack; import java.util.Hashtable; import java.util.EmptyStackException; import java.util.Enumeration; // Really limited pool - in this case just creating several at a time... class RepositoryIdPool extends Stack { private static int MAX_CACHE_SIZE = 4; private RepositoryIdCache cache; public final synchronized RepositoryId popId() { try { return (RepositoryId)super.pop(); } catch(EmptyStackException e) { increasePool(5); return (RepositoryId)super.pop(); } } // Pool management final void increasePool(int size) { //if (cache.size() <= MAX_CACHE_SIZE) for (int i = size; i > 0; i--) push(new RepositoryId()); /* // _REVISIT_ This will not work w/out either thread tracing or weak references. I am // betting that thread tracing almost completely negates benefit of reuse. Until either // 1.2 only inclusion or proof to the contrary, I'll leave it this way... else { int numToReclaim = cache.size() / 2; Enumeration keys = cache.keys(); Enumeration elements = cache.elements(); for (int i = numToReclaim; i > 0; i--) { Object key = keys.nextElement(); Object element = elements.nextElement(); push(element); cache.remove(key); } } */ } final void setCaches(RepositoryIdCache cache) { this.cache = cache; } } public class RepositoryIdCache extends Hashtable { private RepositoryIdPool pool = new RepositoryIdPool(); public RepositoryIdCache() { pool.setCaches(this); } public final synchronized RepositoryId getId(String key) { RepositoryId repId = (RepositoryId)super.get(key); if (repId != null) return repId; else { //repId = pool.popId().init(key); repId = new RepositoryId(key); put(key, repId); return repId; } } }