This document discusses Java concurrency. It begins with an agenda and then covers key topics like shared state, thread safety, concurrency problems and symptoms, and Java concurrency methods. Facts about processors, caches and memory interactions that can impact concurrency are presented. Examples are provided to illustrate concurrency issues like visibility and atomicity. Common concurrency problems like invalid states and their symptoms are outlined. Finally, Java concurrency methods like thread confinement, immutability, volatile variables, and synchronized are defined and code examples are shown.