org.hibernate.stat.ConcurrentCollectionStatisticsImpl Maven / Gradle / Ivy
package org.hibernate.stat;
import java.util.concurrent.atomic.AtomicLong;
/**
* Collection related statistics
*
* @author Alex Snaps
*/
public class ConcurrentCollectionStatisticsImpl extends CategorizedStatistics implements CollectionStatistics {
ConcurrentCollectionStatisticsImpl(String role) {
super(role);
}
private AtomicLong loadCount = new AtomicLong();
private AtomicLong fetchCount = new AtomicLong();
private AtomicLong updateCount = new AtomicLong();
private AtomicLong removeCount = new AtomicLong();
private AtomicLong recreateCount = new AtomicLong();
public long getLoadCount() {
return loadCount.get();
}
public long getFetchCount() {
return fetchCount.get();
}
public long getRecreateCount() {
return recreateCount.get();
}
public long getRemoveCount() {
return removeCount.get();
}
public long getUpdateCount() {
return updateCount.get();
}
public String toString() {
return new StringBuilder()
.append("CollectionStatistics")
.append("[loadCount=").append(this.loadCount)
.append(",fetchCount=").append(this.fetchCount)
.append(",recreateCount=").append(this.recreateCount)
.append(",removeCount=").append(this.removeCount)
.append(",updateCount=").append(this.updateCount)
.append(']')
.toString();
}
void incrementLoadCount() {
loadCount.getAndIncrement();
}
void incrementFetchCount() {
fetchCount.getAndIncrement();
}
void incrementUpdateCount() {
updateCount.getAndIncrement();
}
void incrementRecreateCount() {
recreateCount.getAndIncrement();
}
void incrementRemoveCount() {
removeCount.getAndIncrement();
}
}