Posts

Showing posts from April, 2017

The WeakReference class, monitoring memory leak and garbage collection in a Java application

Image
 Below is a Stack implementation that uses an internal resizeable array structure.  public class MyStack< T > implements Stack< T > { private static final int CAPACITY = 100 ; private Object[] array ; private int pos = 0 ; public MyStack () { this . array = new Object[ CAPACITY ] ; } @Override public void push ( T item) { if ( pos >= array . length / 2 ) { Object[] newArray = new Object[ pos * 2 ] ; System. arraycopy ( array , 0 , newArray , 0 , array . length ) ; array = newArray ; } array [ pos ++] = item ; } @Override public T pop () { if (isEmpty()) { throw new RuntimeException( "empty stack" ) ; } @SuppressWarnings ( "unchecked" ) T item = ( T ) array [ pos - 1 ] ; pos -= 1 ; return item ; } @Override @SuppressWarnings ( "unchecked" ) public T peek...

SimpleScalar Simulator - Part 3

Problem: Can you detect when current page is left for the instruction stream? Inside cache.c we know if the hit is fast (same block) or slow. /*cache.c  line 533*/ printf("Cache tagset: %d  Last tagset: %d\n", CACHE_TAGSET(cp, addr), cp->last_tagset);   /* check for a fast hit: access to same block */   if (CACHE_TAGSET(cp, addr) == cp->last_tagset)     {       printf("Same block hit!\n");       /* hit in the same block */       blk = cp->last_blk;       goto cache_fast_hit;     } printf("Slow hit or miss!\n"); Before cache access, we control the nature of the access and set the iTLB power mode:           if (itlb)   {    if (CACHE_TAGSET(itlb, IACOMPRESS(fetch_regs_PC)) == itlb->last_tagset) {        low_power = 1;        ++low_power_count;    } ...

Popular posts from this blog

Trie Data Structure and Finding Patterns in a Collection of Words

My Crappy Looking Solution to "Binary Tree Common Ancestor" Problem

A Graph Application in Java: Using WordNet to Find Outcast Words