ebook img

Programming Erlang: Software for a Concurrent World PDF

729 Pages·2013·2.88 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Programming Erlang: Software for a Concurrent World

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:
A multi-user game, web site, cloud application, or networked database can have thousands of users all interacting at the same time. You need a powerful, industrial-strength tool to handle the really hard problems inherent in parallel, concurrent environments. You need Erlang. In this second edition
See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.