An Introduction to Python Concurrency
An Introduction to Python
Concurrency
David Beazley
Presented at USENIX Technical Conference
San Diego, June, 2009
Copyright (C) 2009, David Beazley,
1
This Tutorial
? Python : An interpreted high-level programming
language that has a lot of support for "systems
programming" and which integrates well with
existing software in other languages.
? Concurrency : Doing more than one thing at a
time. Of particular interest to programmers
writing code for running on big iron, but also of
interest for users of multicore PCs. Usually a
bad idea--except when it's not.
Copyright (C) 2009, David Beazley,
2
Support Files
? Code samples and support files for this class
? Please go there and follow along
Copyright (C) 2009, David Beazley,
3
An Overview
? We're going to explore the state of concurrent
programming idioms being used in Python
? A look at tradeoffs and limitations
? Hopefully provide some clarity
? A tour of various parts of the standard library
? Goal is to go beyond the user manual and tie
everything together into a "bigger picture."
Copyright (C) 2009, David Beazley,
4
Disclaimers
? The primary focus is on Python
? This is not a tutorial on how to write
concurrent programs or parallel algorithms
? No mathematical proofs involving "dining
philosophers" or anything like that
? I will assume that you have had some prior
exposure to topics such as threads, message
passing, network programming, etc.
Copyright (C) 2009, David Beazley,
5
Disclaimers
? I like Python programming, but this tutorial is
not meant to be an advocacy talk
? In fact, we're going to be covering some
pretty ugly (e.g., "sucky") aspects of Python
? You might not even want to use Python by
the end of this presentation
? That's fine... education is my main agenda.
Copyright (C) 2009, David Beazley,
6
Part I
Some Basic Concepts
Copyright (C) 2009, David Beazley,
7
Concurrent Programming
? Creation of programs that can work on
more than one thing at a time
? Example : A network server that
communicates with several hundred clients
all connected at once
? Example : A big number crunching job that
spreads its work across multiple CPUs
Copyright (C) 2009, David Beazley,
8
Multitasking
? Concurrency typically implies "multitasking"
Task A:
run
run
run
task switch
Task B:
run
run
? If only one CPU is available, the only way it
can run multiple tasks is by rapidly switching
between them
9
Copyright (C) 2009, David Beazley,
Parallel Processing
? You may have parallelism (many CPUs)
? Here, you often get simultaneous task execution
Task A:
Task B:
run
run
run
run
run
run
CPU 1
CPU 2
? Note: If the total number of tasks exceeds the
number of CPUs, then each CPU also multitasks
Copyright (C) 2009, David Beazley,
10
................
................
In order to avoid copyright disputes, this page is only a partial summary.
To fulfill the demand for quickly locating and searching documents.
It is intelligent file search solution for home and business.
Related download
- high performance computing in python using numpy and the
- cmps 401 survey of programming languages
- an introduction to python concurrency
- practical computing for biologists duke university
- cs 1301 study guide
- a python book beginning python advanced python and
- python websitesetup
- practical python programming
- python practice book read the docs
- black hat python olinux
Related searches
- an introduction to marketing pdf
- an introduction to moral philosophy
- an introduction to business
- an introduction to r pdf
- an introduction to an essay
- an introduction to linguistics
- an introduction to formal logic
- an introduction to information retrieval
- an introduction to hazardous materials
- an introduction to literature pdf
- an introduction to community development
- chapter 8 an introduction to metabolism key