Different results of java and C verion of same program ?

Andrew Haley aph@redhat.com
Fri Mar 10 15:32:00 GMT 2006


David Balazic writes:
 > From: Mark Wielaard [mailto:mark@klomp.org] 
 > > 
 > > On Wed, 2006年03月08日 at 11:06 +0100, David Bala¾ic wrote:
 > > > The main part of the program is a double loop, comparing 
 > > each element of 
 > > > a Vector
 > > > with all other elements of the Vector (except itself).
 > > > 
 > > > Any ideas for speedup ?
 > > 
 > > A Vector is synchronized on all operations. If you don't need this try
 > > using an ArrayList and loop over it with an Iterator. gcj might not
 > > optimize away the synchronized accesses on Vector.
 > 
 > I use a Vector, becasue I fill it with data read from file and I don't know
 > beforehand the amount of data.
 > Should copy the data over to new ArrayList, after the Vector is done ?
No. Simply replace all cases of ArrayList in your code with Vector.
 > Unrelated to gcj :
 > I implemented a better algorithm, which is O(n) instead of O(n*n)
 > and compared Sun JIT to a C++ port. The C++ version is twice slower :-)
Err, something weird is happening.
Andrew.


More information about the Java mailing list

AltStyle によって変換されたページ (->オリジナル) /