Search our courses

This Advanced Unix Programmingan an in-depth training course for software developers on UNIX system programming facilities. Learn how to develop sophisticated multi-process applications using system calls and library routines.

Advanced Unix Programming

Course Code



4 Days

Course Fee




Target Audience

  • Application developers who will be writing advanced programs on UNIX. Please contact us for further details.

Attendee Requirements

Fundamentals of UNIX as well as strong C programming skills are required for this course. These skills are taught in the following GuruTeam courses (or similar training programmes)

If you have any questions or doubts as to whether you meet the pre-requisites for this course, or indeed are wondering which course best suits you, please contact us to discuss your suitability for course attendance.

We are sorry, there is currently no availability on this course.

contact us for more information

Ways to Attend this Course

  • In the Classroom
  • Private Training

Expand all

Course Description

This Advanced Unix Programmingan an in-depth training course for software developers on UNIX system programming facilities. Learn how to develop sophisticated multi-process applications using system calls and library routines.

Course Outline

1. Course Introduction

Course Objectives

Course Overview

Using the Workbook

Suggested References

2. UNIX Standards

Brief History of UNIX

AT&T and Berkeley UNIX Systems

Major Vendors

What is a Standard?

What is POSIX?

Other Industry Specs and Standards

Library vs. System-Level Functions

3. Files and Directories

Basic File Types

File Descriptors

The open() and creat() Functions

Keeping Track of Open Files

File Table Entries

The v-node Structure

The fcntl Function

The fcntl() Function – with F_DUPFD Command

File Attributes

The access() Function

link(), unlink(), remove(), and rename() Functions

Functions to Create, Remove, and Read Directories

4. System I/O

Standard I/O vs System I/O

System I/O Calls

File and Record Locking

5. Processes

What is a Process?

Process Creation and Termination

Process Memory Layout

Dynamic Memory Allocation

Accessing Environment Variables

Real and Effective User IDs

6. Process Management

The Difference Between Programs and Processes

The fork() System Function

Parent and Child

The exec System Function

Current Image and New Image

The wait() and waitpid() Function

Interpreter files and exec

7. Basic Interprocess Communication: Pipes

Interprocess Communication



8. Signals

What is a Signal?

Types of Signals

Signal Action

Blocking Signals from Delivery

The sigaction() Function

Signal Sets and Operations

Sending a Signal to Another Process

Blocking Signals with sigprocmask()

Scheduling and Waiting for Signals

Restarting System Calls (SVR4)

Signals and Reentrancy

9. Introduction to Pthreads

Processes and Threads

Creating Threads


Overview of Thread Architectures

Processes Versus Threads

The Pthreads API

Thread Termination

Joining Threads

Detaching Threads

Passing Arguments to Threads

10. Pthreads Synchronization

The Sharing Problem


Creating and Initializing Mutexes

Using Mutexes

Additional Synchronization Requirement

Using Condition Variables

11. Overview of Client/Server Programming

Designing Applications for a Distributed Environment

Clients and Servers

Ports and Services

Connectionless vs. Connection-Oriented Servers

Stateless vs. Stateful Servers

Concurrency Issues

12. The Berkeley Sockets API

Berkeley Sockets

Data Structures of the Sockets API

Socket System Calls

Socket Utility Functions

13. TCP Client Design

Algorithms Instead of Details

Client Architecture

Generic Client/Server Model – TCP

The TCP Client Algorithm

14. TCP Server Design

General Concepts

Iterative Servers

Concurrent Servers

Performance Consideration

An Iterative Server Design

A Concurrent Server Design

15. System V Interprocess Communication

System V IPC

Elements Common to msg, shm, and sem Facilities

The Three System V IPC Facilities

IPC via Message Queues

IPC via Shared Memory

Coordinating the Use of Shared Memory Segments

Semaphore Sets – emget()

Semaphore Sets – semctl()

Semaphore Sets – the semop() calls

Shared Memory Coordination Using Semaphores

Commands for IPC Facility Handling – ipcs and ipcrm

16. Appendix A – Date and Time Functions


Time Representations

Decoding Calendar Time

Shorthand Functions – asctime(), ctime()

Formatting Date and Time Strings

Process Times

The Difference Between clock() and times()

Berkeley High Resolution Timers

17. Appendix B – Standard I/O

Standard I/O Calls to manipulate streams

Standard I/O Calls which perform character I/O

Standard I/O Calls which perform string I/O

Standard I/O Calls Which Perform Formatted I/O

Standard I/O Calls Which Perform Binary I/O

Learning Path
  • There are a number of options of suitable follow-on courses, depending on your business needs. Please contact us for further details.
Ways to Attend
  • Attend a public course, if there is one available. Please check our schedule, or register your interest in joining a course in your area.
  • Private onsite Team training also available, please contact us to discuss. We can customise this course to suit your business requirements.

Sorry, we are not taking bookings on this course at present

If you would like to contact us for more information on this course, you may do so here:

Contact us

Technical ICT learning & mentoring services

Private Team Training

Our instructors are specialist consultants with vast real world experience and expertise allowing them to design and deliver client-focused courses for your organisation.

Learn more about our Private Team Training

What Our Clients Say

“Very interesting course from an excellent instructor. Highly technical and well delivered”


Introduction to Modern Security - GTJ50

Dec '17

“Super experience. The instructor spoke with great knowledge and experience. The materials will be invaluable in the real world”


Professional Cloud Service Manager Certification training- GTC13

Dec '17

“Very useful course, making complex topics more approachable and the instructor was very good at getting concepts across and engaging with delegates and our specific needs”


Optimising Java - GTJ47

Dec '17

“This was an excellent course and I found it very interesting and enjoyable.  The instructor was a font of knowledge on all aspects of Big Data and Analytics and was enthusiastic about sharing his knowledge”


Applied Data Science and Big Data Analytics - GTBD7

Nov '17

“The instructor was fantastic at explaining lessons with applicable work type examples.  He was enthusiastic with what he was teaching which made learning the course more enjoyable”


Linux Essentials Certification - GTU2

Oct '17

"Intelligence is the ability to avoid doing work, yet
getting the work done"

Linus Torvalds, creator of Linux and GIT

Technical ICT learning & mentoring services

About GuruTeam

GuruTeam is a high-level ICT Learning, Mentoring and Consultancy services company. We specialise in delivering instructor-led on and off-site training in Blockchain, Linux, Cloud, Big Data, DevOps, Kubernetes, Agile, Software & Web Development technologies. View our Testimonials

Download our eBrochure
Our Accreditation Partners
Upcoming Courses

Kubernetes Administration

19 - 22 Mar - LONDON

1 - 4 Apr - DUBLIN

This Kubernetes Administration Certification training course is suitable for anyone who wants to learn the skills necessary to build and administer a Kubernetes cluster

Learn More

CompTIA Network+ FastTrack

11 - 13 Mar


This fast-paced course teaches the essentials of networking and helps to prepare the student for the CompTIA Network+ certification.

Learn More

Cloud Service Manager

29 - 31 Jan


ITIL in the Cloud certification training, accredited by the Cloud Credential Council

Learn More

Introduction to Python 3

11 - 13 Mar


Python is a powerful and popular object-oriented programming/scripting language with many high quality libraries.

Learn More


Stay up to date, receive updates on scheduled dates, new courses, offers, and events.

Subscribe to our Newsletter