Book Image

Oracle JRockit: The Definitive Guide

Book Image

Oracle JRockit: The Definitive Guide

Overview of this book

Oracle JRockit is one of the industry’s highest performing Java Virtual Machines. Java developers are always on the lookout for better ways to analyze application behavior and gain performance. As we all know, this is not as easy as it looks. Welcome to JRockit: The Definitive Guide.This book helps you gain in-depth knowledge of Java from the JVM’s point of view. We will explain how to write code that works well with the JVM to gain performance and scalability. Starting with the inner workings of the JRockit JVM and finishing with a thorough walkthrough of the tools in the JRockit Mission Control suite, this book is for anyone who wants to know more about how the JVM executes your Java application and how to profile for better performance.
Table of Contents (23 chapters)
Oracle JRockit
Credits
Foreword
About the Authors
Acknowledgement
About the Reviewers
Preface
12
Using the JRockit Management APIs
Bibliography
Glossary
AST
CAS
HIR
IR
JFR
JMX
JRA
JSR
LIR
MD5
MIR
PDE
RCP
SWT
TLA
Index

Lazy unlocking


Lazy unlocking is also sometimes known as biased locking. This is an optimization of lock behavior that works if the assumption is valid that many locks are thread local, albeit possibly frequently taken and released. In lazy unlocking, the runtime gambles that locks are likely to remain thread local. When a lock is released for the first time, the runtime may choose not to unlock it, treating the unlock as a no-op. When the lock is later reacquired by the same thread, that lock also becomes a no-op. The worst case is, of course, if another thread tries to acquire the lazy locked monitor. In that case, it needs to be converted to a normal lock or forcefully unlocked to preserve semantics. Consequently, locks that are "ping ponging" back and forth, repeatedly being acquired and released by different threads are ill-suited for lazy unlocking.

A lazy unlocking implementation typically contains various heuristics to make it perform more optimally in a changing environment, for example, by banning its application on certain objects or certain object types that have too frequently needed to be forcefully unlocked.