Difference between revisions of "Java Concurrency"

From Suhrid.net Wiki
Jump to navigationJump to search
m (moved CRTP to Java Concurrency)
Line 14: Line 14:
 
** Multiprocessing: Multiple processes multiplex their executions on a a multiprocessor system where there is access to shared memory.
 
** Multiprocessing: Multiple processes multiplex their executions on a a multiprocessor system where there is access to shared memory.
 
** Distributed processing: Multiple processes multiplex their executions on several processors where they do not share memory.
 
** Distributed processing: Multiple processes multiplex their executions on several processors where they do not share memory.
 +
 +
= Java Concurrency =
 +
 +
* Java supports threads.
 +
* In the native model, each Java thread maps to a single OS thread.
 +
* In the green thread model, threads are invisible to the OS. The thread library handles all the threading.
  
 
= Real time systems =
 
= Real time systems =

Revision as of 16:54, 23 December 2011

Concurrent Programming

  • The name given to programming notations and techniques to express potential parallelism and solve the resulting communication and synchronization problems.
  • Why do we need it ? To allow the expression of potential parallelism so that more than CPU can solve the problem.
  • To model the parallelism in the real world.
  • Alternative is difficult: programmer must construct sequential program as a cyclic execution of task to handle various concurrent activities.
  • This make programming difficult and introduction of structures which are irrelevant to the problem at hand.
  • Parallel execution on multiple CPU's is difficult.
  • A concurrent program is a collection of autonomous sequential processes executing logically in parallel.
  • Each process has a single thread of control.
  • The actual implementation of these collection of processes can be via:
    • Multiprogramming: Multiple processes multiplex their executions on a single processor.
    • Multiprocessing: Multiple processes multiplex their executions on a a multiprocessor system where there is access to shared memory.
    • Distributed processing: Multiple processes multiplex their executions on several processors where they do not share memory.

Java Concurrency

  • Java supports threads.
  • In the native model, each Java thread maps to a single OS thread.
  • In the green thread model, threads are invisible to the OS. The thread library handles all the threading.

Real time systems

  • A real time system is any system which has to respond to a stimuli within a finite and specified period.
  • The correctness depends on both the result and the time it was delivered.
  • Failure to respond is as bad as the wrong response.
  • Types of real time systems
    • Hard real-time — systems where it is absolutely imperative that responses occur within the required deadline. E.g. Flight control systems.
    • Soft real-time — systems where deadlines are important but which will still function correctly if deadlines are occasionally missed. E.g. Data acquisition system.
    • Firm real-time — systems which are soft real-time but in which there is no benefit from late delivery of service.

Characteristics of RTS

  • Concurrent control of separate system components.
  • Facilities to interact with special purpose hardware.
  • Extreme reliability and safe.
  • Guaranteed response times.