2025-01-24 14:27:00
www.sandordargo.com
C++11 introduced parameter packs to provide a safer way to pass an undefined number of parameters to functions instead of relying on variadic functions.
While packs are a useful feature, and since C++17 it’s so easy to use them in fold expressions, extracting a specific element of a pack is somewhat cumbersome.
You either have to rely on some standard functions not made for the purpose or use “awkward boolean expression crafting or recursive templates”. None of them is unbearable, but it might be error-prone or simply expensive regarding compile-time performance. Nevertheless, they are not the most readable solutions.
C++26 brings us pack indexing as a core language feature thanks to the proposal of Corentin Jabot and Pablo Halpern, P2662R3.
Before discussing some interesting points, first, let’s look at an example:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
template typename... T>
constexpr auto first(T... values) -> T...[0] {
return values...[0];
}
template typename... T>
constexpr auto last(T... values) -> T...[sizeof...(values)-1] {
return values...[sizeof...(values)-1];
}
int main() {
// first(); // ill-formed: invalid index 0 for pack 'T' of size 0
static_assert(first(1, 2, 3, 4, 5) == 1);
static_assert(last(1, 2, 3, 4, 5) == 5);
static_assert(first(1, 2, 3, 4, 5) + last(1, 2, 3, 4, 5) == 6);
}
We can observe that we can use indexes both with the types and with the values and we can use anything that can be evaluated at compile time. With that, I refer to the fact, that we can get the type or value of the last element by using sizeof...(expr)-1
.
P2662R3 is a long but interesting proposal. It discusses several alternative syntaxes for pack indexing and mentions that in fact several people independently came to the same conclusion regarding syntax, which is also proposed by this paper.
While reading the above example one might have the feeling that it uses way too many triple dots, but it still perfectly fits in and just by looking at it, you probably know exactly what’s going on. Maybe we could even say that it reads like well-written prose.
Moreover, the beauty of this syntax and proposal is that it’s open for extension. The proposal doesn’t try to push for everything at once. I met many people who think that we often get half-baked solutions in the standard. To get a new feature completely usable, we usually have to wait for one more standard at least, think about ranges, coroutines, not to mention modules…
In this, case, I don’t think that the feature is half-baked. While indexing from the back is not solved, it’s still just as usable as any indexing in C++. On the other hand, it’s educating to read about the considerations. Did you think about using negative indexes just like in Python? It would also kick in if an expression was accidentally evaluated as negative and therefore it’s undesirable.
But maybe an alternative syntax like T...[^1]
or T...[$-1]
will be accepted in the future. Until then, we’ll have to live with T...[sizeof...(T)-1
. Providing a syntax for slicing is also yet to be standardized.
Conclusion
C++26 brings us pack indexing as a language feature. We’ll be able to extract individual elements from a pack using the subscript operator: T...[0]
. Thanks for the work of those who contributed to the proposal!
Connect deeper
If you liked this article, please
Keep your files stored safely and securely with the SanDisk 2TB Extreme Portable SSD. With over 69,505 ratings and an impressive 4.6 out of 5 stars, this product has been purchased over 8K+ times in the past month. At only $129.99, this Amazon’s Choice product is a must-have for secure file storage.
Help keep private content private with the included password protection featuring 256-bit AES hardware encryption. Order now for just $129.99 on Amazon!
Support Techcratic
If you find value in Techcratic’s insights and articles, consider supporting us with Bitcoin. Your support helps me, as a solo operator, continue delivering high-quality content while managing all the technical aspects, from server maintenance to blog writing, future updates, and improvements. Support Innovation! Thank you.
Bitcoin Address:
bc1qlszw7elx2qahjwvaryh0tkgg8y68enw30gpvge
Please verify this address before sending funds.
Bitcoin QR Code
Simply scan the QR code below to support Techcratic.
Please read the Privacy and Security Disclaimer on how Techcratic handles your support.
Disclaimer: As an Amazon Associate, Techcratic may earn from qualifying purchases.