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
Learn Java 12 Programming

You're reading from   Learn Java 12 Programming A step-by-step guide to learning essential concepts in Java SE 10, 11, and 12

Arrow left icon
Product type Paperback
Published in Apr 2019
Publisher Packt
ISBN-13 9781789957051
Length 690 pages
Edition 1st Edition
Languages
Arrow right icon
Author (1):
Arrow left icon
Nick Samoylov Nick Samoylov
Author Profile Icon Nick Samoylov
Nick Samoylov
Arrow right icon
View More author details
Toc

Table of Contents (25) Chapters Close

Preface 1. Section 1: Overview of Java Programming FREE CHAPTER
2. Getting Started with Java 12 3. Java Object-Oriented Programming (OOP) 4. Java Fundamentals 5. Section 2: Building Blocks of Java
6. Exception Handling 7. Strings, Input/Output, and Files 8. Data Structures, Generics, and Popular Utilities 9. Java Standard and External Libraries 10. Multithreading and Concurrent Processing 11. JVM Structure and Garbage Collection 12. Managing Data in a Database 13. Network Programming 14. Java GUI Programming 15. Section 3: Advanced Java
16. Functional Programming 17. Java Standard Streams 18. Reactive Programming 19. Microservices 20. Java Microbenchmark Harness 21. Best Practices for Writing High-Quality Code 22. Java - Getting New Features 23. Assessments 24. Other Books You May Enjoy

Thread versus process

Java has two units of execution—process and thread. A process usually represents the whole JVM, although an application can create another process using java.lang.ProcessBuilder. But, since the multi-process case is outside the scope of this book, we will focus on the second unit of execution, that is, a thread, which is similar to a process but less isolated from other threads and requires fewer resources for execution.

A process can have many threads running and at least one thread called the main thread—the one that starts the application—which we use it in every example. Threads can share resources, including memory and open files, which allows for better efficiency. But it comes with a price of higher risk of unintended mutual interference and even blocking of the execution. That is where programming skills and an understanding of...

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