Book Image

C++ Reactive Programming

By : Praseed Pai, Peter Abraham
Book Image

C++ Reactive Programming

By: Praseed Pai, Peter Abraham

Overview of this book

Reactive programming is an effective way to build highly responsive applications with an easy-to-maintain code base. This book covers the essential functional reactive concepts that will help you build highly concurrent, event-driven, and asynchronous applications in a simpler and less error-prone way. C++ Reactive Programming begins with a discussion on how event processing was undertaken by different programming systems earlier. After a brisk introduction to modern C++ (C++17), you’ll be taken through language-level concurrency and the lock-free programming model to set the stage for our foray into the Functional Programming model. Following this, you’ll be introduced to RxCpp and its programming model. You’ll be able to gain deep insights into the RxCpp library, which facilitates reactive programming. You’ll learn how to deal with reactive programming using Qt/C++ (for the desktop) and C++ microservices for the Web. By the end of the book, you will be well versed with advanced reactive programming concepts in modern C++ (C++17).
Table of Contents (20 chapters)
Title Page
Copyright and Credits
Packt Upsell
Contributors
Preface
Index

Chapter 12. Reactive Microservices Using C++

 So far, we have covered essential aspects of reactive programming using C++. Some of the key topics covered include:

  • The reactive programming model and its cognitive prerequisites
  • The RxCpp library and its programming model
  • Reactive GUI programming using Qt/RxCpp
  • Writing Custom Operators 
  • Design patterns and the reactive programming model

If you take a closer look, all examples so far in this book are related to what happens inside a process. Or, we were essentially focusing on shared memory parallel and concurrent techniques. The Rx.net, RxJava and most Rx implementations are   basically concerned with shared memory concurrent and parallel programming. A system such as Akka applies reactive programming model to the distributed world. In Akka, we can write reactive logic that spans processes and machines. The reactive programming model is also good for exposing REST-based web services and consuming them. The RxJs library is mostly used for consuming...