COMPSCI 230 S2C 2013 Software Design and Construction Introduction to Java Threads Lecture 1 of Theme C.

Slides:



Advertisements
Similar presentations
1 Multithreaded Programming in Java. 2 Agenda Introduction Thread Applications Defining Threads Java Threads and States Examples.
Advertisements

Concurrency Important and difficult (Ada slides copied from Ed Schonberg)
Silberschatz, Galvin and Gagne ©2009Operating System Concepts – 8 th Edition Chapter 4: Threads.
Modified from Silberschatz, Galvin and Gagne ©2009 Lecture 7 Chapter 4: Threads (cont)
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts Essentials – 2 nd Edition Chapter 4: Threads.
COMPSCI 230 S2C 2015 Software Design and Construction Thread usage and synchronisation Lecture 3 of Theme C C31.
CS220 Software Development Lecture: Multi-threading A. O’Riordan, 2009.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 3: Processes.
Definitions Process – An executing program
1 Chapter 4 Threads Threads: Resource ownership and execution.
Multithreading in Java Nelson Padua-Perez Chau-Wen Tseng Department of Computer Science University of Maryland, College Park.
A. Frank - P. Weisberg Operating Systems Introduction to Tasks/Threads.
Silberschatz, Galvin and Gagne ©2009Operating System Concepts – 8 th Edition Chapter 4: Threads.
Multithreading in Java Nelson Padua-Perez Bill Pugh Department of Computer Science University of Maryland, College Park.
50.003: Elements of Software Construction Week 5 Basics of Threads.
What is Concurrent Programming? Maram Bani Younes.
Silberschatz, Galvin and Gagne ©2009 Operating System Concepts – 8 th Edition, Chapter 4: Threads.
Advanced Operating Systems CIS 720 Lecture 1. Instructor Dr. Gurdip Singh – 234 Nichols Hall –
Silberschatz, Galvin and Gagne ©2011Operating System Concepts Essentials – 8 th Edition Chapter 4: Threads.
 Introduction to Operating System Introduction to Operating System  Types Of An Operating System Types Of An Operating System  Single User Single User.
Threads. Overview Problem Multiple tasks for computer Draw & display images on screen Check keyboard & mouse input Send & receive data on network Read.
Multi-Threaded Application CSNB534 Asma Shakil. Overview Software applications employ a strategy called multi- threaded programming to split tasks into.
10/17/2015Vimal1 Threads By 10/17/2015Vimal2 Why use threads?? It is a powerful programming tool Computer users take it for granted.
Java Threads 11 Threading and Concurrent Programming in Java Introduction and Definitions D.W. Denbo Introduction and Definitions D.W. Denbo.
INVITATION TO COMPUTER SCIENCE, JAVA VERSION, THIRD EDITION Chapter 6: An Introduction to System Software and Virtual Machines.
Threads Concurrency in Java. What is mult-tasking? Doing more than one task.
Java Threads. What is a Thread? A thread can be loosely defined as a separate stream of execution that takes place simultaneously with and independently.
1 Web Based Programming Section 8 James King 12 August 2003.
Games Development 2 Concurrent Programming CO3301 Week 9.
Operating Systems David Goldschmidt, Ph.D. Computer Science The College of Saint Rose CIS 432.
COMPSCI 230 S2C 2013 Software Design and Construction Deadlock, Performance, Programming Guidelines Lecture 6 of Theme C.
CS333 Intro to Operating Systems Jonathan Walpole.
Multithreading in Java Sameer Singh Chauhan Lecturer, I. T. Dept., SVIT, Vasad.
COMPSCI 230 S2C 2013 Software Design and Construction A Thread’s Life Lecture 2 of Theme C.
Introduction to Threads Session 01 Java Simplified / Session 14 / 2 of 28 Objectives Define a thread Define multithreading List benefits of multithreading.
15.1 Threads and Multi- threading Understanding threads and multi-threading In general, modern computers perform one task at a time It is often.
COMPSCI 230 S2C 2015 Software Design and Construction Synchronization (cont.) Lecture 4 of Theme C.
Concurrency Control 1 Fall 2014 CS7020: Game Design and Development.
Threads in Java1 Concurrency Synchronizing threads, thread pools, etc.
Concurrent Computing CSCI 201L Jeffrey Miller, Ph.D. HTTP :// WWW - SCF. USC. EDU /~ CSCI 201 USC CSCI 201L.
© Janice Regan, CMPT 300, May CMPT 300 Introduction to Operating Systems Operating Systems Processes and Threads.
CMSC 330: Organization of Programming Languages Threads.
Thread basics. A computer process Every time a program is executed a process is created It is managed via a data structure that keeps all things memory.
Threads. Readings r Silberschatz et al : Chapter 4.
Silberschatz, Galvin and Gagne ©2013 Operating System Concepts – 9 th Edition Chapter 4: Threads.
Multithreading. Multitasking The multitasking is the ability of single processor to perform more than one operation at the same time Once systems allowed.
SMP Basics KeyStone Training Multicore Applications Literature Number: SPRPxxx 1.
Agenda  Quick Review  Finish Introduction  Java Threads.
Concurrency (Threads) Threads allow you to do tasks in parallel. In an unthreaded program, you code is executed procedurally from start to finish. In a.
Concurrency in Java MD. ANISUR RAHMAN. slide 2 Concurrency  Multiprogramming  Single processor runs several programs at the same time  Each program.
Threads by Dr. Amin Danial Asham. References Operating System Concepts ABRAHAM SILBERSCHATZ, PETER BAER GALVIN, and GREG GAGNE.
Silberschatz, Galvin and Gagne ©2009Operating System Concepts – 8 th Edition Chapter 4: Threads.
Java Thread Programming
Tutorial 2: Homework 1 and Project 1
Chapter 4: Threads Modified by Dr. Neerja Mhaskar for CS 3SH3.
Advanced Operating Systems CIS 720
Multi Threading.
CS399 New Beginnings Jonathan Walpole.
Chapter 4: Multithreaded Programming
Lecture 21 Concurrency Introduction
Chapter 4: Threads.
Multithreaded Programming
What is Concurrent Programming?
Multithreaded Programming
What is Concurrent Programming?
Chapter 4: Threads & Concurrency
Chapter 4: Threads.
- When you approach operating system concepts there might be several confusing terms that may look similar but in fact refer to different concepts:  multiprogramming, multiprocessing, multitasking,
CMSC 202 Threads.
Java Chapter 3 (Estifanos Tilahun Mihret--Tech with Estif)
Presentation transcript:

COMPSCI 230 S2C 2013 Software Design and Construction Introduction to Java Threads Lecture 1 of Theme C

Lecture Plan for Weeks /5Introduction to Java threads Sikora pp , Goetz1 pp /5A thread's lifeGoetz1 pp /5Where Java threads are used; synchronizationGoetz1 pp /5Locking, blocking, mutex; visibility, consistency.Goetz1 pp /5Deadlock; performance; programming guidelines.Goetz1 pp /5Dealing with InterruptedException (intro)Goetz2 pp /6 Executors, tasks, concurrent collections, synchronizers. Bloch pp /6Concurrency in SwingOracle 5/6 Debugging Swing / Revision of this unit Potochkin C12

Readings for this unit  Strongly recommended! 1. Sikora  Zbigniew Sikora, “Threads”, Chapter 10 of Java: Practical Guide for Programmers, Elsevier, Available to registered students through our library: Goetz1  Brian Goetz, “Introduction to Java threads”, IBM developerWorks, 26 Sep 2002, 27 pages. Available: Goetz2  Brian Goetz, “Java theory and Practice: Dealing with InterruptedException”, IBM developerWorks, 23 May Available: Bloch  Joshua Bloch, “Concurrency: Prefer executors and tasks to threads, and Prefer concurrency utilities to wait and notify”, Items 68 and 69 in Chapter 10 of Effective Java, Prentice Hall, 2 nd Edition, Available to registered students through our library: Oracle  Oracle, “Lesson: Concurrency in Swing”, The Java Tutorials, Available: Potochkin  Alexander Potochkin, “Debugging Swing, the final summary”, 16 February Available: C13

Learning Goals for Today  Develop an appropriate “mental model” for multithreaded programs.  Predict the outputs of a simple multithreaded program.  Understand why multithreading is important – and difficult!  List, and briefly discuss, some of the ways in which multithreading is used in Java.  Recognise some common “design patterns” for multithreaded computations: Model-View-Controller, simulation with one-thread-per- actor, foreground/background computations.  Explain how a volatile variable differs from a non-volatile one: what are its advantages and disadvantages? C14

PrintNumbersThread public class PrintNumbersThread extends Thread { String name; public PrintNumbersThread( String threadName ) { name = threadName; } public void run() { for( int i=1; i<=2; i++ ) { System.out.println(name + ": " + i); try { Thread.sleep(500); } catch( InterruptedException e ) { } } C15

RunThreads public class RunThreads { public static void main( String args[] ) { PrintNumbersThread threadl; PrintNumbersThread thread2; threadl = new PrintNumbersThread("Threadl"); thread2 = new PrintNumbersThread("Thread2") ; threadl.start () ; thread2.start () ; } Expected output: Thread1: 1 Thread2: 1 Thread1: 2 Thread2: 2 Thread1: 1 Thread2: 1 Thread2: 2 Thread1: 2 or Thread2: 1 Thread1: 1 Thread2: 2 Thread1: 2 Thread2: 1 Thread1: 2 Thread1: 1 Thread2: 2 Thread2: 1 Thread2: 2 Thread1: 1 Thread1: 2 Thread1: 1 Thread1: 2 Thread2: 1 Thread2: 2 C16

Tracing a Threaded Program 1. public class RunThreads { 2. public static void main( String args[] ) { 3. PrintNumbersThread threadl; 4. PrintNumbersThread thread2; 5. threadl = new PrintNumbersThread("Threadl"); 6. thread2 = new PrintNumbersThread("Thread2") ; 7. threadl.start () ; 8. thread2.start () ; 9. } } 10. public class PrintNumbersThread extends Thread { 11. public void run() { 12. for( int i=1; i<3; i++ ) { 13. System.out.println(name + ": " + i); 14. try { Thread.sleep(500); } 15. catch( InterruptedException e ) { } 16. } } } Note that the “parent thread” dies before its children. Thread1: 1 Thread2: 1 Thread1: 2 Thread2: 2 C17

Tracing a Threaded Program (2) 1. public class RunThreads { 2. public static void main( String args[] ) { 3. PrintNumbersThread threadl; 4. PrintNumbersThread thread2; 5. threadl = new PrintNumbersThread("Threadl"); 6. thread2 = new PrintNumbersThread("Thread2") ; 7. threadl.start () ; 8. thread2.start () ; 9. } } 10. public class PrintNumbersThread extends Thread { 11. public void run() { 12. for( int i=1; i<3; i++ ) { 13. System.out.println(name + ": " + i); 14. try { Thread.sleep(500); } 15. catch( InterruptedException e ) { } 16. } } } Note that the threads are unsynchronised. Thread1: 1 Thread2: 1 Thread2: 2 Thread1: 2 C18

CPUs, Cores, Processes, Threads  Modern computers have many forms of parallelism.  In hardware, there are  One to four CPU chips, with  Two to eight cores per CPU chip, and  Hundreds of instructions in the execution pipeline of each core.  In software, there are  Hundreds of processes, where  Each process is either running or waiting (for a core or an I/O device); and  One to 20 (or more) threads of control per process.  Each thread is either running or waiting.  (There are actually four states in Java’s thread model, as we’ll see later.)  If you are “hand-executing” a multithreaded program, you probably move only one instruction-pointer at a time – this is like a single-core execution.  If you could move 8 pointers simultaneously, you’d be simulating an 8-core CPU. C19

Context Switches  When a core “switches” its context to start executing a different thread, there is significant performance penalty:  Very roughly: hundreds of “wasted” instruction-execution cycles.  When you’re hand-executing a multi-threaded program, you have to ‘move your hand’ to a different instruction-pointer before you can start to move it – this is your context-switching time.  Currently, most CPU cores run only one thread at a time.  Ideally: number of runnable threads ≈ number of cores.  Ideally: each thread runs for a long time (>> 1000 instructions) before it has to “wait” for the output of another thread, or for an I/O device, or before it is interrupted by the end of its time-slice.  Currently, most operating systems have 100 to 1000 time-slices per second.  If you have more than 100 threads in a single Java program on a laptop or home computer, your threads will be waiting most of the time.  If threads have to wait more than 30 msec, your GUI will probably be “jerky” and “sluggish”. C110

Parallelism is difficult, why use it?  “Because it’s there”  If you write single-threaded Java programs, and your competitors are multi- threading efficiently, their programs will run 3x or even 8x faster because they’re using CPU cores that you’re leaving idle.  This is especially noticeable on “CPU-limited” computations e.g. image analysis.  Note: modern PCs also have a GPU (Graphics Processor Unit), allowing very efficient computer graphics without burdening the CPU.  “Because it’s very convenient”  When you’re writing GUIs, you generally use one thread to render the graphics (the “View”), one or more threads to run the back-end computation (the “Model”), and one thread (the “Controller”) to accept input from the user.  If you single-thread a GUI, the controls will be non-responsive and the display will “freeze” while you’re updating the Model (unless your model-updates take 30 milliseconds or less). C111

Why use parallelism? (cont.)  “Because it’s built into the JVM”  The JVM has some daemon threads which run very helpful services, e.g. its memory “garbage” collection.  In earlier languages, you had to “clean up your own garbage” by explicitly de- allocating objects.  Java collects “garbage” objects automatically – and correctly almost-all of the time, unless you terminate your threads improperly!  JVM’s daemons are carefully designed to “stay out of your way”:  running only when necessary,  making useful progress during a single time-slice, and  allowing your program’s threads to make progress (on other CPU cores) while the service is actively running. C112

Why use parallelism? (cont.)  “Because it’s natural (in some programs)”  When simulating a system with many actors, it’s natural to have one thread per actor:  the thread’s run() method describes “what this actor does”.  For example, a traffic simulator might have one thread for each automobile, bus, or truck that is on the roads being simulated.  Warning: using “parallelism to fit your problem,” rather than “parallelism to fit your hardware”, may lead to very inefficient computations.  A desktop PC will not run threads efficiently, however it can efficiently simulate automobiles in a roading network (if your simulator uses 100 threads). C113

Why use parallelism? (cont.)  “Because it’s natural (in some programs)”  In a server program, a thread “worker” can be assigned to each client.  The thread’s run() method delivers the service.  In a program that handles asynchronous I/O devices (e.g. network interfaces, disks, keyboards) a thread can be assigned to each device.  The thread’s run() method handles the I/O stream for this device.  If the thread executes a blocking read, e.g. SocketInputStream.read(), it will not run again until the read succeeds. The JVM handles this wait very efficiently. C114

Sharing Nicely  If your threads don’t “talk” to each other, they can’t cooperate.  If your threads do “talk”, they might confuse each other.  When one thread is changing an object, the other threads must be prevented from reading this object until the changes are complete.  When one thread is accessing a method, other threads must wait their turn (unless the method is “thread-safe” i.e. it can handle multiple simultaneous accesses).  There are several ways to share safely… C115

Volatile variables  If a variable, object, or field is declared as volatile, then  It can be used for reliable communication between threads.  Non-volatile variables, objects, and fields have unpredictable semantics, if they are read & written by more than one thread.  For example, if Thread1 and Thread2 are both executing the following: int x = 1; System.out.println(name + ": " + ( x++ ) );  This is equivalent to executing: int x = 1; int t = x; t = t + 1; x = t; System.out.println(name + ": " + x );  Thread1: 2 Thread2: 3 C116

Volatile variables (2)  If a variable, object, or field is declared as volatile, then  It can be used for reliable communication between threads.  Non-volatile variables, objects, and fields have unpredictable semantics, if they are read & written by more than one thread.  For example, if Thread1 and Thread2 are both executing the following: int x = 1; System.out.println(name + ": " + ( x++ ) );  This is equivalent to executing: int x = 1; int t = x; t = t + 1; x = t; System.out.println(name + ": " + x );  Thread1: 2 Thread2: 3 Thread2: 2 Thread1: 3 or C117

Volatile variables (3)  If a variable, object, or field is declared as volatile, then  It can be used for reliable communication between threads.  Non-volatile variables, objects, and fields have unpredictable semantics, if they are read & written by more than one thread.  For example, if Thread1 and Thread2 are both executing the following: int x = 1; System.out.println(name + ": " + ( x++ ) );  This is equivalent to executing: int x = 1; int t = x; t = t + 1; x = t; System.out.println(name + ": " + x );  Thread1: 2 Thread2: 3 Thread2: 2 Thread1: 3 Thread2: 2 Thread1: 2 or Thread1: 2 Thread2: 2 or Thread1: 3 Thread2: 2 or Thread2: 3 Thread1: 2 or C118

Volatile variables (4)  If a variable, object, or field is declared as volatile, then  It can be used for reliable communication between threads.  Semantics are predictable – if a thread reads the variable then writes it, the other thread is blocked from reading until the newly-written value is available.  Warning: you can cripple a multithreaded program by making all of its variables volatile.  The JVM must always read volatiles from memory. Frequently-used non-volatile values are retained in the CPU register file, which is *much* faster than main memory.  For example, if Thread1 and Thread2 are both executing the following: volatile int x = 1; System.out.println(name + ": " + ( x++ ) );  Thread1 and Thread2 always get different values! Thread1: 2 Thread2: 3 Thread2: 2 Thread1: 3 or Thread1: 3 Thread2: 2 Thread2: 3 Thread1: 2 or C119

Learning Goals for Today  Develop an appropriate “mental model” for multithreaded programs.  Predict the outputs of a simple multithreaded program.  Understand why multithreading is important – and difficult!  List, and briefly discuss, some of the ways in which multithreading is used in Java.  Recognise some common “design patterns” for multithreaded computations: Model-View-Controller, simulation with one-thread-per- actor, foreground/background computations.  Explain how a volatile variable differs from a non-volatile one: what are its advantages and disadvantages? C120