Search icon CANCEL
Subscription
0
Cart icon
Your Cart (0 item)
Close icon
You have no products in your basket yet
Save more on your purchases! discount-offer-chevron-icon
Savings automatically calculated. No voucher code required.
Arrow left icon
Explore Products
Best Sellers
New Releases
Books
Videos
Audiobooks
Learning Hub
Free Learning
Arrow right icon
Arrow up icon
GO TO TOP
Clojure High Performance Programming, Second Edition

You're reading from   Clojure High Performance Programming, Second Edition Become an expert at writing fast and high performant code in Clojure 1.7.0

Arrow left icon
Product type Paperback
Published in Sep 2015
Publisher
ISBN-13 9781785283642
Length 198 pages
Edition 2nd Edition
Languages
Arrow right icon
Author (1):
Arrow left icon
Shantanu Kumar Shantanu Kumar
Author Profile Icon Shantanu Kumar
Shantanu Kumar
Arrow right icon
View More author details
Toc

Table of Contents (10) Chapters Close

Preface 1. Performance by Design FREE CHAPTER 2. Clojure Abstractions 3. Leaning on Java 4. Host Performance 5. Concurrency 6. Measuring Performance 7. Performance Optimization 8. Application Performance Index

Performance and queueing theory


If we observe the performance benchmark numbers across a number of runs, even though the hardware, loads and OS remain the same, the numbers are rarely exactly the same. The difference between each run may be as much as -8 percent to 8 percent for no apparent reason. This may seem surprising, but the deep-rooted reason is that the performances of computer systems are stochastic by nature. There are many small factors in a computer system that make performance unpredictable at any given point of time. At best, the performance variations can be explained by a series of probabilities over random variables.

The basic premise is that each subsystem is more or less like a queue where requests await their turn to be served. The CPU has an instruction queue with unpredictable fetch/decode/branch-predict timings, the memory access again depends on cache hit ratio and whether it needs to be dispatched via the interconnect, and the I/O subsystem works using interrupts...

lock icon The rest of the chapter is locked
Register for a free Packt account to unlock a world of extra content!
A free Packt account unlocks extra newsletters, articles, discounted offers, and much more. Start advancing your knowledge today.
Unlock this book and the full library FREE for 7 days
Get unlimited access to 7000+ expert-authored eBooks and videos courses covering every tech area you can think of
Renews at $19.99/month. Cancel anytime
Banner background image