Programming Erlang, Second Edition Software for a Concurrent World by Joe Armstrong Version: P1.0 (August 2013) Copyright © 2013 Pragmatic Programmers, LLC. This book is licensed to the individual who purchased it. We don't copy-protect it because that would limit your ability to use it for your own purposes. Please don't break this trust—you can use this across all of your devices but please do not share this copy with other members of your team, with friends, or via file sharing services. Thanks. —Dave & Andy. Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in this book, and The Pragmatic Programmers, LLC was aware of a trademark claim, the designations have been printed in initial capital letters or in all capitals. The Pragmatic Starter Kit, The Pragmatic Programmer, Pragmatic Programming, Pragmatic Bookshelf and the linking g device are trademarks of The Pragmatic Programmers, LLC. Every precaution was taken in the preparation of this book. However, the publisher assumes no responsibility for errors or omissions, or for damages that may result from the use of information (including program listings) contained herein. Our Pragmatic courses, workshops, and other products can help you and your team create better software and have more fun. For more information, as well as the latest Pragmatic titles, please visit us at http://pragprog.com. Table of Contents Introduction What’s This Book About? Who Is This Book For? New in This Edition Road Map The Code in This Book Help! It Doesn’t Work Acknowledgments I. Why Erlang? 1. Introducing Concurrency 1.1Modeling Concurrency 1.2Benefits of Concurrency 1.3Concurrent Programs and Parallel Computers 1.4Sequential vs. Concurrent Programming Languages 2. A Whirlwind Tour of Erlang 2.1The Shell 2.2Processes, Modules, and Compilation 2.3Hello, Concurrency II. Sequential Programming 3. Basic Concepts 3.1Starting and Stopping the Erlang Shell 3.2Simple Integer Arithmetic 3.3Variables 3.4Floating-Point Numbers 3.5Atoms 3.6Tuples 3.7Lists 3.8Strings 3.9Pattern Matching Again 4. Modules and Functions 4.1Modules Are Where We Store Code 4.2Back to Shopping 4.3Funs: The Basic Unit of Abstraction 4.4Simple List Processing 4.5List Comprehensions 4.6BIFs 4.7Guards 4.8case and if Expressions 4.9Building Lists in Natural Order 4.10Accumulators 5. Records and Maps 5.1When to Use Maps or Records 5.2Naming Tuple Items with Records 5.3Maps: Associative Key-Value Stores 6. Error Handling in Sequential Programs 6.1Handling Errors in Sequential Code 6.2Trapping an Exception with try…catch 6.3Trapping an Exception with catch 6.4Programming Style with Exceptions 6.5Stack Traces 6.6Fail Fast and Noisily, Fail Politely 7. Binaries and the Bit Syntax 7.1Binaries 7.2The Bit Syntax 7.3Bitstrings: Processing Bit-Level Data 8. The Rest of Sequential Erlang 8.1apply 8.2Arithmetic Expressions 8.3Arity 8.4Attributes 8.5Block Expressions 8.6Booleans 8.7Boolean Expressions 8.8Character Set 8.9Comments 8.10Dynamic Code Loading 8.11 Erlang Preprocessor 8.12Escape Sequences 8.13Expressions and Expression Sequences 8.14Function References 8.15Include Files 8.16List Operations ++ and - - 8.17Macros 8.18Match Operator in Patterns 8.19Numbers 8.20Operator Precedence 8.21The Process Dictionary 8.22References 8.23Short-Circuit Boolean Expressions 8.24Term Comparisons 8.25Tuple Modules 8.26Underscore Variables 9. Types 9.1Specifying Data and Function Types 9.2Erlang Type Notation 9.3A Session with the Dialyzer 9.4Type Inference and Success Typing 9.5Limitations of the Type System 10. Compiling and Running Your Program 10.1Modifying the Development Environment 10.2Different Ways to Run Your Program 10.3Automating Compilation with Makefiles 10.4When Things Go Wrong 10.5Getting Help 10.6Tweaking the Environment III. Concurrent and Distributed Programs 11. Real-World Concurrency 12. Concurrent Programming 12.1The Concurrency Primitives 12.2Introducing Client-Server 12.3Processes Are Cheap 12.4Receive with a Timeout 12.5Selective Receive 12.6Registered Processes 12.7A Word About Tail Recursion 12.8Spawning with MFAs or Funs 13. Errors in Concurrent Programs 13.1Error Handling Philosophy 13.2Error Handling Semantics 13.3Creating Links 13.4Groups of Processes That All Die Together 13.5Setting Up a Firewall 13.6Monitors 13.7Error Handling Primitives 13.8Programming for Fault Tolerance 14. Distributed Programming 14.1Two Models for Distribution 14.2Writing a Distributed Program 14.3Building the Name Server 14.4Libraries and BIFS for Distributed Programming 14.5The Cookie Protection System 14.6Socket-Based Distribution IV. Programming Libraries and Frameworks 15. Interfacing Techniques 15.1How Erlang Communicates with External Programs 15.2Interfacing an External C Program with a Port 15.3Calling a Shell Script from Erlang 15.4Advanced Interfacing Techniques 16. Programming with Files 16.1Modules for Manipulating Files 16.2Ways to Read a File 16.3Ways to Write a File 16.4Directory and File Operations 16.5Bits and Pieces 16.6A Find Utility 17. Programming with Sockets 17.1Using TCP 17.2Active and Passive Sockets 17.3Error Handling with Sockets 17.4UDP 17.5Broadcasting to Multiple Machines 17.6A SHOUTcast Server 18. Browsing with Websockets and Erlang 18.1Creating a Digital Clock 18.2Basic Interaction 18.3An Erlang Shell in the Browser 18.4Creating a Chat Widget 18.5IRC Lite 18.6Graphics in the Browser 18.7The Browser Server Protocol 19. Storing Data with ETS and DETS 19.1Types of Table 19.2ETS Table Efficiency Considerations 19.3Creating an ETS Table 19.4Example Programs with ETS 19.5Storing Tuples on Disk 19.6What Haven’t We Talked About? 20. Mnesia: The Erlang Database 20.1Creating the Initial Database 20.2Database Queries 20.3Adding and Removing Data in the Database 20.4Mnesia Transactions 20.5Storing Complex Data in Tables 20.6Table Types and Location 20.7The Table Viewer 20.8Digging Deeper 21. Profiling, Debugging, and Tracing 21.1Tools for Profiling Erlang Code 21.2Testing Code Coverage 21.3Generating Cross-References 21.4Compiler Diagnostics 21.5Runtime Diagnostics 21.6Debugging Techniques 21.7The Erlang Debugger 21.8Tracing Messages and Process Execution 21.9Frameworks for Testing Erlang Code 22. Introducing OTP 22.1The Road to the Generic Server 22.2Getting Started with gen_server 22.3The gen_server Callback Structure 22.4Filling in the gen_server Template 22.5Digging Deeper 23. Making a System with OTP 23.1Generic Event Handling 23.2The Error Logger 23.3Alarm Management 23.4The Application Servers 23.5The Supervision Tree 23.6Starting the System 23.7The Application 23.8File System Organization 23.9The Application Monitor 23.10How Did We Make That Prime? 23.11 Digging Deeper V. Building Applications 24. Programming Idioms 24.1Maintaining the Erlang View of the World 24.2A Multipurpose Server 24.3Stateful Modules 24.4Adapter Patterns 24.5Intentional Programming 25. Third-Party Programs 25.1Making a Shareable Archive and Managing Your Code with Rebar 25.2Integrating External Programs with Our Code 25.3Making a Local Copy of the Dependencies 25.4Building Embedded Web Servers with Cowboy 26. Programming Multicore CPUs 26.1Good News for Erlang Programmers 26.2How to Make Programs Run Efficiently on a Multicore CPU 26.3Parallelizing Sequential Code 26.4Small Messages, Big Computations 26.5Parallelizing Computations with mapreduce 27. Sherlock’s Last Case 27.1Finding Similarities in Data
Description: