Daemon thread, 7 Deadlock, 27

Size: px
Start display at page:

Download "Daemon thread, 7 Deadlock, 27"

Transcription

1 Index A ArrayBlockingQueue, Atomic variables AtomicLong, 132 contention-reduction techniques, 132 counters and sequence generators, 131 getnextid() class, 131 intrinsic lock, 131 java.util.concurrent.atomic package, 130 lock-free, 130 nonblocking algorithms, 130 synchronization, 130 thread-safe operations, B BlockingQueue and ArrayBlockingQueue, interface, 166 producer-consumer application, 127 put() and take() methods, 128 subinterfaces, 126 C Cached variables computepi(), 23 processor-local cache, 23 Compare-and-swap (CAS) atomic methods int getvalue(), 133 atomic read-modify-write sequences, 133 atomic variable classes, 134 getnextid() method, Java Native Interface [JNI], 133 java.util.concurrent.locks. ReentrantLock, 134 Completion service CSDemo s main() method, 144 Euler s number, ExecutorCompletionService, 142 Future<V> s get() method, 142 java.util.concurrent. CompletionService<V> interface, 142 java.util.concurrent.executor CompletionService<V> class, 142 poll() method, 142 submit() methods, 142 Concurrency utilities higher-level constructs, 69 java.util.concurrent, 70 java.util.concurrent.atomic, 70, 82, 130 java.util.concurrent.locks, 70, 113 low-level concurrency primitives, 69 nanotime() method, 70 thread pools and blocking queues, 70 Concurrent collections BlockingQueue, 126, 166 ConcurrentMap, 126 java.util.concurrent package, 126 synchronized wrapper methods, 125 thread-safe collections, 126 weakly-consistent iterators, 126 ConcurrentHashMap class, ConcurrentMap subinterface, 166 Condition interface, 112, 164 Contended synchronization, 132 Countdown latch boolean await(long timeout, TimeUnit unit), 83 donesignal s countdown() method,

2 index Countdown latch (cont.) java.util.concurrent.countdownlatch class, 83 startsignal s await() method, 85 trigger thread, void await(), 83 void countdown(), 83 Counting semaphores, 96 Cyclic barrier await(), 91 barrieraction, 86 boolean isbroken(), 87 constructor, 90 fixed-size party, threads, 86 IllegalArgumentException, 86 int await(long timeout, TimeUnit unit), 87 int getnumberwaiting(), 87 int getparties(), 87 java.util.concurrent.cyclicbarrier class, 86 parallel decomposition, void reset(), 87 D Daemon thread, 7 Deadlock, 27 E Event-dispatch thread (EDT) listener method, 170 rules, 169 Exchanger buffers swap, EmptyingLoop and FillingLoop local classes, 95 Exchanger() constructor, 92 genetic algorithms, 91 generic java.util.concurrent. Exchanger<V> class, 92 V exchange(v x), 92 Executors class asynchronous computation, 75 callable s call() method, 80 callable tasks, 74 class s static methods, tasks, 77 Euler s Number e calculation, ExecutorService implementations, 72 74, 77 future s methods, 75 IllegalArgumentException, 77 interfaces, 71 java.lang.arithmeticexception, 80 java.math.bigdecimal local variable, 80 java.util.concurrent.executor interface, 70 java.util.concurrent.executorservice interface, 71 java.util.concurrent. ScheduledExecutorService interface, 76 java.util.concurrent.timeunit, 74 newfixedthreadpool() method, 79 new java.lang.thread, 70 RejectedExecutionException, 71 ScheduledExecutorService implementations, 76 submit() method, 76 task, 70 thread pool, 77 F Fork/Join framework algorithm, 139 CountedCompleter, 136 executor service and thread pool, 135 ForkJoinPool, 136, 141 ForkJoinTask, 136 ForkJoinWorkerThread, 136 invokeall() method, 141 java.util.concurrent package s ForkJoinPool, 136 massive parallelism, 134 MatMult class, 141 MatMult constructor, 141 matrix-multiplication algorithm, multiply() method, 138 RecursiveAction, 136 RecursiveAction s Collection<T>, 141 RecursiveTask-based tasks, 136 sorting algorithm, 135 subtasks,

3 Index thread contention, 135 two-dimensional table, two matrix instances (multiplication), worker thread, 135 G getinstance(), H holdslock(object o) method, 24 I ID.getID(), 26 IllegalThreadStateException, 8, 19 InheritableThreadLocal, 57 instancemethod1(), 29 instancemethod2(), 29 Interruption mechanism boolean isinterrupted():, 11 static boolean interrupted():, 11 void interrupt(), 10 while-based busy loop, 12 J, K java.lang.interruptedexception, 10 Java virtual machine (JVM), 3, 23, 53 L, M, N lambda expression, 4 Livelock, 27 Lock acquisition and release, 108 block-structured, 109 chain locking, 108 condition interface await() method, 116 boolean await(long time, TimeUnit unit), 112 boolean awaituntil(date deadline), 112 consumer signals, 116 consumer thread, 116 default main thread, 116 lock.newcondition(), 116 lockstep synchronization, 117 long awaitnanos(long nanostimeout), 112 newcondition() method, 112 producer and consumer classes, 116 setsharedchar(), 116 synchronization, void await(), 112 void awaituninterruptibly(), 112 void signal(), 112 void signalall(), 112 consumption and signals, 116 getlock() method, 116 hand-over-hand, 108 implementations, 109 interface, 109 methods, 108 producer thread, 116 ReentrantLock class, O One-shot execution, 58 59, 64 P Parallelism, Phaser constructor, 103 int arriveandawaitadvance() method, 103 int arriveandderegister() method, 103 integer-based phase number, 103 int register() method, 103 java.util.concurrent.phaser class, 103 The Phaser(int threads) constructor, 103 Preemptive scheduling, 6 Q Queue interface BlockingQueue subinterface, 166 (see also BlockingQueue) R Race condition getid(), 22 getinstance(),

4 index Race condition (cont.) memory location, 22 multithreaded context, 21 Parser object, 23 ReadWriteLock interface, 117 methods, 117 read-only operations, 117 ReentrantLock concurrency and memory semantics, 109 constructors, 110 fairness policy, 110 java.lang.illegal MonitorStateException, 110 lock() and unlock() methods, lockuninterruptibly(), 109 monitor lock, 109 synchronization, thread contention, 109 trylock() methods, 109 unlock(), 110 ReentrantReadWriteLock acquisition and release, 121 constructors, 118 dictionary application s reader and writer threads, executor, 121 int getreadholdcount(), 119 int getwriteholdcount(), 119 ReentrantReadWriteLock class, 118 ReentrantReadWriteLock.ReadLock readlock(), 118 ReentrantReadWriteLock.WriteLock writelock(), 118 run() method, 121 thread pool, 121 Round robin scheduling, 6 Runnable Objects constructors, 3 lambda expression, 4 S Semaphore class, 162 constructor method, control access, pool items, description, 96 fairness policy, 96 fairness setting, 97 java.util.concurrent.semaphore class, 96 Pool s String getitem(), 101 putitem(string), 101 String getnextavailableitem(), 101 synchronizers, 44, 162 void putitem(string item), 101 setpriority(int priority) method, 7 Single-processor/single-core machine, 31 sleep() methods Thread class, 152 s.setsharedchar(ch), 44 Starvation, 27 StoppableThread s stop() method, 31 StoppableThread, 31 stopthread() method, 31 SwingUtilities invokeandwait(), 174, 176 invokelater(), 174 iseventdispatchthread(), 174 SwingWorker class. SwingWorker timer class start and stop count, 183, 185 void start(), 183 void stop(), 183 SwingWorker get(), 179 GetHTML, 182 ViewPage application code, , 182 void execute(), 179 Synchronization cached variable, 26, 35 class method, 25 code sequence, 25 Deadlock, 30 field variable, 34 getid() method, 25 immutable objects, 35 loop iteration, 33 mutual exclusion, 24 pathological problem, 27 shared variables, 24 sleep() methods, 24 stopthread(), 30, 33 syntax, 26 Synchronizers countdown latch, 83, cyclic barrier. see (Cyclic barrier) exchanger. see (Exchanger) phaser, semaphore. see (Semaphore) 198

5 Index T, U Task-execution thread, 58 Thread alive/dead status, 5, 9 calling start(), 8 command line, 9 execution state, 5 feedback queue, 6 Java application, 3 name (assigning), 5 power series, 13 preemptive scheduling, 6 processors/cores, 6 Runnable interface, 3 schedulers, 6 setpriority(int priority) method, 7 sleep, 16 stacks, 3 start() method, 5 Windows 7 operating system, 10 Thread capabilities local variables. Thread-Local variables timer. see (Timer) timer framework, TimerTask boolean cancel(), 64 long scheduledexecutiontime(), 65 Thread class interruption mechanism, 10 semaphores, 162 sleep method, 152 Thread groups activecount(), 52 enumerate() methods, 52 handling exceptions, 52 int activecount() method, 52 java.lang.arithmeticexception object, 52 java.lang.threadgroup class, 51 JDK documentation, 51 JVM, 53 setdefaultuncaught ExceptionHandler() methods, 54 setuncaught ExceptionHandler(), static void setdefaultuncaught ExceptionHandler, 53 object s uncaught Exception() method, 53 uncaughtexception(), 53 uncaught exception handlers, 54 void resume(), 51 void stop(), 51 void suspend(), 51 Thread.interrupted(), 12 Thread-Local variables constructor and methods class, 55 final class field, 58 InheritableThreadLocal, 57 initialvalue() s value, 57 java.lang.threadlocal class, 55 multislot variable, 55 parent thread to child thread, 57 T childvalue(t parentvalue), 57 ThreadLocal<T>, 55 user IDs, threads, 56 Thread pools, 77 Thread-safe counters, 133 Thread.State getstate() method, 6 Timer constructors Timer(), 61 Timer(boolean isdaemon), 61 Timer(String name), 61 Timer(String name, boolean isdaemon), 61 methods void cancel(), 61 int purge(), 61 void scheduleatfixedrate (TimerTask task, Date firsttime, long period), 63 void schedule AtFixedRate (TimerTask task, long delay, long period), 63 Date firsttime, long period), 62 Date time), 62 long delay), 62 long delay, long period), 63 scales, 61 stop() method, 64 task-execution thread, 64 Timer-based slide show blend() method, 191 definition, slide show, 185 description, , loadslides() method,

6 index Timer-based slide show (cont.) output view, 193 projector, screen, 191 slide, 191 Timer framework alarm clock task, 58 current millisecond value, 60 Java 1.3, 58 one-shot execution, schedule() method, System.exit(0), 59 task-execution thread, 58 task scheduling, 58 TimerTask anonymous subclass, 60 Timer tasks, 64 V void join(), 13 void join(long millis, int nanos), 13 Volatile keyword, 30 W, X, Y, Z Wait-and-Notify API void notify(), 40 void notifyall(), 40 void wait(), 39 void wait(long timeout), 39 void wait(long timeout, int nanos), 39 Windows NT-based operating systems, 6 worker thread,

Threads Questions Important Questions

Threads Questions Important Questions Threads Questions Important Questions https://dzone.com/articles/threads-top-80-interview https://www.journaldev.com/1162/java-multithreading-concurrency-interviewquestions-answers https://www.javatpoint.com/java-multithreading-interview-questions

More information

CONCURRENT API AND PARALLEL PROGRAMMING

CONCURRENT API AND PARALLEL PROGRAMMING MODULE 11 CONCURRENT API AND PARALLEL PROGRAMMING Module 11.A THREAD MODEL: RUNNABLE, CALLABLE, FUTURE, FUTURETASK Threads > What are threads? Threads are a virtual CPU. > The three parts of at thread

More information

MultiThreading 07/01/2013. Session objectives. Introduction. Introduction. Advanced Java Programming Course

MultiThreading 07/01/2013. Session objectives. Introduction. Introduction. Advanced Java Programming Course Advanced Java Programming Course MultiThreading By Võ Văn Hải Faculty of Information Technologies Industrial University of Ho Chi Minh City Session objectives Introduction Creating thread Thread class

More information

Advanced Java Programming Course. MultiThreading. By Võ Văn Hải Faculty of Information Technologies Industrial University of Ho Chi Minh City

Advanced Java Programming Course. MultiThreading. By Võ Văn Hải Faculty of Information Technologies Industrial University of Ho Chi Minh City Advanced Java Programming Course MultiThreading By Võ Văn Hải Faculty of Information Technologies Industrial University of Ho Chi Minh City Session objectives Introduction Creating thread Thread class

More information

Chair of Software Engineering. Java and C# in depth. Carlo A. Furia, Marco Piccioni, Bertrand Meyer. Java: concurrency

Chair of Software Engineering. Java and C# in depth. Carlo A. Furia, Marco Piccioni, Bertrand Meyer. Java: concurrency Chair of Software Engineering Carlo A. Furia, Marco Piccioni, Bertrand Meyer Java: concurrency Outline Java threads thread implementation sleep, interrupt, and join threads that return values Thread synchronization

More information

COMP 322: Fundamentals of Parallel Programming

COMP 322: Fundamentals of Parallel Programming COMP 322: Fundamentals of Parallel Programming https://wiki.rice.edu/confluence/display/parprog/comp322 Lecture 30: Advanced locking in Java Vivek Sarkar Department of Computer Science Rice University

More information

Chapter 32 Multithreading and Parallel Programming

Chapter 32 Multithreading and Parallel Programming Chapter 32 Multithreading and Parallel Programming 1 Objectives To get an overview of multithreading ( 32.2). To develop task classes by implementing the Runnable interface ( 32.3). To create threads to

More information

Basics of. Multithreading in Java

Basics of. Multithreading in Java Basics of programming 3 Multithreading in Java Thread basics Motivation in most cases sequential (single threaded) applications are not adequate it s easier to decompose tasks into separate instruction

More information

CST242 Concurrency Page 1

CST242 Concurrency Page 1 CST242 Concurrency Page 1 1 2 3 4 5 6 7 9 Concurrency CST242 Concurrent Processing (Page 1) Only computers with multiple processors can truly execute multiple instructions concurrently On single-processor

More information

COMP 322: Fundamentals of Parallel Programming. Lecture 30: Java Synchronizers, Dining Philosophers Problem

COMP 322: Fundamentals of Parallel Programming. Lecture 30: Java Synchronizers, Dining Philosophers Problem COMP 322: Fundamentals of Parallel Programming Lecture 30: Java Synchronizers, Dining Philosophers Problem Vivek Sarkar, Shams Imam Department of Computer Science, Rice University Contact email: vsarkar@rice.edu,

More information

Paradigmas de Computação Paralela

Paradigmas de Computação Paralela Paradigmas de Computação Paralela Concurrent/Parallel Programming in OO /Java João Luís Ferreira Sobral jls@... Specification of concurrency/parallelism Benefits from concurrent programming Programs that

More information

27/04/2012. We re going to build Multithreading Application. Objectives. MultiThreading. Multithreading Applications. What are Threads?

27/04/2012. We re going to build Multithreading Application. Objectives. MultiThreading. Multithreading Applications. What are Threads? Objectives MultiThreading What are Threads? Interrupting threads Thread properties By Võ Văn Hải Faculty of Information Technologies Summer 2012 Threads priorities Synchronization Callables and Futures

More information

Dr.-Ing. Michael Eichberg

Dr.-Ing. Michael Eichberg Dr.-Ing. Michael Eichberg Concurrent Programming (Overview of the Java concurrency model and its relationship to other models...) (some slides are based on slides by Andy Wellings) 2 Processes vs. Threads

More information

CMSC 433 Programming Language Technologies and Paradigms Fall Locks & Conditions

CMSC 433 Programming Language Technologies and Paradigms Fall Locks & Conditions CMSC 433 Programming Language Technologies and Paradigms Fall 2011 Locks & Conditions Intrinsic Lock Example public class RWDictionaryIntrinsicLock { Map m = new TreeMap();

More information

Threads and Locks, Part 2. CSCI 5828: Foundations of Software Engineering Lecture 08 09/18/2014

Threads and Locks, Part 2. CSCI 5828: Foundations of Software Engineering Lecture 08 09/18/2014 Threads and Locks, Part 2 CSCI 5828: Foundations of Software Engineering Lecture 08 09/18/2014 1 Goals Cover the material presented in Chapter 2 of our concurrency textbook In particular, selected material

More information

CMSC 330: Organization of Programming Languages

CMSC 330: Organization of Programming Languages CMSC 330: Organization of Programming Languages Threads Synchronization Refers to mechanisms allowing a programmer to control the execution order of some operations across different threads in a concurrent

More information

Recap. Contents. Reenterancy of synchronized. Explicit Locks: ReentrantLock. Reenterancy of synchronise (ctd) Advanced Thread programming.

Recap. Contents. Reenterancy of synchronized. Explicit Locks: ReentrantLock. Reenterancy of synchronise (ctd) Advanced Thread programming. Lecture 07: Advanced Thread programming Software System Components 2 Behzad Bordbar School of Computer Science, University of Birmingham, UK Recap How to deal with race condition in Java Using synchronised

More information

Taming Dava Threads. Apress ALLEN HOLUB. HLuHB Darmstadt

Taming Dava Threads. Apress ALLEN HOLUB. HLuHB Darmstadt Taming Dava Threads ALLEN HOLUB HLuHB Darmstadt Apress TM Chapter l The Architecture of Threads l The Problems with Threads l All Nontrivial Java Programs Are Multithreaded 2 Java's Thread Support Is Not

More information

G52CON: Concepts of Concurrency

G52CON: Concepts of Concurrency G52CON: Concepts of Concurrency Lecture 11 Synchronisation in Java II Natasha Alechina School of Computer Science nza@cs.nott.ac.uk Outline of this lecture Mutual exclusion in Java continued (next lecture:

More information

Dr.-Ing. Michael Eichberg

Dr.-Ing. Michael Eichberg Dr.-Ing. Michael Eichberg Concurrent Programming (Overview of the Java concurrency model and its relationship to other models...) (some slides are based on slides by Andy Wellings) Processes vs. Threads

More information

UNIT V CONCURRENT PROGRAMMING

UNIT V CONCURRENT PROGRAMMING UNIT V CONCURRENT PROGRAMMING Multi-Threading: Java provides built-in support for multithreaded programming. A multithreaded program contains two or more parts that can run concurrently. Each part of such

More information

COMP31212: Concurrency A Review of Java Concurrency. Giles Reger

COMP31212: Concurrency A Review of Java Concurrency. Giles Reger COMP31212: Concurrency A Review of Java Concurrency Giles Reger Outline What are Java Threads? In Java, concurrency is achieved by Threads A Java Thread object is just an object on the heap, like any other

More information

The Dining Philosophers Problem CMSC 330: Organization of Programming Languages

The Dining Philosophers Problem CMSC 330: Organization of Programming Languages The Dining Philosophers Problem CMSC 0: Organization of Programming Languages Threads Classic Concurrency Problems Philosophers either eat or think They must have two forks to eat Can only use forks on

More information

Practical Concurrency. Copyright 2007 SpringSource. Copying, publishing or distributing without express written permission is prohibited.

Practical Concurrency. Copyright 2007 SpringSource. Copying, publishing or distributing without express written permission is prohibited. Practical Concurrency Agenda Motivation Java Memory Model Basics Common Bug Patterns JDK Concurrency Utilities Patterns of Concurrent Processing Testing Concurrent Applications Concurrency in Java 7 2

More information

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, Part 2 (Can't live with it, can't live without it.

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, Part 2 (Can't live with it, can't live without it. Principles of Software Construction: Objects, Design and Concurrency 15-214 toad The Perils of Concurrency, Part 2 (Can't live with it, can't live without it.) Spring 2013 Christian Kästner Charlie Garrod

More information

Concurrency Utilities: JSR-166

Concurrency Utilities: JSR-166 Concurrency Concurrency Utilities: JSR-166 Enables development of simple yet powerful multi-threaded applications > Like Collection provides rich data structure handling capability Beat C performance in

More information

What is a thread anyway?

What is a thread anyway? Concurrency in Java What is a thread anyway? Smallest sequence of instructions that can be managed independently by a scheduler There can be multiple threads within a process Threads can execute concurrently

More information

EDAF65 Processes and Threads

EDAF65 Processes and Threads EDAF65 Processes and Threads Per Andersson Lund University http://cs.lth.se/per_andersson/ January 24, 2018 Per Andersson EDAF65 Processes and Threads January 24, 2018 1 / 65 Time-Sharing Operating Systems

More information

JAVA EXAMPLES - SOLVING DEADLOCK

JAVA EXAMPLES - SOLVING DEADLOCK JAVA EXAMPLES - SOLVING DEADLOCK http://www.tutorialspoint.com/javaexamples/thread_deadlock.htm Copyright tutorialspoint.com Problem Description: How to solve deadlock using thread? Solution: Following

More information

CMSC 330: Organization of Programming Languages. The Dining Philosophers Problem

CMSC 330: Organization of Programming Languages. The Dining Philosophers Problem CMSC 330: Organization of Programming Languages Threads Classic Concurrency Problems The Dining Philosophers Problem Philosophers either eat or think They must have two forks to eat Can only use forks

More information

Java Concurrency. Towards a better life By - -

Java Concurrency. Towards a better life By - - Java Concurrency Towards a better life By - Srinivasan.raghavan@oracle.com - Vaibhav.x.choudhary@oracle.com Java Releases J2SE 6: - Collection Framework enhancement -Drag and Drop -Improve IO support J2SE

More information

EDA095 Processes and Threads

EDA095 Processes and Threads EDA095 Processes and Threads Pierre Nugues Lund University http://cs.lth.se/pierre_nugues/ April 1st, 2015 Pierre Nugues EDA095 Processes and Threads April 1st, 2015 1 / 65 Time-Sharing Operating Systems

More information

Programming in Java

Programming in Java 320341 Programming in Java Fall Semester 2014 Lecture 11: Introduction to Concurrency Instructor: Slides: Jürgen Schönwälder Bendick Mahleko Introduction Multithreaded Programs - A program represents separate,

More information

CMSC 330: Organization of Programming Languages. Threads Classic Concurrency Problems

CMSC 330: Organization of Programming Languages. Threads Classic Concurrency Problems : Organization of Programming Languages Threads Classic Concurrency Problems The Dining Philosophers Problem Philosophers either eat or think They must have two forks to eat Can only use forks on either

More information

Computation Abstractions. CMSC 330: Organization of Programming Languages. So, What Is a Thread? Processes vs. Threads. A computer.

Computation Abstractions. CMSC 330: Organization of Programming Languages. So, What Is a Thread? Processes vs. Threads. A computer. CMSC 330: Organization of Programming Languages Threads Computation Abstractions t1 t2 t1 t3 t2 t1 p1 p2 p3 p4 CPU 1 CPU 2 A computer t4 t5 Processes (e.g., JVM s) Threads CMSC 330 2 Processes vs. Threads

More information

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, Part 2 Can't live with it. Cant live without it.

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, Part 2 Can't live with it. Cant live without it. Principles of Software Construction: Objects, Design and Concurrency 15-214 toad The Perils of Concurrency, Part 2 Can't live with it. Cant live without it. Fall 2013 Jonathan Aldrich Charlie Garrod School

More information

Advanced Programming Methods. Lecture 6 - Concurrency in Java (1)

Advanced Programming Methods. Lecture 6 - Concurrency in Java (1) Advanced Programming Methods Lecture 6 - Concurrency in Java (1) Overview Introduction Java threads Java.util.concurrent References NOTE: The slides are based on the following free tutorials. You may want

More information

Principles of Software Construction: Objects, Design, and Concurrency. The Perils of Concurrency, Part 3 Can't live with it. Can't live without it.

Principles of Software Construction: Objects, Design, and Concurrency. The Perils of Concurrency, Part 3 Can't live with it. Can't live without it. Principles of Software Construction: Objects, Design, and Concurrency The Perils of Concurrency, Part 3 Can't live with it. Can't live without it. Fall 2014 Charlie Garrod Jonathan Aldrich School of Computer

More information

Multitasking. Multitasking allows several activities to occur concurrently on the computer Levels of multitasking: Process based multitasking

Multitasking. Multitasking allows several activities to occur concurrently on the computer Levels of multitasking: Process based multitasking Java Thread Multitasking Multitasking allows several activities to occur concurrently on the computer Levels of multitasking: Process based multitasking Allows programs (processes) to run concurrently

More information

Parallel Programming Practice

Parallel Programming Practice Parallel Programming Practice Threads and Tasks Susanne Cech Previtali Thomas Gross Last update: 2009-10-29, 09:12 Thread objects java.lang.thread Each thread is associated with an instance of the class

More information

CMSC 132: Object-Oriented Programming II. Threads in Java

CMSC 132: Object-Oriented Programming II. Threads in Java CMSC 132: Object-Oriented Programming II Threads in Java 1 Problem Multiple tasks for computer Draw & display images on screen Check keyboard & mouse input Send & receive data on network Read & write files

More information

CS 455: INTRODUCTION TO DISTRIBUTED SYSTEMS [THREADS] Frequently asked questions from the previous class survey

CS 455: INTRODUCTION TO DISTRIBUTED SYSTEMS [THREADS] Frequently asked questions from the previous class survey CS 455: INTRODUCTION TO DISTRIBUTED SYSTEMS [THREADS] Threads block when they can t get that lock Wanna have your threads stall? Go ahead, synchronize it all The antidote to this liveness pitfall? Keeping

More information

Parallel Programming Practice

Parallel Programming Practice Parallel Programming Practice Threads and Tasks Susanne Cech Previtali Thomas Gross Last update: 2009-10-29, 09:12 Thread objects java.lang.thread Each thread is associated with an instance of the class

More information

Java Threads. Introduction to Java Threads

Java Threads. Introduction to Java Threads Java Threads Resources Java Threads by Scott Oaks & Henry Wong (O Reilly) API docs http://download.oracle.com/javase/6/docs/api/ java.lang.thread, java.lang.runnable java.lang.object, java.util.concurrent

More information

Phaser volle Energie...

Phaser volle Energie... Phaser volle Energie...... eine Reise ins Paralleluniversum von JDK7 Hartmut Lang, Ericsson July 2011 Hartmut Lang Senior Software Developer Solution Architect Network Management and Customer Solutions

More information

Synchronization COMPSCI 386

Synchronization COMPSCI 386 Synchronization COMPSCI 386 Obvious? // push an item onto the stack while (top == SIZE) ; stack[top++] = item; // pop an item off the stack while (top == 0) ; item = stack[top--]; PRODUCER CONSUMER Suppose

More information

Multithreaded Programming Part II. CSE 219 Stony Brook University, Department of Computer Science

Multithreaded Programming Part II. CSE 219 Stony Brook University, Department of Computer Science Multithreaded Programming Part II CSE 219 Stony Brook University, Thread Scheduling In a Java application, main is a thread on its own Once multiple threads are made Runnable the thread scheduler of the

More information

Overview. CMSC 330: Organization of Programming Languages. Concurrency. Multiprocessors. Processes vs. Threads. Computation Abstractions

Overview. CMSC 330: Organization of Programming Languages. Concurrency. Multiprocessors. Processes vs. Threads. Computation Abstractions CMSC 330: Organization of Programming Languages Multithreaded Programming Patterns in Java CMSC 330 2 Multiprocessors Description Multiple processing units (multiprocessor) From single microprocessor to

More information

Concurrent Programming Benoît Garbinato

Concurrent Programming Benoît Garbinato Concurrent Programming Benoît Garbinato 1 Processes & threads A process is a unit of execution managed at the level of the operating system Each process has its own address space, i.e., no other process

More information

Only one thread can own a specific monitor

Only one thread can own a specific monitor Java 5 Notes Threads inherit their priority and daemon properties from their creating threads The method thread.join() blocks and waits until the thread completes running A thread can have a name for identification

More information

Module 6: Process Synchronization. Operating System Concepts with Java 8 th Edition

Module 6: Process Synchronization. Operating System Concepts with Java 8 th Edition Module 6: Process Synchronization 6.1 Silberschatz, Galvin and Gagne 2009 Module 6: Process Synchronization Background The Critical-Section Problem Peterson s Solution Synchronization Hardware Semaphores

More information

CPIT 305 Advanced Programming Multithreading

CPIT 305 Advanced Programming Multithreading CPIT 305 Advanced Programming Multithreading Dr. M. G. Abbas Malik Assistant Professor Faculty of Computing and IT (North Jeddah Branch) King Abdulaziz University, Jeddah, KSA mgmalik@kau.edu.sa www.sanlp.org/malik/cpit305/ap.html

More information

Multitasking Multitasking allows several activities to occur concurrently on the computer. A distinction is usually made between: Process-based multit

Multitasking Multitasking allows several activities to occur concurrently on the computer. A distinction is usually made between: Process-based multit Threads Multitasking Multitasking allows several activities to occur concurrently on the computer. A distinction is usually made between: Process-based multitasking Thread-based multitasking Multitasking

More information

Buch gefunden? Im Blackboard eingetragen? Abgabe 1. Übung: , 23:59

Buch gefunden? Im Blackboard eingetragen? Abgabe 1. Übung: , 23:59 Buch gefunden? Im Blackboard eingetragen? Abgabe 1. Übung: 09.04., 23:59 1 www.msproteomics.org Ver teil tes Rechnen und Parallelprogrammierung: Introduction to Multi-Threading in Java Based on the book

More information

Advanced Programming Concurrency

Advanced Programming Concurrency Advanced Programming Concurrency Concurrent Programming Until now, a program was a sequence of operations, executing one after another. In a concurrent program, several sequences of operations may execute

More information

Simpler, Faster, Better: Concurrency Utilities in JDK Software Version 5.0

Simpler, Faster, Better: Concurrency Utilities in JDK Software Version 5.0 Simpler, Faster, Better: Concurrency Utilities in JDK Software Version 5.0 Brian Goetz Principal Consultant, Quiotix Corp David Holmes Staff Engineer, Sun Microsystems, Inc. TS-4915 2006 JavaOne SM Conference

More information

Phaser And StampedLock Concurrency Synchronizers

Phaser And StampedLock Concurrency Synchronizers 1 Phaser And StampedLock Concurrency Synchronizers Dr Heinz M. Kabutz www.javaspecialists.eu Last updated 2013-04-23 2 Note: PDF Presentation Of The Talks What is included The slides as I presented them

More information

Overview of Java Threads (Part 2)

Overview of Java Threads (Part 2) Overview of Java Threads (Part 2) Douglas C. Schmidt d.schmidt@vanderbilt.edu www.dre.vanderbilt.edu/~schmidt Institute for Software Integrated Systems Vanderbilt University Nashville, Tennessee, USA Learning

More information

Concurrent Programming using Threads

Concurrent Programming using Threads Concurrent Programming using Threads Threads are a control mechanism that enable you to write concurrent programs. You can think of a thread in an object-oriented language as a special kind of system object

More information

EDA095 Processes and Threads

EDA095 Processes and Threads EDA095 Processes and Threads Pierre Nugues Lund University http://cs.lth.se/pierre_nugues/ March 23, 2011 Pierre Nugues EDA095 Processes and Threads March 23, 2011 1 / 71 Time-Sharing Operating Systems

More information

CMSC 330: Organization of Programming Languages

CMSC 330: Organization of Programming Languages CMSC 330: Organization of Programming Languages Multithreading Multiprocessors Description Multiple processing units (multiprocessor) From single microprocessor to large compute clusters Can perform multiple

More information

Threads and Java Memory Model

Threads and Java Memory Model Threads and Java Memory Model Oleg Šelajev @shelajev oleg@zeroturnaround.com October 6, 2014 Agenda Threads Basic synchronization Java Memory Model Concurrency Concurrency - several computations are executing

More information

The New Java Technology Memory Model

The New Java Technology Memory Model The New Java Technology Memory Model java.sun.com/javaone/sf Jeremy Manson and William Pugh http://www.cs.umd.edu/~pugh 1 Audience Assume you are familiar with basics of Java technology-based threads (

More information

Java Threads. COMP 585 Noteset #2 1

Java Threads. COMP 585 Noteset #2 1 Java Threads The topic of threads overlaps the boundary between software development and operation systems. Words like process, task, and thread may mean different things depending on the author and the

More information

EI 338: Computer Systems Engineering (Operating Systems & Computer Architecture)

EI 338: Computer Systems Engineering (Operating Systems & Computer Architecture) EI 338: Computer Systems Engineering (Operating Systems & Computer Architecture) Dept. of Computer Science & Engineering Chentao Wu wuct@cs.sjtu.edu.cn Download lectures ftp://public.sjtu.edu.cn User:

More information

Java SE 8 Programming

Java SE 8 Programming Oracle University Contact Us: +52 1 55 8525 3225 Java SE 8 Programming Duration: 5 Days What you will learn This Java SE 8 Programming training covers the core language features and Application Programming

More information

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, Part 3 Can't live with it. Cant live without it.

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, Part 3 Can't live with it. Cant live without it. Principles of Software Construction: Objects, Design and Concurrency 15-214 toad The Perils of Concurrency, Part 3 Can't live with it. Cant live without it. Fall 2013 Jonathan Aldrich Charlie Garrod School

More information

Java SE 8 Programming

Java SE 8 Programming Oracle University Contact Us: Local: 1800 103 4775 Intl: +91 80 67863102 Java SE 8 Programming Duration: 5 Days What you will learn This Java SE 8 Programming training covers the core language features

More information

Java Barrier Synchronizers: CyclicBarrier (Part 1)

Java Barrier Synchronizers: CyclicBarrier (Part 1) Java Barrier Synchronizers: CyclicBarrier (Part 1) Douglas C. Schmidt d.schmidt@vanderbilt.edu www.dre.vanderbilt.edu/~schmidt Institute for Software Integrated Systems Vanderbilt University Nashville,

More information

Dr. Rafiq Zakaria Campus. Maulana Azad College of Arts, Science & Commerce, Aurangabad. Department of Computer Science. Academic Year

Dr. Rafiq Zakaria Campus. Maulana Azad College of Arts, Science & Commerce, Aurangabad. Department of Computer Science. Academic Year Dr. Rafiq Zakaria Campus Maulana Azad College of Arts, Science & Commerce, Aurangabad Department of Computer Science Academic Year 2015-16 MCQs on Operating System Sem.-II 1.What is operating system? a)

More information

Programmazione Avanzata e Paradigmi Ingegneria e Scienze Informatiche - UNIBO a.a 2013/2014 Lecturer: Alessandro Ricci

Programmazione Avanzata e Paradigmi Ingegneria e Scienze Informatiche - UNIBO a.a 2013/2014 Lecturer: Alessandro Ricci v1.0 20130323 Programmazione Avanzata e Paradigmi Ingegneria e Scienze Informatiche - UNIBO a.a 2013/2014 Lecturer: Alessandro Ricci [module lab 2.1] CONCURRENT PROGRAMMING IN JAVA: INTRODUCTION 1 CONCURRENT

More information

Java SE 8 Programming

Java SE 8 Programming Java SE 8 Programming Training Calendar Date Training Time Location 16 September 2019 5 Days Bilginç IT Academy 28 October 2019 5 Days Bilginç IT Academy Training Details Training Time : 5 Days Capacity

More information

Virtual Machine Design

Virtual Machine Design Virtual Machine Design Lecture 4: Multithreading and Synchronization Antero Taivalsaari September 2003 Session #2026: J2MEPlatform, Connected Limited Device Configuration (CLDC) Lecture Goals Give an overview

More information

Network Applications: High-Performance Network Servers

Network Applications: High-Performance Network Servers Network Applications: High-Performance Network Servers Y. Richard Yang http://zoo.cs.yale.edu/classes/cs433/ 10/01/2013 Outline Ø Admin and recap High performance servers Thread Per-request thread Thread

More information

Synchronization

Synchronization Synchronization 10-28-2013 Synchronization Coming next: Multithreading in JavaFX (javafx.concurrent) Read: Java Tutorial on concurrency JavaFX Tutorial on concurrency Effective Java, Chapter 9 Project#1:

More information

Semaphore. Originally called P() and V() wait (S) { while S <= 0 ; // no-op S--; } signal (S) { S++; }

Semaphore. Originally called P() and V() wait (S) { while S <= 0 ; // no-op S--; } signal (S) { S++; } Semaphore Semaphore S integer variable Two standard operations modify S: wait() and signal() Originally called P() and V() Can only be accessed via two indivisible (atomic) operations wait (S) { while

More information

Programmazione Avanzata e Paradigmi Ingegneria e Scienze Informatiche - UNIBO a.a 2013/2014 Lecturer: Alessandro Ricci

Programmazione Avanzata e Paradigmi Ingegneria e Scienze Informatiche - UNIBO a.a 2013/2014 Lecturer: Alessandro Ricci v1.0 20130510 Programmazione Avanzata e Paradigmi Ingegneria e Scienze Informatiche - UNIBO a.a 2013/2014 Lecturer: Alessandro Ricci [module lab 3.1] TASK FRAMEWORKS 1 STRUCTURING CONCURRENT PROGRAMS INTO

More information

Time-Sharing Operating Systems. EDA095 Processes and Threads. Process Creation. The Content of a Process

Time-Sharing Operating Systems. EDA095 Processes and Threads. Process Creation. The Content of a Process Time-Sharing Operating Systems EDA095 Processes and Threads Pierre Nugues Lund University http://cs.lth.se/pierre_nugues/ Processes are programs in execution Most operating systems can run multiple processes

More information

Summary Semaphores. Passing the Baton any await statement. Synchronisation code not linked to the data

Summary Semaphores. Passing the Baton any await statement. Synchronisation code not linked to the data Lecture 4 Monitors Summary Semaphores Good news Simple, efficient, expressive Passing the Baton any await statement Bad news Low level, unstructured omit a V: deadlock omit a P: failure of mutex Synchronisation

More information

G Programming Languages Spring 2010 Lecture 13. Robert Grimm, New York University

G Programming Languages Spring 2010 Lecture 13. Robert Grimm, New York University G22.2110-001 Programming Languages Spring 2010 Lecture 13 Robert Grimm, New York University 1 Review Last week Exceptions 2 Outline Concurrency Discussion of Final Sources for today s lecture: PLP, 12

More information

Producing Production Quality Software. Lecture 12: Concurrent and Distributed Programming Prof. Arthur P. Goldberg Fall, 2004

Producing Production Quality Software. Lecture 12: Concurrent and Distributed Programming Prof. Arthur P. Goldberg Fall, 2004 Producing Production Quality Software Lecture 12: Concurrent and Distributed Programming Prof. Arthur P. Goldberg Fall, 2004 Topics Models of concurrency Concurrency in Java 2 Why Use Concurrency? Enable

More information

SUMMARY FUTURES CALLABLES CONCURRENT PROGRAMMING THREAD S ADVANCED CONCEPTS

SUMMARY FUTURES CALLABLES CONCURRENT PROGRAMMING THREAD S ADVANCED CONCEPTS SUMMARY CONCURRENT PROGRAMMING THREAD S ADVANCED CONCEPTS Callable tasks Futures Executors Executor services Deadlocks PROGRAMMAZIONE CONCORRENTE E DISTR. Università degli Studi di Padova Dipartimento

More information

Threads in Java. Threads (part 2) 1/18

Threads in Java. Threads (part 2) 1/18 in Java are part of the Java language. There are two ways to create a new thread of execution. Declare a class to be a subclass of Thread. This subclass should override the run method of class Thread.

More information

Java Concurrency in practice Chapter 9 GUI Applications

Java Concurrency in practice Chapter 9 GUI Applications Java Concurrency in practice Chapter 9 GUI Applications INF329 Spring 2007 Presented by Stian and Eirik 1 Chapter 9 GUI Applications GUI applications have their own peculiar threading issues To maintain

More information

EMBEDDED SYSTEMS PROGRAMMING More About Languages

EMBEDDED SYSTEMS PROGRAMMING More About Languages EMBEDDED SYSTEMS PROGRAMMING 2015-16 More About Languages JAVA: ANNOTATIONS (1/2) Structured comments to source code (=metadata). They provide data about the code, but they are not part of the code itself

More information

Java Concurrency For Humans. Cay Horstmann Author of Core Java (10 editions since 1996)

Java Concurrency For Humans. Cay Horstmann Author of Core Java (10 editions since 1996) Java Concurrency For Humans Cay Horstmann Author of Core Java (10 editions since 1996) Outline Audience: Application programmers Goal: Modern Concurrency Constructs Executors and Futures Asynchronous Processing

More information

-Aditya Bhave CSCI-5448 Graduate Presentation

-Aditya Bhave CSCI-5448 Graduate Presentation -Aditya Bhave CSCI-5448 Graduate Presentation 04-01-2011 MSEE at CU finishing up in Summer 11 Work full time at Alticast Inc Background in Embedded Systems Media Processing Middleware Cable TV industry

More information

Contents. G53SRP: Java Threads. Definition. Why we need it. A Simple Embedded System. Why we need it. Java Threads 24/09/2009 G53SRP 1 ADC

Contents. G53SRP: Java Threads. Definition. Why we need it. A Simple Embedded System. Why we need it. Java Threads 24/09/2009 G53SRP 1 ADC Contents G53SRP: Java Threads Chris Greenhalgh School of Computer Science 1 Definition Motivations Threads Java threads Example embedded process Java Thread API & issues Exercises Book: Wellings 1.1 &

More information

Threads and Parallelism in Java

Threads and Parallelism in Java Threads and Parallelism in Java Java is one of the few main stream programming languages to explicitly provide for user-programmed parallelism in the form of threads. A Java programmer may organize a program

More information

CS 351 Design of Large Programs Threads and Concurrency

CS 351 Design of Large Programs Threads and Concurrency CS 351 Design of Large Programs Threads and Concurrency Brooke Chenoweth University of New Mexico Spring 2018 Concurrency in Java Java has basic concurrency support built into the language. Also has high-level

More information

Overview. Processes vs. Threads. Computation Abstractions. CMSC 433, Fall Michael Hicks 1

Overview. Processes vs. Threads. Computation Abstractions. CMSC 433, Fall Michael Hicks 1 CMSC 433 Programming Language Technologies and Paradigms Spring 2003 Threads and Synchronization April 1, 2003 Overview What are threads? Thread scheduling, data races, and synchronization Thread mechanisms

More information

Programmers and Parallelism

Programmers and Parallelism Programmers and Parallelism Milan Potdar Computer Science Department San Jose State University San Jose, CA 95192 408-924-1000 milan.potdar@gmail.com ABSTRACT A programmer writes programs which can be

More information

Concurrent Programming

Concurrent Programming Concurrency Concurrent Programming A sequential program has a single thread of control. Its execution is called a process. A concurrent program has multiple threads of control. They may be executed as

More information

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, part 4 Can't live with it. Can't live without it.

Principles of Software Construction: Objects, Design and Concurrency. The Perils of Concurrency, part 4 Can't live with it. Can't live without it. Principles of Software Construction: Objects, Design and Concurrency 15-214 toad The Perils of Concurrency, part 4 Can't live with it. Can't live without it. Fall 2012 Jonathan Aldrich Charlie Garrod School

More information

re-exam Concurrent Programming tda383/dit390 Date: Time: 14:00 18:00 Place: Maskinhuset (M)

re-exam Concurrent Programming tda383/dit390 Date: Time: 14:00 18:00 Place: Maskinhuset (M) re-exam Concurrent Programming tda383/dit390 Date: 2016-08-22 Time: 14:00 18:00 Place: Maskinhuset (M) Responsible Michał Pałka 031 772 10 79 Result Available no later than 2016-09-12 Aids Max 2 books

More information

Midterm Exam. October 20th, Thursday NSC

Midterm Exam. October 20th, Thursday NSC CSE 421/521 - Operating Systems Fall 2011 Lecture - XIV Midterm Review Tevfik Koşar University at Buffalo October 18 th, 2011 1 Midterm Exam October 20th, Thursday 9:30am-10:50am @215 NSC Chapters included

More information

Multi-threaded programming in Java

Multi-threaded programming in Java Multi-threaded programming in Java Java allows program to specify multiple threads of execution Provides instructions to ensure mutual exclusion, and selective blocking/unblocking of threads What is a

More information

CS 159: Parallel Processing

CS 159: Parallel Processing Outline: Concurrency using Java CS 159: Parallel Processing Spring 2007 Processes vs Threads Thread basics Synchronization Locks Examples Avoiding problems Immutable objects Atomic operations High"level

More information

Java Threads Vs Processes. CS Concurrent Programming. Java Threads. What can a thread do? Java Concurrency

Java Threads Vs Processes. CS Concurrent Programming. Java Threads. What can a thread do? Java Concurrency Java Threads Vs Processes CS6868 - Concurrent Programming Java Concurrency V. Krishna Nandivada Typically each instance of JVM creates a single process. Each process creates one or more threads. Main thread

More information

CONCURRENCY IN JAVA Course Parallel Computing

CONCURRENCY IN JAVA Course Parallel Computing CONCURRENCY IN JAVA Course Parallel Computing Wolfgang Schreiner Research Institute for Symbolic Computation (RISC) Wolfgang.Schreiner@risc.jku.at http://www.risc.jku.at Java on a NUMA Architecture Loading

More information