All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.ibm.as400.access.DBStoragePool Maven / Gradle / Ivy

There is a newer version: 20.0.7
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                                 
//                                                                             
// Filename: DBStoragePool.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2001 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.lang.ref.SoftReference;

//@P0D import java.util.BitSet;
//@P0D import java.util.Vector;



/**

This class manages a pool of large byte arrays for use in creating request datastreams. This enables reduction in the number of allocations and the amount of synchronization involved in sending request datastreams. **/ class DBStoragePool { static final String copyright = "Copyright (C) 1997-2001 International Business Machines Corporation and others."; static final int MAX_POOL_INCREMENT = 4096; //@B5A private static final int STORAGE_POOL_LOCALITY = 256; //@B5A //@P0D private int count_; //@P0D private BitSet lockState_; //@P0D private Vector pool_; // // Use soft references to avoid running the JVM out of memory // private SoftReference[] pool_ = new SoftReference[16]; //@P0A private int lastReturned_; // @B5A private int searches_ = 0; // @B5A /** Constructs a DBStoragePool object. **/ //@P0D DBStoragePool () //@P0D { //@P0D count_ = 0; // The initial capacity is 128. This is pretty // large and would only be hit if we had 128 data // streams being created at the same time. Even // if this does happen (an extremely stressed // scenario), the resizing should not happen too // often. //@P0D lockState_ = new BitSet (128); //@P0D pool_ = new Vector (128, 128); //@P0D } int getSize() { return pool_.length; } // @B5A /** Frees a DBStorage object for reuse. @param a DBStorage object. **/ //@P0D synchronized void freeStorage (DBStorage storage) // @B1C //@P0D { //@P0D lockState_.clear (storage.getId ()); //@P0D } /** Returns an unused DBStorage object. @return a DBStorage object. **/ final synchronized DBStorage getUnpooledStorage() { DBStorage storage = new DBStorage(-1, this); storage.canUse(); return storage; } //@B5A /** Returns an unused, pre-allocated DBStorage object. If none are available, a brand new one will be allocated. @return a DBStorage object. **/ // // Note: This method must be synchronized to make it // threadsafe. // final synchronized DBStorage getUnusedStorage() // @B0C @B1C @P0C { //@P0D DBStorage storage; int max = pool_.length; //@P0A // Start the search at the last returned location @B5A int searchStart = lastReturned_; searches_++; if (searches_ > MAX_POOL_INCREMENT) { searchStart = 0; searches_ = 0; } // Find an unused storage object. for (int i=searchStart; i MAX_POOL_INCREMENT) increment = MAX_POOL_INCREMENT; // @B5A SoftReference[] tempPool = new SoftReference[max+increment]; //@P0A@B5C for (int i=0; i= (lastReturned_ - STORAGE_POOL_LOCALITY))) { lastReturned_ = id_; } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy