Tags
Language
Tags
May 2025
Su Mo Tu We Th Fr Sa
27 28 29 30 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 31
    Attention❗ To save your time, in order to download anything on this site, you must be registered 👉 HERE. If you do not have a registration yet, it is better to do it right away. ✌

    ( • )( • ) ( ͡⚆ ͜ʖ ͡⚆ ) (‿ˠ‿)
    SpicyMags.xyz

    Learning Concurrent Programming in Scala - Second Edition

    Posted By: AlenMiler
    Learning Concurrent Programming in Scala - Second Edition

    Learning Concurrent Programming in Scala - Second Edition by Aleksandar Prokopec
    English | 22 Feb. 2017 | ISBN: 1786466899 | 516 Pages | PDF (conv) | 5.85 MB

    Key Features
    Make the most of Scala by understanding its philosophy and harnessing the power of multicores
    Get acquainted with cutting-edge technologies in the field of concurrency, through practical, real-world applications
    Get this step-by-step guide packed with pragmatic examples

    Book Description
    Scala is a modern, multiparadigm programming language designed to express common programming patterns in a concise, elegant, and type-safe way. Scala smoothly integrates the features of object-oriented and functional languages.

    In this second edition, you will find updated coverage of the Scala 2.12 platform. The Scala 2.12 series targets Java 8 and requires it for execution. The book starts by introducing you to the foundations of concurrent programming on the JVM, outlining the basics of the Java Memory Model, and then shows some of the classic building blocks of concurrency, such as the atomic variables, thread pools, and concurrent data structures, along with the caveats of traditional concurrency.

    The book then walks you through different high-level concurrency abstractions, each tailored toward a specific class of programming tasks, while touching on the latest advancements of async programming capabilities of Scala. It also covers some useful patterns and idioms to use with the techniques described. Finally, the book presents an overview of when to use which concurrency library and demonstrates how they all work together, and then presents new exciting approaches to building concurrent and distributed systems.

    What you will learn
    Get to grips with the fundamentals of concurrent programming on modern multiprocessor systems
    Build high-performance concurrent systems from simple, low-level concurrency primitives
    Express asynchrony in concurrent computations with futures and promises
    Seamlessly accelerate sequential programs by using data-parallel collections
    Design safe, scalable, and easy-to-comprehend in-memory transactional data models
    Transparently create distributed applications that scale across multiple machines
    Integrate different concurrency frameworks together in large applications
    Develop and implement scalable and easy-to-understand concurrent applications in Scala 2.12

    About the Author
    Aleksandar Prokopec, who also authored the first edition of this book, is a concurrent and distributed programming researcher. He holds a PhD in computer science from the Ecole Polytechnique Federale de Lausanne, Switzerland. He has worked at Google and is currently a principal researcher at Oracle Labs.

    As a member of the Scala team at EPFL, Aleksandar actively contributed to the Scala programming language, and he has worked on programming abstractions for concurrency, data-parallel programming support, and concurrent data structures for Scala. He created the Scala Parallel Collections framework, which is a library for high-level data-parallel programming in Scala, and participated in working groups for Scala concurrency libraries, such as Futures, Promises, and ScalaSTM. Aleksandar is the primary author of the reactor programming model for distributed computing.

    Table of Contents
    Introduction
    Concurrency on the JVM and the Java Memory Model
    Traditional Building Blocks of Concurrency
    Asynchronous Programming with Futures and Promises
    Data-Parallel Collections
    Concurrent Programming with Reactive Extensions
    Software Transactional Memory
    Actors
    Concurrency in Practice
    Reactors