2018-01-09
C++ holds a special place in my heart and mind because it was my first programming language (and as of this post I regularly use it). I was lucky enough to really start using the language when the 2011 standard was established (but in the growing-pain stage). I learned a lot while following the adoption process and I continue to keep up with the developments of the language and the standard library.
C++17 was formally approved approved a few months ago. These days the GCC and Clang developers do an awesome job implementing features early on, so a lot of C++17 language and standard library features have been available in a number of recent releases of both compilers (and their respective STL implementations). Unfortunately it'll be a little while before I can use C++17 in my experiment's production code. Nevertheless, I've still identified a few of my early favorite features. I'll discuss them a bit with a couple of high energy physics analysis use cases.
When writing Python I always appreciate the ease of writing functions with multiple returns and the intuitive looping over dictionaries. Adding structured bindings to C++ makes it easy to use multiple returns and intuitive to loop over an std::map.
For multiple returns in C++ 11 and 14 we had to use std::tie.
auto
int
Now, with structured bindings:
int
Before C++17, when looping over the std::map
container, we were
locked into using the first
and second
members of std::pair.
int
With structured bindings, we have something a bit more intuitive and less verbose:
int
For even more verbosity, go back to C++03 container looping with iterators.
Consistent with a number of existing C++ STL features... boost was the original supplier of a C++ filesystem library. It's not always desirable to carry Boost around as a dependency; avoiding that dependency makes the filesystem library a very welcome inclusion to the standard. Having a way to interact with the filesystem is a very common feature to most languages' standard libraries. With respect to C++, it's about time.
The library allows users to parse and modify the filesystem. As an example, I'll use the task of selecting files with a specific extension in a given directory. This is a useful piece of code for processing a large dataset that's broken into many files (I do this a lot for my physics analysis).
;
std::vector<std::string>
PhysicsResult
The constexpr specifier (for constant expressions) was introduced in C++11. The purpose of the specifier is to communicate to the compiler that the expression should be evaluated at compile time.
Some awesome things about if constexpr
are the reduction of
boilerplate and decrease in compile time. if constexpr
tells the
compiler what to actually compile based on templates, and to
ignore the rest.
Let's say I have three different objects I can analyze, but one of
them is a component of the other two. In particle physics
terminology, I can analyze an electron, a muon, or a track; but,
all electrons and muons have an associated track. If I have an API
which supplies a feature to analyze tracks from containers of all
three of these types, if constexpr
is great if I want study them
with different functions elsewhere in the code without overloading
an analyzeTracks
function multiple times.
void
The if constexpr
feature of C++17 allows me (when wearing an API
developer hat) to avoid writing the boilerplate of multiple
function overloads and still supply the same easy to use API.