RSS

.NET

Concurrency Runtime (CRT): The Resource Manager


Visual C++ 2010 comes with new features and enhancements to simplify more native programming. The Concurrency Runtime (CRT), for instance, is a framework that simplifies parallel programming and helps you write robust, scalable, and responsive parallel applications.

The CRT raises the level of abstraction so that you do not have to manage the infrastructure details that are related to concurrency. The Concurrency Runtime also enables you to specify scheduling policies that meet the quality of service demands of your applications.

Here's the architecture of Concurrent Runtime Framework:

[Click image to view at full size]

In this article I discuss the ResourceManager layer and examine how it works internally. To do so, I use CppDepend, an analysis tool that makes it easier for you to manage complex C\C++ (Native, Mixed, and COM) code bases.

ResourceManager Design

Which classes are used by ResourceManager to achieve its responsibility?


SELECT TYPES WHERE IsDirectlyUsedBy "Concurrency.details.ResourceManager"

[Click image to view at full size]

The first thing to note about this design is that it enforces:

High Cohesion: Many classes and structs are used by ResourceManager and each one has a specific responsibility.The single responsibility principle states that a class should have more than one reason to change. Such a class is said to be "cohesive". A high LCOM value generally pinpoints a poorly cohesive class. There are several LCOM metrics. The LCOM takes its values in the range [0-1]. The LCOMHS (HS stands for "Henderson-Sellers') takes its values in the range [0-2]. Note that the LCOMHS metric is often considered as more efficient to detect non-cohesive types. LCOMHS value higher than 1 should be considered alarming.


WARN IF Count > 0 IN SELECT TYPES WHERE LCOMHS > 1 AND NbFields > 10
AND NbMethods >10 AND !IsGlobal ORDER BY LCOMHS DESC

[Click image to view at full size]

So among classes used by ResourceManager, only UMS is considered as class with a poor cohesion.

Low Coupling:Many interfaces and proxies are used to isolate ResourceManager from other components. The Scheduler communicates with ResourceManager but there's no direct link between two components. So how the scheduler communicate with ResourceManager? To answer to this question let's discover classes using ResourceManager:


SELECT TYPES WHERE IsDirectlyUsing "Concurrency.details.ResourceManager"

[Click image to view at full size]

Only these classes use the ResourceManager, and the Scheduler doesn't know the ResourceManager directly. So how it interact with it? Let's add to dependency graph the scheduler and interfaces used by it.

[Click image to view at full size]

As shown in the dependency graph the Scheduler communicate with ResourceManager using interfaces IResourceManager, ISchedulere, and ISchedulerProxy.

Where is the ResourceManager created?


SELECT METHODS WHERE DepthOfCreateA "Concurrency.details.ResourceManager" = = 1

[Click image to view at full size]

Only ResourceManager create an instance, and since it's a singleton only one ResourceManager exist for the whole process.


Related Reading


More Insights






Currently we allow the following HTML tags in comments:

Single tags

These tags can be used alone and don't need an ending tag.

<br> Defines a single line break

<hr> Defines a horizontal line

Matching tags

These require an ending tag - e.g. <i>italic text</i>

<a> Defines an anchor

<b> Defines bold text

<big> Defines big text

<blockquote> Defines a long quotation

<caption> Defines a table caption

<cite> Defines a citation

<code> Defines computer code text

<em> Defines emphasized text

<fieldset> Defines a border around elements in a form

<h1> This is heading 1

<h2> This is heading 2

<h3> This is heading 3

<h4> This is heading 4

<h5> This is heading 5

<h6> This is heading 6

<i> Defines italic text

<p> Defines a paragraph

<pre> Defines preformatted text

<q> Defines a short quotation

<samp> Defines sample computer code text

<small> Defines small text

<span> Defines a section in a document

<s> Defines strikethrough text

<strike> Defines strikethrough text

<strong> Defines strong text

<sub> Defines subscripted text

<sup> Defines superscripted text

<u> Defines underlined text

DrDobbs encourages readers to engage in spirited, healthy debate, including taking us to task. However, DrDobbs moderates all comments posted to our site, and reserves the right to modify or remove any content that it determines to be derogatory, offensive, inflammatory, vulgar, irrelevant/off-topic, racist or obvious marketing/SPAM. DrDobbs further reserves the right to disable the profile of any commenter participating in said activities.

 
Disqus Tips To upload an avatar photo, first complete your Disqus profile. | View the list of supported HTML tags you can use to style comments. | Please read our commenting policy.
 

Best of the Web

What the New iPad and iOS 5.1 Mean for Developers

The new display is gorgeous. But local storage for HMTL5 is currently broken on the new iPad and performance of some apps is slower. Here's a deep dive into the issues, including benchmarks and analysis.

Quick Read

Triple Buffering as A Concurrency Mechanism

Triple Buffering is a way of passing data between a producer and a consumer running at different rates. It ensures that the consumer sees only complete data with minimal lag.

Quick Read

Embedding GDB Breakpoints in C Source Code

Have you ever wanted to embed GDB breakpoints in C source code? Something like this:
printf("Hello,\n");
EMBED_BREAKPOINT;
printf("world!\n");

Quick Read

Writing Kernel Exploits

Why attack the kernel? Because it has a huge attack surface with potential for very interesting bugs. This presentation (pdf) takes a code-level dive into recently reported Linux-kernel exploits.

Quick Read


More "Best of the Web" >>

Video

Enabling People and Organizations to Harness the Transformative Power of Technology