Java Performance
Author: Charlie Hunt & Binu John
Publisher: Addison-Wesley
Pages: 720
ISBN: 978-0137142521
Aimed at: Experienced Java Programmers
Rating: 4.5
Pros: Provides highly technical information in an accessible way
Cons: Bias towards Oracle
Reviewed by: Mike James

Performance is a topic that engages most Java programmers sooner or later. How does this book help?

Author: Charlie Hunt & Binu John
Publisher: Addison-Wesley
Pages: 720
ISBN: 978-0137142521
Aimed at: Experienced Java Programmers
Rating: 4.5
Pros: Provides highly technical information in an accessible way
Cons: Bias towards Oracle
Reviewed by: Mike James

Performance is a topic that engages most Java programmers sooner or later. As everyone knows, Java compiles to an intermediate code which is run on a virtual machine (VM) designed specially for the job. What is less well known is that there is a lot you can do to optimize the performance. This book is all about how to find out what is critical for a particular program and how to make it better.

The most important thing to say about this book is that it is deep. It certainly isn't for beginners and you need to not only know your Java but also quite a lot about machines and low level things in particular. The first few chapters are all about profiling and measuring performance. The basic idea is that you need to know what is causing any performance problems before trying to fix anything. Performance monitoring is also a recurring topic in the remainder of the book for the same reason.

Banner

Things start to get really interesting and specific in Chapter 3 which starts to explain the JVM - memory management, threading, garbage collection and so on. The following two chapters are on performance monitoring and profiling. Chapter 6 is about tuning the application and has a lot of advice that you will have encountered before in general optimization. Chapter 7 moves on to tuning the JVM.

The remainder of the book is on benchmarking various types of applications - multi-tiered, web applications, web services and EJB applications.

The book closes with a look at the command line parameters for the HotSpot VM and sample source code.

The best bits of the book are probably the chapters on the JVM, Chapters 3, 4 and 5, because this is of interest to all Java programmers and it tells you things you want to know about, even if it doesn't turn out to be actually useful. Finding out about the JVM, and in particular the command line parameters that you can use to modify its behavior, is a real eye-opener.

The only negative is that throughout the book there are lots of plugs for Oracle products. Yes, this book has an Oracle bias and there are lots of references to Solaris, NetBeans and Sparc processors.  More importantly it uses the Solaris Performance Analyzer which works with Unix/Linux systems. If you are a Windows programmer, no alternatives such as JProbe are explored.

This is a rare thing - a technical book that isn't afraid to be technical. If you are at all interested in the inner workings of Java, or if you really have a performance problem with a Java application, you need to read at least some of the chapters in this book. It is an excellent addition to any Java bookshelf.


Banner


Modern Fortran

Author: Milan Curcic
Publisher: Manning
Date: November 2020
Pages: 416
ISBN: 978-1617295287
Print: 1617295280
Audience: Fortran programmers
Rating: 5
Reviewer: Mike James
Not your parents' Fortran?



Driving Value With Sprint Goals

Author: Maarten Dalmijn
Publisher: Addison-Wesley
Pages: 256
ISBN: 9780137381920
Print: 0137381921
Kindle:B0C7ZJR7N2
Audience: Scrum developers
Rating: 5
Reviewer: Kay Ewbank

Over the years I've read a lot of books about agile development and Scrum, and most concentrate on the methodology rather tha [ ... ]


More Reviews

Last Updated ( Tuesday, 20 March 2012 )