Welcome to the Intel® Software Dispatch Subscription Program

POSIX Threads Programming
Unix Thread Creation Tutorial: In shared memory multiprocessor architectures, such as SMPs, threads can be used to implement parallelism. Historically, hardware vendors have implemented their own proprietary versions of threads, making portability a concern for software developers. For UNIX systems, a standardized C language threads programming interface has been specified by the IEEE POSIX 1003.1c standard.

Abstract

In shared memory multiprocessor architectures, such as SMPs, threads can be used to implement parallelism. Historically, hardware vendors have implemented their own proprietary versions of threads, making portability a concern for software developers. For UNIX systems, a standardized C language threads programming interface has been specified by the IEEE POSIX 1003.1c standard. Implementations that adhere to this standard are referred to as POSIX threads, or Pthreads.

The tutorial begins with an introduction to concepts, motivations, and design considerations for using Pthreads. Each of the three major classes of routines in the Pthreads API are then covered: Thread Management, Mutex Variables, and Condition Variables. Example codes are used throughout to demonstrate how to use most of the Pthreads routines needed by a new Pthreads programmer. The tutorial concludes with a discussion and examples of how to develop hybrid MPI/Pthreads programs in an IBM SMP environment. A lab exercise, with numerous example codes (C Language) is also included.

Read Tutorial here.


If you're interested in this topic, these articles may be helpful:

The "Rich-Client" Advantage for .NET Web Services
by Dan Fineberg, enterprise/business marketing manager, and Gary Hayco...
Intel® Threading Tools Boost Performance for CPU Cycle-Hungry Digital Artists
Introduction Intel ® Threading Tools help Autodesk optimize its M...
Multithreaded Technology and Multi-Core Processors
Introduction by Craig Szydlowski Infrastructure Processor Divi...
Intel® Tools Make Threading Easier on Multiple Processors
Introduction Intel® Thread Profiler, Intel® Thread Checker,...
Getting Started with OpenMP*
Abstract By Richard Gerber As you probably know by now, to get the m...

Related Jobs:

Software Development Engineer #136377 - WA - Redmond - Microsoft Corporation
Just how fast can you make mathematical code run? Multimedia compre...
Software Development Engineer #137943 - WA - Mountain View - Microsoft Corporation
Hate spam? Love designing solutions to hard problems in a high perform...
PL/SQL Developer #2339347 - NC - Charlotte - Ajilon
Description : If you're an IT professional looking for exciting, new...
Software Development Engineer #138950 - WA - Redmond - Microsoft Corporation
Do you want to be a part of future and bring Real-time audio and video...
Associate Software Engineer - CA - Santa Clara - Willow Technology, Inc.
We are looking for a software engineer with tremendous potential for ...
Senior Audio Systems Engineer #977 - CA - Milpitas - PalmOne, Inc.
Senior Audio Systems Engineer Job code: 977 Job Category: Engineerin...
Software Development Engineer #146359 - WA - Redmond - Microsoft Corporation
Would you like to work on an exciting V1 project? Would you like to de...
Software Development Engineer #146357 - WA - Redmond - Microsoft Corporation
Would you like to work on an exciting V1 project? Would you like to de...
Software Development Engineer #135603 - WA - Redmond - Microsoft Corporation
The Real-time Media development team is looking for an SDE to help bui...
Software Development Engineer #136658 - WA - Redmond - Microsoft Corporation
Just how fast can you make mathematical code run? Multimedia compre...