Published Articles and Committee Papers
Here is a list of articles and other publications written by one of our directors, Anthony Williams. In each case, the title is linked to the online version. Anthony's conference presentations are available here.
Book
Anthony is the author of C++ Concurrency in Action, published by Manning, which provides a comprehensive tutorial and reference to the multithreading support in C++11, C++14, C++17 and the Concurrency TS.
It's not just the best current treatment of C++11's threading facilities ... it's likely to remain the best for some time to come. Scott Meyers
The second edition is now in print. Get your copy now.
Interviews
Anthony was also interviewed for CppCast for their 17th October 2015 episode.
Articles
Issue / Publication Date | Publication | Title | Description |
---|---|---|---|
April 2016 | Overload 132 | Using enum classes as bitfields | This article is a slightly expanded version of my blog entry: Using enum classes as bitfields. |
August 2015 | Overload 128 | Numbers in Javascript | This article is a slightly expanded version of my blog entry: Numbers in Javascript. |
October 2011 | Overload 105 | Picking patterns for parallel programs | A description of design patterns for parallel programs, and some guidance on when each is useful. |
September 2010 | DrDobbs.com | Concept Checking Without Concepts in C++ | One of the important features of the now-defunct C++0x Concepts proposal was the ability to overload functions based on whether or not their arguments met certain concepts. This article describes a way to allow that for concepts based on the presence of particular member functions. |
May 2010 | DrDobbs.com | Enforcing Correct Mutex Usage with Synchronized Values | This article expands on
the SynchronizedValue<T> template I mentioned in my
presentation
on Concurrency
in the Real World at ACCU 2010, and deals with the problem of
ensuring that the mutex associated with some data is locked whenever
the data is accessed. |
April 2010 | DrDobbs.com | Simple Concurrency with Dataflow Variables in C++ | Dataflow variables are write-once read-many variables with in-built synchronization. In this article I explain how they can be used to write scalable code with no race conditions, and how to implement them in C++. |
October 2009 | Overload 93 | Multi-threading in C++0x | An overview of the new multithreading facilities in C++0x. |
September 2009 | DevX.com | Avoiding the Perils of C++0x Data Races | Race conditions are one of the biggest causes of problems in multithreaded code. This article takes a brief look at some of the ways in which race conditions can occur. There is also sample code that demonstrates the perils of data races by showing how even simple code with a data race can lead to corrupt data. |
May 2009 | DevX.com | Introduction to Variadic Templates in C++0x | This article introduces the new variadic template facility from C++0x, which allows you to write templates that take a variable number of template arguments. |
November 2008 | Dr. Dobb's Journal | What's New in Boost Threads? | This article gives an overview of the new features added to the Boost thread library in the recent releases. |
September 2008 | Codeguru.com | Deadlock: The problem and a solution | This is an excerpt from Anthony's book C++ Concurrency in Action, and describes the problem of deadlock and ways to avoid it. |
August 2008 | DevX.com | Simpler Multithreading in C++0x | Part of DevX.com's Special Report on C++0x, this article provides a whistle-stop tour of the new C++0x multithreading support. |
August 2008 | Overload 86 | Exceptions make for Elegant Code | This article is a slightly expanded version of my blog entry: Exceptions make for Elegant Code. |
April 2008 | Dr. Dobb's Journal | Optimizing Math-intensive Applications with Fixed Point Arithmetic | This article describes the fixed-point techniques used to vastly improve the performance of an application using sines,
cosines and exponentials without hardware floating point support. The source code referenced in the article can be downloaded from here. It is released under the Boost Software License. |
April 2007 | Overload 78 | Implementing Synchronization Primitives for Boost on Windows Platforms | This article describes the techniques involved in writing a new mutex implementation for Windows. |
June 2006 | CVu 18.3 | Building on a Legacy | This article discusses ways of handling legacy code, and how to work so that maintenance gets easier rather than harder. |
June 2006 | Overload 73 | Implementing drop-down menus in pure CSS (no JavaScript) | This article describes the details behind implementing drop-down menus with CSS in a cross-browser fashion. |
May 2006 | Dr. Dobb's Journal | Message Handling Without Dependencies | This article describes a type-safe technique for passing messages around an application in C++, without requiring extensive coupling between the producer and consumer |
April 2004 | CVu 16.2 | Writing Maintainable Code | A brief summary of techniques to help you write maintainable code. |
November 2003 | C/C++ Users Journal | Strong Exception-Safe Storage | This article describes the use of a double-buffer technique to provide the Strong Exception Safety Guarantee without the use of dynamic memory, even when the underlying data only provides the Basic Exception Safety Guarantee. |
April 2003 | Overload 54 | EXPR_TYPE — An Implementation of typeof Using Current Standard
C++ (PDF) |
typeof is a much-sought-after facility that is lacking from current C++; it is the
ability to declare a variable to have the same type as the result of a given expression, or make a
function have the same type as an expression. The general idea is that
typeof(some-expression) would be usable anywhere a type name could normally be
used. This article describes a way of providing this ability within the realms of current
C++. There is code to accompany this article. |
October 2002 | Overload 51 | Pairing Off Iterators (PDF) | This article describes the implementation of an iterator adaptor that converts a pair of ranges into a range of pairs, so that two containers can be sorted by a key held in only one of them, for example. The code is available for download |
October 2001 | Overload 45 | Introduction to C++ Templates (PDF) | This is a brief introduction to C++ templates - how they work, how to use them, and how to write your own. |
August 2001 | Overload 44 | Flexible Functors and Binders (PDF) | This article describes a set of binders to assist writing programs using the Functional Programming style, and a set of adaptors for other functors, such as pointers-to-functions and pointers-to-member-functions, to enable them to be integrated seamlessly. The code to accompany the article can be downloaded. |
April 2001 | Overload 42 | A Generic Non-Intrusive Smart Pointer Implementation (PDF) | This article describes the implementation of a smart pointer that can
be freely converted to and from a raw pointer, or other types of smart
pointer, without losing its reference count. It also permits the use of
arrays, and the use of dynamic_cast . The code to accompany the
article can be downloaded. There is an
erratum for this article. |
C++ Standards Committee Papers
Issue / Publication Date | Publication | Title | Description | |
---|---|---|---|---|
March 2019 | C++ Standards Committee Mailing | P0660R9: Stop Tokens and a Joining Thread, Rev 9 | A replacement for std::thread that always joins, and "stop" tokens to allow
cooperative interruption. | |
January 2019 | C++ Standards Committee Mailing | P0660R8: Stop Tokens and a Joining Thread, Rev 8 | A replacement for std::thread that always joins, and "stop" tokens to allow
cooperative interruption. | |
November 2018 | C++ Standards Committee Mailing | P0660R7: Interrupt Tokens and a Joining Thread, Rev 7 | A replacement for std::thread that always joins, and cancellation tokens to allow
cooperative interruption. | |
November 2018 | C++ Standards Committee Mailing | P0660R6: A Cooperatively Interruptible Joining Thread, Rev 6 | A replacement for std::thread that always joins, and allows interruption. | |
October 2018 | C++ Standards Committee Mailing | P0660R5: A Cooperatively Interruptible Joining Thread, Rev 5 | A replacement for std::thread that always joins, and allows
interruption. | |
September 2018 | C++ Standards Committee Mailing | P0660R4: A Cooperatively Interruptible Joining Thread, Rev 4 | A replacement for std::thread that always joins, and allows interruption. | |
June 2018 | C++ Standards Committee Mailing | P0660R3: A Cooperatively Interruptible Joining Thread, Rev 3 | A replacement for std::thread that always joins, and allows interruption. | |
May 2018 | C++ Standards Committee Mailing | P0660R2: A Cooperatively Interruptible Joining Thread, Rev 2 | A replacement for std::thread that always joins, and allows interruption. | |
March 2017 | C++ Standards Committee Mailing | P0623R0: Final C++17 Parallel Algorithms Fixes | Apply final changes to the parallel algorithms for C++17. | |
March 2017 | C++ Standards Committee Mailing | P0574R1: Algorithm Complexity Constraints and Parallel Overloads | A revision of P0547R0 based on feedback from SG1 and LWG | |
March 2017 | C++ Standards Committee Mailing | P0290R2: apply() for synchronized_value<T> | A revision of P0290R1 to allow coexistence with apply for std::tuple | |
February 2017 | C++ Standards Committee Mailing | P0574R0: Algorithm Complexity Constraints and Parallel Overloads | Modifications to the C++17 draft to better specify the complexity constraints of parallel algorithms to allow efficient implementations. | |
October 2016 | C++ Standards Committee Mailing | P0290R1: apply() for synchronized_value<T> | Revision of P0290R0 based on feedback from SG1 | |
March 2016 | C++ Standards Committee Mailing | P0290R0: apply() for synchronized_value<T> | A revision of N4032; all operations on the value wrapped in
a synchronized_value<T> are now down through a separate apply
function. | |
November 2015 | C++ Standards Committee Mailing | P0158R0: Couroutines belong in a TS | BSI position paper advocating coroutines being in a TS rather than moved straight to the standard. | |
April 2015 | C++ Standards Committee Mailing | P0120R0: constexpr unions and common initial sequences | A proposal to allow accessing common initial sequences of struct s
in constexpr union s, the same as allowed for
non-constexpr union s, in order to allow more
space-efficient variant implementations. | |
April 2015 | C++ Standards Committee Mailing | P0110R0: Implementing the strong guarantee for variant<> assignment | Description of the difficulties in implementing the strong guarantee
for std::variant , with techniques on how to do it, and the requirements on the types
for the various options. | |
May 2014 | C++ Standards Committee Mailing | N4033: synchronized_value<T> for associating a mutex with a value | synchronized_value<T> wraps a mutex and a value so you cannot access the value without locking the mutex | |
May 2014 | C++ Standards Committee Mailing | N4032: Comments on continuations and executors | My comments on the executors proposal for the Concurrency TS | |
November 2010 | C++ Standards Committee Mailing | N3197: Lockable requirements for C++0x | A revision of N3130 | |
August 2010 | C++ Standards Committee Mailing | N3131: Compile-time rational arithmetic and overflow | Document the handling of overflow in std::ratio operations | |
August 2010 | C++ Standards Committee Mailing | N3130: Lockable requirements for C++0x | This paper revises the wording for the C++0x draft for mutexes to gather together common requirements | |
February 2010 | C++ Standards Committee Mailing | N3038: Managing the lifetime of thread_local variables with contexts (Revision 2) | A revision of N2959, adding support for nested contexts | |
September 2009 | C++ Standards Committee Mailing | N2959: Managing the lifetime of thread_local variables with contexts (Revision 1) | This is a revision of my earlier paper, N2907
which expands my proposal for a thread_local_context
class, along with full proposed wording. I think this provides a
workable solution to the general problem of ensuring that destructors
for thread_local variables are run at particular points
in the execution of a program as discussed in N2880. | |
September 2009 | C++ Standards Committee Mailing | N2967: Issues on Futures | This paper that I co-authored with Detlef Vollmann provides a
complete rewording for the "Futures" section of the standard
(30.6). It folds the proposed changes from N2888
in with changes requested by the LWG at July's meeting (including the
addition of a new future type — atomic_future which
serializes all operations), and editorial comments on the earlier
wording. It doesn't resolve everything — there is still some
discussion over whether unique_future::get() should
return a value or a reference, for example — but it provides a
sound basis for further discussion. | |
June 2009 | C++ Standards Committee Mailing | N2907: Managing the lifetime of thread_local variables with contexts | This paper introduces the idea of
a thread_local_context which manages the lifetime of
variables declared thread_local . In particular, this
concept is introduced to manage the interaction
of thread_local variables with detached threads and
asynchronous function calls. | |
June 2009 | C++ Standards Committee Mailing | N2888: Moving Futures - Proposed Wording for UK comments 335, 336, 337 and 338 | This paper provides rationale and proposed wording for the UK
comments on the C++ working draft requesting move semantics
for std::unique_future
and std::shared_future . | |
July 2008 | C++ Standards Committee Mailing | N2709: Packaging Tasks for Asynchronous Execution | This paper proposes a revised version
of packaged_task following its removal from N2671. | |
June 2008 | C++ Standards Committee Post-Sophia Antipolis Mailing | N2671: An Asynchronous Future Value Proposed Wording | Jointly authored with Deltef Vollmann and Howard Hinnant. An updated version of N2627 with proposed
wording. packaged_task has been removed for a later proposal. | |
May 2008 | C++ Standards Committee Pre-Sophia Antipolis Mailing | N2627: An Asynchronous Future Value (Revised) | Jointly authored with Deltef Vollmann and Howard Hinnant. An updated version of N2561. | |
March 2008 | C++ Standards Committee Post-Bellevue Mailing | N2561: An Asynchronous Future Value | Jointly authored with Deltef Vollmann and Howard Hinnant. Futures, promises and packaged tasks for multi-threaded programming. See Futures and Tasks in C++0x for a summary. | |
September 2007 | C++ Standards Committee Pre-Kona Mailing | Names, Linkage and Templates (Rev 2) (PDF) | This paper is an update to the earlier proposals for making local types usable with templates (N1945 and N2187), with revised wording. | |
June 2007 | C++ Standards Committee Pre-Toronto Mailing | Multi-threading library for Standard C++ | This paper (jointly authored with Howard Hinnant, Beman Dawes, Lawrence Crowl and Jeff Garland) proposes a set of classes for a basic thread library for C++, including thread launching, mutexes and condition variables. | |
May 2007 | C++ Standards Committee Post-Oxford Mailing | Thread Pools and Futures | This paper proposes new classes to the C++ Standard Library for thread pools and futures, to build on top of the new threading facilities. | |
March 2007 | C++ Standards Committee Pre-Oxford Mailing | Names, Linkage and Templates (rev 1) (PDF) | This paper is an update to the earlier proposal for making local types usable with templates (N1945), with revised examples, motiviation and wording. | |
November 2006 | C++ Standards Committee Post-Portland Mailing | Thoughts on a Thread Library for C++ | This paper outlines thoughts on various aspects of a thread library for C++, including one-time initialization, and general thread synchronization. | |
February 2006 | C++ Standards Committee Pre-Berlin Mailing | Names, Linkage and Templates (PDF) | This paper proposes that the C++ Standard is changed, so that unnamed and local types have linkage, in order to simplify the language and make these types usable with templates. | |
March 2003 | C++ Standards Committee Pre-Oxford Mailing | Making Local Classes more Useful (PDF) | This paper proposes a couple of small changes to the C++ Standard: to allow local classes to work with templates, and to allow local classes to declare friend functions. |
Design and Content Copyright © 2005-2025 Just Software Solutions Ltd. All rights reserved. | Privacy Policy