C++ Network Programming
Volume 1: Resolving Complexity Using Ace and Patterns
Douglas C. Schmidt, Stephen D. Huston
Résumé
This book guides software professionals through the traps and pitfalls of developing efficient, portable, and flexible networked applications. It explores the inherent design complexities of concurrent networked applications and the tradeoffs that must be considered when working to master them.
C++ Network Programming begins with an overview of the issues and tools involved in writing distributed concurrent applications. The book then provides the essential design dimensions, patterns, and principles needed to develop flexible and efficient concurrent networked applications. The book's expert author team shows you how to enhance design skills while applying C++ and patterns effectively to develop object-oriented networked applications.
Readers will find coverage of:
- C++ network programming, including an overview and strategies for addressing common development challenges The ACE Toolkit
- Connection protocols, message exchange, and message-passing versus shared memory
- Implementation methods for reusable networked application services
- Concurrency in object-oriented network programming
- Design principles and patterns for ACE wrapfacades
With this book, C++ developers have at their disposal the most complete toolkit available for developing successful, multiplatform, concurrent networked applications with ease and efficiency.
Contents(NOTE: All chapters end with a Summary.)
About This Book.
Design Challenges, Middleware Solutions, and
ACE.
Networked Application Design Dimensions.
Object-Oriented Middleware Solutions.
An Overview of the ACE Toolkit.
Example Application: A Networked Logging Service.
I. OBJECT-ORIENTED NETWORK PROGRAMMING.
1. Communication Design Dimensions.
Synchronous versus Asynchronous Message Exchange.
Message Passing versus Shared Memory.
2. An Overview of the Socket API.
The Socket API.
Limitations of the Socket API.
3. The ACE Socket Wrapper Facades.
The ACE Addr and ACE INET Addr Classes.
The ACE IPC SAP Class.
The ACE SOCK Class.
The ACE SOCK Connector Class.
The ACE SOCK Stream and ACE SOCK IO Classes..
The ACE SOCK Acceptor Class.
4. Implementing the Networked Logging Service.
The ACE Message Block Class.
The ACE InputCDR and ACE OutputCDR Classes.
The Initial Logging Server.
The Client Application.
II. CONCURRENT OBJECT-ORIENTED NETWORK PROGRAMMING.
5.Concurrency Design Dimensions.
Processes versus Threads.
Process/Thread Spawning Strategies.
User, Kernel, and Hybrid Threading Models.
Time-shared and Real-time Scheduling Classes.
Task- vs. Message-based Architectures.
6. An Overview of Operating System Concurrency Mechanisms.
MultiProcessing Mechanisms.
MultiThreading Mechanisms.
Synchronization Mechanisms.
Limitations with OS Concurrency Mechanisms.
7. The ACE Synchronous Event Demultiplexing Wrapper Facades.
The ACE Handle Set Class.
The ACE Handle Set Iterator Class.
The ACE::select() Methods.
8. The ACE Process Wrapper Facades.
The ACE Process Class.
The ACE Process Options Class.
The ACE Process Manager Class.
9. The ACE Threading Wrapper Facades.
The ACE Thread Manager Class.
The ACE Sched Params Class.
The ACE TSS Class.
10. The ACE Synchronization Wrapper Facades.
The ACE Guard Classes.
The ACE Mutex Classes.
The ACE Readers/Writer Lock Classes.
The ACE Semaphore Classes.
The ACE Condition Variable Classes.
A Design Principles for ACE C++ Wrapper Facades.
Use Wrapper Facades to Enhance Type Safety.
Simplify for the Common Case.
Use Hierarchies to Enhance Design Clarity and Extensibility.
Hide Platform Differences Whenever Possible.
Optimize for Efficiency.
B The Past, Present, and Future of ACE.
The Road Ahead.
Concluding Remarks.
Glossary.
Index.
L'auteur - Douglas C. Schmidt
, PhD is a professor of Computer Science at Washington University and consults for Lucent Technologies. He is a pioneer in the field of telecommunications patterns and frameworks.
L'auteur - Stephen D. Huston
Stephen D. Huston is President and CEO of Riverace
Corporation, a provider of technical support and consulting
services to companies who want to keep software projects on
track using ACE. Steve has more than five years of
experience with ACE, and more than twenty years of software
development experience, focusing on network protocol and
C++ networked application development in a wide range of
hardware and software environments.
Caractéristiques techniques
PAPIER | |
Éditeur(s) | Addison Wesley |
Auteur(s) | Douglas C. Schmidt, Stephen D. Huston |
Parution | 14/02/2002 |
Nb. de pages | 304 |
Format | 18,6 x 23,3 |
Couverture | Broché |
Poids | 674g |
Intérieur | Noir et Blanc |
EAN13 | 9780201604641 |
ISBN13 | 978-0-201-60464-1 |
Avantages Eyrolles.com
Nos clients ont également acheté
Consultez aussi
- Les meilleures ventes en Graphisme & Photo
- Les meilleures ventes en Informatique
- Les meilleures ventes en Construction
- Les meilleures ventes en Entreprise & Droit
- Les meilleures ventes en Sciences
- Les meilleures ventes en Littérature
- Les meilleures ventes en Arts & Loisirs
- Les meilleures ventes en Vie pratique
- Les meilleures ventes en Voyage et Tourisme
- Les meilleures ventes en BD et Jeunesse
- Informatique Développement d'applications Technologies objet
- Informatique Développement d'applications Programmation graphique et multimédia Programmation graphique en C/C++
- Informatique Développement d'applications Langages C++
- Informatique Développement d'applications Outils de développement Borland C++ Builder
- Informatique Développement d'applications Outils de développement Visual C++
- Informatique Développement d'applications Outils de développement Visual C++ .NET