Posts

Showing posts from March, 2009

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...

ANT ve Yazılım Projelerinin İnşası

Günümüzde kurumsal uygulamalar geliştirilirken yinelemeli (iterative) yöntemler kullanılıyor. Yani projenin geliştirme takvimi, yineleme (iterasyon) denilen kısımlara ayrılıyor ve her yinelemede çalışabilen bir ürünün çıkarılması hedefleniyor. Kaynak kod kontrol sistemleri (CVS, Subversion, Clearcase, Visual SourceSafe gibi) projenin kodlarını bir makinede saklarken, bir yandan da bu kodlardan ürün elde etmek için gereken işlemler düzenli olarak yapılıyor. Örneğin Java ortamına ilişkin bir ağ (web) uygulaması söz konusu ise, elde etmek istediğimiz ürün bir WAR dosyası olabilir. Microsoft geliştirme ortamında da genellikle Visual Studio üzerinden düzenli olarak "build" komutunu çalıştırıyoruz. Aynı şekilde "Build Solution", "Clean Solution" gibi komutlar çalıştırıyoruz. Burada Visual Studio ne yapıyor? Ant ve NAnt kütüphaneleri, her türlü projeyi inşa ederken yapılması gereken derleme, dosya kopyalama, dosya/dizin silme gibi işlemleri kolay bir biçimde tan...

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