private int sizeOfBin(Transaction tx, int index) throws IOException { return getBin(tx, index).size(); }
synchronized public Value put(Transaction tx, Key key, Value value) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.put(key,value); store(tx, bin); int newSize = bin.size(); if (newSize != originalSize) { metadata.size++; if (newSize == 1) { metadata.binsActive++; } } if (metadata.binsActive >= this.increaseThreshold) { newSize = Math.min(maximumBinCapacity, metadata.binCapacity*2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
synchronized public Value remove(Transaction tx, Key key) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.remove(key); int newSize = bin.size(); if (newSize != originalSize) { store(tx, bin); metadata.size--; if (newSize == 0) { metadata.binsActive--; } } if (metadata.binsActive <= this.decreaseThreshold) { newSize = Math.max(minimumBinCapacity, metadata.binCapacity/2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
resizeBin.put(entry.getKey(), entry.getValue()); store(tx, resizeBin); if( resizeBin.size() == 1) { metadata.binsActive++;
private int sizeOfBin(Transaction tx, int index) throws IOException { return getBin(tx, index).size(); }
private int sizeOfBin(Transaction tx, int index) throws IOException { return getBin(tx, index).size(); }
private int sizeOfBin(Transaction tx, int index) throws IOException { return getBin(tx, index).size(); }
synchronized public Value remove(Transaction tx, Key key) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.remove(key); int newSize = bin.size(); if (newSize != originalSize) { store(tx, bin); metadata.size--; if (newSize == 0) { metadata.binsActive--; } } if (metadata.binsActive <= this.decreaseThreshold) { newSize = Math.max(minimumBinCapacity, metadata.binCapacity/2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
synchronized public Value put(Transaction tx, Key key, Value value) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.put(key,value); store(tx, bin); int newSize = bin.size(); if (newSize != originalSize) { metadata.size++; if (newSize == 1) { metadata.binsActive++; } } if (metadata.binsActive >= this.increaseThreshold) { newSize = Math.min(maximumBinCapacity, metadata.binCapacity*2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
synchronized public Value remove(Transaction tx, Key key) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.remove(key); int newSize = bin.size(); if (newSize != originalSize) { store(tx, bin); metadata.size--; if (newSize == 0) { metadata.binsActive--; } } if (metadata.binsActive <= this.decreaseThreshold) { newSize = Math.max(minimumBinCapacity, metadata.binCapacity/2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
synchronized public Value put(Transaction tx, Key key, Value value) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.put(key,value); store(tx, bin); int newSize = bin.size(); if (newSize != originalSize) { metadata.size++; if (newSize == 1) { metadata.binsActive++; } } if (metadata.binsActive >= this.increaseThreshold) { newSize = Math.min(maximumBinCapacity, metadata.binCapacity*2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
synchronized public Value put(Transaction tx, Key key, Value value) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.put(key,value); store(tx, bin); int newSize = bin.size(); if (newSize != originalSize) { metadata.size++; if (newSize == 1) { metadata.binsActive++; } } if (metadata.binsActive >= this.increaseThreshold) { newSize = Math.min(maximumBinCapacity, metadata.binCapacity*2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
synchronized public Value remove(Transaction tx, Key key) throws IOException { assertLoaded(); HashBin<Key,Value> bin = getBin(tx, key); int originalSize = bin.size(); Value result = bin.remove(key); int newSize = bin.size(); if (newSize != originalSize) { store(tx, bin); metadata.size--; if (newSize == 0) { metadata.binsActive--; } } if (metadata.binsActive <= this.decreaseThreshold) { newSize = Math.max(minimumBinCapacity, metadata.binCapacity/2); if(metadata.binCapacity!=newSize) { resize(tx, newSize); } } return result; }
resizeBin.put(entry.getKey(), entry.getValue()); store(tx, resizeBin); if( resizeBin.size() == 1) { metadata.binsActive++;
resizeBin.put(entry.getKey(), entry.getValue()); store(tx, resizeBin); if( resizeBin.size() == 1) { metadata.binsActive++;
resizeBin.put(entry.getKey(), entry.getValue()); store(tx, resizeBin); if( resizeBin.size() == 1) { metadata.binsActive++;