Class Lectures and Reading Assignments 
This page documents what we do in class. It contains code that we will discuss in class, reading assignments, simple homework exercises that you can work on for practice and exam preparation (not for credit), links to other sources of information, etc.
Wednesday, April 29. Here is the exam/homework assignment. Follow the directions in the pdf document. This is due in Blackboard on Friday, May 8.
  
Here is a link to today's video lecture.
  
Here is the updated code for doing serial and parallel searches on either one large data file or a large collection of data files. I've included timing information from my computer on the data linked to below.
  
Here are links to the 2.3 GB of data I used, both as one big file and as 1,000 individual files, and also Andrew's original data set.
  
 
Monday, April 27. Here is a link to today's video lecture.
  
Here is an exam/homework assignment. Follow the directions in the pdf document. This is due in Blackboard on Friday, May 8.
  
 
Wednesday, April 22. Here is a link to today's video lecture.
  
Here is a link to the 2.3GB collection of 1,000 text files that I used for the in class experiments.
  
Here is the updated code for doing serial and parallel searches on either one large data file or a large collection of data files.
  
 
Monday, April 20. Here is a link to today's video lecture.
  
I have tried to reorganize the code that we have been looking at lately. I've divided the code into four folders
  
For some of this code, it helps to have large amounts of data to run the code on. Here are links to Andrew's collection of text files and also the 2.3GB data file that I have been using for in class experiments.
  
 
Wednesday, April 15. Here is a link to today's video lecture.
  
 
Monday, April 13. Here is a link to today's video lecture.
  
Here is the updated futures and thread pool code from today's lecture.
  
 
Wednesday, April 8. Here is a link to today's video lecture.
  
Here is the updated futures and thread pool code from today's lecture.
  
 
Monday, April 6. Here is a link to today's video lecture.
  
Here are the notes and code from today's lecture.
  
 
Wednesday, April 1. Here is a link to today's video lecture.
  
 
Monday, March 30. Here is a link to today's video lecture.
  
Here is a second copy of the fork/join code. Hopefully this copy will download correctly.
  
 
Wednesday, March 25. Here are links to the video lectures from this week.
  
 
Monday, March 23. 
Our class will meet at 6:30 using the Zoom  application. Here is an invite link to the class meeting.
  
Read the following two articles about Fork/Join.
 
Wednesday, March 18. Spring Break - No class today.
 
Monday, March 16. Spring Break - No class today.
 
Wednesday, March 11. Read each of the following pairs of a discussion followed be a research paper.
Read Sections 3 and 4 (pages 14-30 and 36-43) on Java concurrency from the following.
  
We will look at the fork-join examples from the following zip file.
  
 
Monday, March 9. The code in this zip file demonstrate three ways to do simultaneous I/O, polling, events, and threads.
The following zip file explains inter-process communication using pipes with Linux, Windows and Java.
 
Wednesday, February 19. The code in these zip files demonstrate the producer/consumer  pattern (also called the "bounded buffer").
Here are explanations of the producer/consumer pattern using condition variables and semaphores (using pthreads) from this operating systems textbook .
 
Monday, February 17. Read Chapter 4 from the book The Well-Grounded Java Developer .
 
Wednesday, February 12. The code in this zip file demonstrates the idea of "false sharing".
 
Monday, February 10. We will look at the code from the following zip file.
 
Wednesday, February 5. We will look at the code from the following zip file.
 
Monday, January 27. We will look at the code from the following zip file.
 
Monday, January 20. No class today, Martin Luther King Jr. Day.
 
Wednesday, January 15. Read the following two chapters about Pthreads from this operating systems  textbook.
 
Monday, January 13. Read the following two introductions to Java threads.
Here are a few more introductions to Java threads that you might find useful.
We will look at the code from the following file.