Pro .NET 4 Parallel Programming in C#
Author: Adam Freeman
Publisher: Apress
Pages: 328
ISBN: 978-1430229674
Aimed at: Experienced C# programmers
Rating: 4
Pros: Methodical and clear approach
Cons: Fails to cover UI thread
Reviewed by: Ian Elliot

Parallel Programming is more important than ever. Does this book give you a clear lead? Author: Adam Freeman

Publisher: Apress, 2010
Pages: 328
ISBN: 978-1430229674
Aimed at: Experienced C# programmers
Rating: 4
Pros: Methodical and clear approach
Cons: Fails to cover UI thread
Reviewed by: Ian Elliot


Parallel Programming is more important than ever and there are some new approaches in the pipeline. This particular book takes a fairly traditional approach to parallel programming by focusing on the Task Programming Library. After the usual preliminaries, Chapter 2 gets started with basic tasks and at this stage it is clear that the author intends to show you every possible way to create a task and generally working with tasks. The examples are small enough to understand and overall the approach works well. As long has you have a rough idea of what you are trying to achieve it all should make good sense. By the end of the chapter you should know everything you need to know about working with tasks - as long as they work in isolation.

Banner

Chapter 3 deals with the more interesting case of sharing data between tasks and introduces the problems - race hazards and deadlock. From here each time of lock and synchronization approach is explained complete with small examples. It also deals with the new concurrent collections and even the synchronization features of the existing collections. At the end of the chapter is a collection of patterns illustrating what can go wrong and how to deal with the situation.

The next chapter moves into slightly less familiar territory - task continuations. This works its way through all the possibilities very clearly and then introduces other methods of co-ordinating tasks again many of which you are unlikely to be familiar with from a threads background.

Chapter 5 widens the horizon again with a look at using the parallel loop constructs to automatically run tasks. With the background you have in using tasks you can easily see how to extend and generally work with the higher level parallel constructs. Chapter 6 is more specialized still and looks at Parallel LINQ. If you don't know what LINQ is all about this isn't going to make much sense.

Finally the book rounds off with debugging and a chapter on parallel algorithms - parallel quicksort, map reduce and producer consumer.

Overall this is a methodical and very clear book and if you want to master the Task Parallel Library it is a good choice. However it doesn't deal with one of most common reasons for getting involved in parallel programming at all - shifting work off the UI thread and hence how to interact with the UI thread. In particular it doesn't cover the invoke pattern and doesn't discuss the dispatcher and asynchronous programming in general. If it did cover these topics it would be a much bigger book. Perhaps these should be the subject of a second volume.

As long as you can work out for yourself how to work with the UI thread, or don't care about it, then this is a good book on the topic of using the Thread Parallel Library.


Banner


SQL Query Design Patterns and Best Practices

Author: Steve Hughes et al
Publisher: Packt Publishing
Pages: 270
ISBN: 978-1837633289
Print: 1837633282
Kindle: B0BWRD7HQ7
Audience: Query writers
Rating: 2.5
Reviewer: Ian Stirk

This book aims to improve your SQL queries using design patterns, how does it fare? 



T-SQL Fundamentals (Microsoft Press)

Author: Itzik Ben-Gan
Publisher: Microsoft Press
Pages: 608
ISBN: 978-0138102104
Print: 0138102104
Kindle: B0BTLBXF8V
Audience: T-SQL developers
Rating: 5
Reviewer: Kay Ewbank

Itzik Ben-Gan is a highly respected Microsoft Data Platform MVP, and the earlier editions of this book were already ver [ ... ]


More Reviews

Last Updated ( Monday, 18 July 2011 )