On Java 8
On Java 8
About the Book
This book teaches Java programming using the features in the 8th version of that language. Version 2 of the book (December 2021) adds supplements covering features through Java 17.
My previous Java book, Thinking in Java, 4th Edition (Prentice Hall 2006), is still useful for programming in Java 5, the version of the language used for Android programming. But especially with the advent of Java 8, the language has changed significantly enough that new Java code feels and reads differently. This justified the two-year effort of creating a new book.
Each chapter teaches a concept, or a group of associated concepts, without relying on features that haven't yet been introduced. That way you can digest each piece in the context of your current knowledge before moving on.
My goals in this book are to:
1. Present the material one step at a time so you can easily incorporate each idea before moving on, and to carefully sequence the presentation of features so you're exposed to a topic before you see it in use. This isn't always possible; in those situations, a brief introductory description is given.
2. Use examples that are as simple and short as possible. This sometimes prevents me from tackling "real world" problems, but I've found that beginners are usually happier when they can understand every detail of an example rather than being impressed by the scope of the problem it solves. For this I might receive criticism for using "toy examples," but I'm willing to accept that in favor of producing something pedagogically useful.
3. Give you what I think is important for you to understand about the language, rather than everything I know. I believe there is an information importance hierarchy, and there are some facts that 95 percent of programmers will never need to know---details that just confuse people and increase their perception of the complexity of the language. If you must think about it, it will also confuse the reader/maintainer of that code, so I advocate choosing a simpler approach.
4. Provide you with a solid foundation so you understand the issues well enough to move on to more difficult coursework and books.
Table of Contents
- Copyright
-
Preface
- Post-Java-8 Features in this Book
- This is Only an eBook
- Colophon
- Acknowledgements
- Dedication
-
Introduction
- Goals
- Language Design Errors
- Popularity
- Android Programmers
- Book Updates
- The New Java “Release Cadence”
- What About User Interfaces?
- JDK HTML Documentation
- Tested Examples
- Coding Standards
- Bug Reports
- Source Code
-
What is an Object?
- The Progress of Abstraction
- An Object Has an Interface
- Objects Provide Services
- The Hidden Implementation
- Reusing the Implementation
- Inheritance
- Interchangeable Objects with Polymorphism
- The Singly-Rooted Hierarchy
- Collections
- Object Creation & Lifetime
- Exception Handling: Dealing with Errors
- Summary
-
Installing Java and the Book Examples
- Editors
- The Shell
- Installing Java
- Verify Your Installation
- Installing and Running the Book Examples
-
Objects Everywhere
- You Manipulate Objects with References
- You Must Create All the Objects
- Comments
- You Never Need to Destroy an Object
-
Creating New Data Types:
class
- Methods, Arguments, and Return Values
- Writing a Java Program
- Your First Java Program
- Coding Style
- Summary
-
Operators
- Using Java Operators
- Precedence
- Assignment
- Mathematical Operators
- Auto Increment and Decrement
- Relational Operators
- Logical Operators
- Literals
- Bitwise Operators
- Shift Operators
-
Ternary
if-else
Operator -
String
Operator + and += - Common Pitfalls When Using Operators
- Casting Operators
- Java Has No “sizeof”
- A Compendium of Operators
- Summary
-
Control Flow
-
true
andfalse
-
if-else
- Iteration Statements
- For-in Syntax
-
return
-
break
andcontinue
- The Infamous “Goto”
-
switch
- Switching on Strings
- Summary
-
-
Housekeeping
- Guaranteed Initialization with the Constructor
- Method Overloading
- Zero-Argument Constructors
-
The
this
Keyword - Cleanup: Finalization and Garbage Collection
- Member Initialization
- Constructor Initialization
- Array Initialization
- Enumerated Types
- New Feature: Local Variable Type Inference
- Summary
-
Implementation Hiding
-
package
: the Library Unit - Java Access Specifiers
- Interface and Implementation
- Class Access
- New Feature: Modules
- Summary
-
-
Reuse
- Composition Syntax
- Inheritance Syntax
- Delegation
- Combining Composition and Inheritance
- Choosing Composition vs. Inheritance
-
protected
- Upcasting
-
The
final
Keyword - Initialization and Class Loading
- Summary
-
Polymorphism
- Upcasting Revisited
- The Twist
- Constructors and Polymorphism
- Covariant Return Types
- Designing with Inheritance
- Summary
-
Interfaces
- Abstract Classes and Methods
- Defining Interfaces
- Abstract Classes vs. Interfaces
- Complete Decoupling
- Combining Multiple Interfaces
- Extending an Interface with Inheritance
- Adapting to an Interface
- Fields in Interfaces
- Nesting Interfaces
- Interfaces and Factories
-
New Feature:
private
Methods in Interfaces - New Feature: Sealed Classes and Interfaces
- Summary
-
Inner Classes
- Creating Inner Classes
- The Link to the Outer Class
-
Using
.this
and.new
- Inner Classes and Upcasting
- Inner Classes in Methods and Scopes
- Anonymous Inner Classes
- Nested Classes
- Why Inner Classes?
- Inheriting from Inner Classes
- Can Inner Classes Be Overridden?
- Local Inner Classes
- Inner-Class Identifiers
- Summary
-
Collections
- Generics and Type-Safe Collections
- Basic Concepts
- Adding Groups of Elements
- Printing Collections
-
List
-
Iterator
s -
LinkedList
-
Stack
-
Set
-
Map
- New Feature: Records
-
Queue
-
Collection
vs.Iterator
- for-in and Iterators
- Summary
-
Functional Programming
- Old vs. New
- Lambda Expressions
- Method References
- Functional Interfaces
- Higher-Order Functions
- Closures
- Function Composition
- Currying and Partial Evaluation
- Pure Functional Programming
- Summary
-
Streams
- Java 8 Stream Support
- Stream Creation
- Intermediate Operations
- Optional
- Terminal Operations
- Summary
-
Exceptions
- Concepts
- Basic Exceptions
- Catching an Exception
- Creating Your Own Exceptions
- The Exception Specification
- Catching Any Exception
- Standard Java Exceptions
-
New Feature: Better
NullPointerException
Reporting -
Performing Cleanup with
finally
- Exception Restrictions
- Constructors
- Try-With-Resources
- Exception Matching
- Alternative Approaches
- Exception Guidelines
- Summary
-
Validating Your Code
- Testing
- Preconditions
- Test-Driven Development
- Logging
- Debugging
- Benchmarking
- Profiling and Optimizing
- Style Checking
- Static Error Analysis
- Code Reviews
- Pair Programming
- Refactoring
- Continuous Integration
- Summary
-
Files
- File and Directory Paths
- Directories
- File Systems
-
Watching a
Path
- Finding Files
- Reading & Writing Files
- Summary
-
Strings
-
Immutable
String
s -
Overloading
+
vs.StringBuilder
- Unintended Recursion
-
Operations on
String
s - Formatting Output
- New Feature: Text Blocks
- Regular Expressions
- Scanning Input
-
StringTokenizer
- Summary
-
Immutable
-
Reflection
- The Need for Reflection
-
The
Class
Object - Checking Before a Cast
- Registered Factories
-
Instanceof
vs.Class
Equivalence - Runtime Class Information
- Dynamic Proxies
- Using Optional
- Interfaces and Type Information
- Summary
-
Generics
- Comparison with C++
- Simple Generics
- Generic Interfaces
- Generic Methods
- Building Complex Models
- The Mystery of Erasure
- Compensating for Erasure
- Bounds
- Wildcards
- Issues
- Self-Bounded Types
- Dynamic Type Safety
- Exceptions
- Mixins
- Latent Typing
- Compensating for the Lack of (Direct) Latent Typing
- Assisted Latent Typing in Java 8
- Summary: Is Casting Really So Bad?
-
Arrays
- Why Arrays are Special
- Arrays are First-Class Objects
- Returning an Array
- Multidimensional Arrays
- Arrays and Generics
-
Arrays.fill()
-
Arrays.setAll()
- Incremental Generators
- Random Generators
- Generics and Primitive Arrays
- Modifying Existing Array Elements
- An Aside On Parallelism
-
Arrays
Utilities - Copying an Array
- Comparing Arrays
-
Stream
s and Arrays - Sorting Arrays
-
Searching with
Arrays.binarySearch()
-
Accumulating with
parallelPrefix()
- Summary
-
Enumerations
-
Basic
enum
Features -
Adding Methods to an
enum
-
enum
s inswitch
Statements -
The Mystery of
values()
- Implements, not Inherits
- Random Selection
- Using Interfaces for Organization
-
Using
EnumSet
Instead of Flags -
Using
EnumMap
- Constant-Specific Methods
- Multiple Dispatching
- New Features to Support Pattern Matching
-
New Feature: Arrow in
switch
-
New Feature:
case null
inswitch
-
New Feature:
switch
as an Expression - New Feature: Smart Casts
- New Feature: Pattern Matching
- Summary
-
Basic
-
Annotations
- Basic Syntax
- Writing Annotation Processors
-
Using
javac
to Process Annotations - Annotation-Based Unit Testing
- Summary
-
Concurrent Programming
- The Terminology Problem
- Concurrency Superpowers
- Concurrency is for Speed
- The Four Maxims of Java Concurrency
- The Brutal Truth
- The Rest of the Chapter
- Parallel Streams
- Creating and Running Tasks
- Terminating Long-Running Tasks
-
CompletableFuture
s - Deadlock
- Constructors are not Thread-Safe
- Effort, Complexity, Cost
- Summary
-
Patterns
- The Pattern Concept
- Singleton
- Classifying Patterns
- Template Method
- Fronting for an Implementation
- Factories: Encapsulating Object Creation
- Function Objects
- Changing the Interface
- Interpreter: Runtime Flexibility
- Callbacks
- Multiple Dispatching
- Pattern Refactoring
- Summary
-
Appendix: Supplements
- On Java 8 Example Code
- Hands-On Java eSeminar
-
Appendix: Programming Guidelines
- Design
- Implementation
-
Appendix: Javadoc
- Syntax
- Embedded HTML
- Some Example Tags
- Documentation Example
-
Appendix: Passing and Returning Objects
- Passing References
- Making Local Copies
- Controlling Cloneability
- Immutable Classes
- Summary
-
Appendix: I/O Streams
-
Types of
InputStream
-
Types of
OutputStream
- Adding Attributes and Useful Interfaces
-
Reader
s &Writer
s -
Off By Itself:
RandomAccessFile
- Typical Uses of I/O Streams
- Summary
-
Types of
-
Appendix: Standard I/O
- Reading from Standard Input
-
Changing
System.out
to aPrintWriter
- Redirecting Standard I/O
- Process Control
-
Appendix: New I/O
-
ByteBuffer
s - Converting Data
- Fetching Primitives
- View Buffers
- Data Manipulation with Buffers
- Memory-Mapped Files
- File Locking
-
-
Appendix: Understanding
equals()
andhashCode()
-
A Canonical
equals()
- Hashing and Hash Codes
-
Tuning a
HashMap
-
A Canonical
-
Appendix: Collection Topics
- Sample Data
-
List
Behavior -
Set
Behavior -
Using Functional Operations with any
Map
-
Selecting Parts of a
Map
- Filling Collections
-
Custom
Collection
andMap
using Flyweight -
Collection
Functionality - Optional Operations
-
Set
s and Storage Order - Queues
-
Understanding
Map
s - Utilities
- Holding References
- Java 1.0/1.1 Collections
- Summary
-
Appendix: Low-Level Concurrency
- What is a Thread?
- Catching Exceptions
- Sharing Resources
-
The
volatile
Keyword - Atomicity
- Critical Sections
- Library Components
- Summary
-
Appendix: Data Compression
- Simple Compression with GZIP
- Multifile Storage with Zip
- Java Archives (Jars)
-
Appendix: Object Serialization
- Overview
- Finding the Class
- Controlling Serialization
- Using Persistence
-
Appendix: Benefits and Costs of Static Type Checking
- Foreword to the 2021 Edition
- Foreword to the Original Edition
- Static Type Checking vs. Testing
- How to Argue about Typing
- The Cost of Productivity
- Static vs. Dynamic
- Appendix: The Positive Legacy of C++ and Java
-
Appendix: Becoming a Programmer
- How I Got Started in Programming
- A Career in Computing
- The Mythical 5%
- Writing Software Is Like … Writing
- Programming as Typing
- Do What You Love
- Notes
Other books by this author
The Leanpub 60 Day 100% Happiness Guarantee
Within 60 days of purchase you can get a 100% refund on any Leanpub purchase, in two clicks.
Now, this is technically risky for us, since you'll have the book or course files either way. But we're so confident in our products and services, and in our authors and readers, that we're happy to offer a full money back guarantee for everything we sell.
You can only find out how good something is by trying it, and because of our 100% money back guarantee there's literally no risk to do so!
So, there's no reason not to click the Add to Cart button, is there?
See full terms...
Earn $8 on a $10 Purchase, and $16 on a $20 Purchase
We pay 80% royalties on purchases of $7.99 or more, and 80% royalties minus a 50 cent flat fee on purchases between $0.99 and $7.98. You earn $8 on a $10 sale, and $16 on a $20 sale. So, if we sell 5000 non-refunded copies of your book for $20, you'll earn $80,000.
(Yes, some authors have already earned much more than that on Leanpub.)
In fact, authors have earnedover $14 millionwriting, publishing and selling on Leanpub.
Learn more about writing on Leanpub
Free Updates. DRM Free.
If you buy a Leanpub book, you get free updates for as long as the author updates the book! Many authors use Leanpub to publish their books in-progress, while they are writing them. All readers get free updates, regardless of when they bought the book or how much they paid (including free).
Most Leanpub books are available in PDF (for computers) and EPUB (for phones, tablets and Kindle). The formats that a book includes are shown at the top right corner of this page.
Finally, Leanpub books don't have any DRM copy-protection nonsense, so you can easily read them on any supported device.
Learn more about Leanpub's ebook formats and where to read them