NuGet PackageReference for C++ Projects in Visual StudioNative C++ projects (.vcxproj) now support NuGet PackageReference, the same modern package management experience .NET developers have used for years. Available as an experimental feature in Visual Studio 2026 version 18.7. The post NuGet PackageReference for C++ Projects in Visual Studio appeared first on C++ Team Blog .πC++ Team BlogWelcome to SwedenCpp
Latest blogs, videos, podcasts and releases in one stream
Tuesday, May 19, 2026
NuGet PackageReference for C++ Projects in Visual StudioNative C++ projects (.vcxproj) now support NuGet PackageReference, the same modern package management experience .NET developers have used for years. Available as an experimental feature in Visual Studio 2026 version 18.7. The post NuGet PackageReference for C++ Projects in Visual Studio appeared first on C++ Team Blog .πC++ Team BlogIf this page is useful, please consider your support
Monday, May 18, 2026
SIMD-accelerated integer-to-string conversionConverting a 64-bit integer to its decimal string representation is a mundane task that shows up everywhere: logging, JSON serialization, CSV output, debug prints, etc. In C++, you might use std::to_chars, sprintf, or some library routine. How do these functions work? At a high level, they repeatedly divide by ten. Start with your integer k. β¦ Continue reading SIMD-accelerated integer-to-string conversionπDaniel Lemire's blog
CVPR 2026Kitware is proud to participate in the IEEE/CVF Conference on Computer Vision and Pattern Recognition (CVPR) 2026, one of the premier venues for cutting-edge research in computer vision and machine learning. Building on our long-standing involvement in the CVPR community, we look forward to sharing our latest work, connecting with collaborators, and engaging with researchers advancing the state of the art.πKitware Inc
VTK Hackathon β May 13, 2026On May 13, 2026, the Visualization Toolkit (VTK) developer community gathered for a hands-on hackathon. As an open source project, VTK relies on the contributions of its community, and this event highlighted the collective effort to maintain and improve the toolkit. The objectives for the day included reducing technical debt, triaging issues, stabilizing builds, and [β¦]πKitware Inc
Zero-Cost Abstractions in Large C++ Systems - Shubhankar Gambhir - C++Online 2026π₯CppOnline
GPU Programming and HLSL with Chris Bieneman - CppCast 407 - C++Weekly Ep 537π₯Jason Turner
Let's make a programming language together!π₯PVS-Studio
How tokenization works: making a programming languageπ₯PVS-Studio
Let's make a programming language: lexer!π₯PVS-Studio
Lightning Talk: How Fast Isnβt You Constexpr? - Hossein GhahramanzadehAnigh - CppCon 2025π₯CppCon
Let's make a programming language. Lexerπ₯PVS-Studio
Real-Time EEG for Adaptive Music in Games and VR - Marta Rossi - ADC 2025π₯audiodevcon
Introducing the AI Code Documentation Skills for QtWriting reference documentation for Qt/C++ and QML code has traditionally meant either maintaining hand-written Markdown files that drift out of sync with the source or running toolchains that require annotated comment blocks throughout the codebase. The Qt documentation skills give developers a third option for higher productivity: point an AI agent at your source files and get structured, developer-ready Markdown reference docs in seconds.πQt BlogSunday, May 17, 2026
PVS-Studio in CMake: It's official now!If you're working on a cross-platform project in C or C++, you usually don't rely on a single build system, but instead use a build script generator. CMake, the most popular one, has recently been...πfrom pvs-studio.com
Let's Talk About AIπ₯The Cherno
A simple question? When to copy, when to move?π₯MeetingCpp
C++ on courses.mshah.io | Modern Cpp Seriesπ₯Mike ShahSaturday, May 16, 2026
Lecture 26. Coroutines, part II: Awaiters and Threads (MIPT, 2025-2026).π₯Konstantin Vladimirov
BeCPP Symposium 2026 - Gabriel Dos Reis - Tightening the Screws with C++ Profilesπ₯BeCPP Users Group
How to join or concat ranges, C++26Modern C++ continuously improves its range library to provide more expressive, flexible, and efficient ways to manipulate collections. Usually, when you wanted to concatenate or flatten ranges, youβd use raw loops or custom algorithms. With C++βs range adaptors, we now have an elegant and efficient way to process collections lazily without unnecessary allocations. In this post, we will explore three powerful range adaptors introduced in different C++ standards: std::ranges::concat_view (C++26) std::ranges::join_view (C++20) std::ranges::join_with_view (C++23) Letβs break down their differences, use cases, and examples. Updated in May 2026: added from_range construction options. std::ranges::concat_view (C++26) The concat_view allows you to concatenate multiple independent ranges into a single sequence. Unlike join_view , it does not require a range of ranges-it simply merges the given ranges sequentially while preserving their structure. In short: Takes multiple independent ranges as arguments. Supports random access if all underlying ranges support it. Allows modification if underlying ranges are writable. Lazy evaluation: No additional memory allocations. See the example: #include #include #include #include int main () { std :: vector std :: string > v1 { "world" , "hi" }; std :: vector std :: string > v2 { "abc" , "xyz" }; std :: string arr []{ "one" , "two" , "three" }; auto v1_rev = v1 | std :: views :: reverse ; auto concat = std :: views :: concat ( v1_rev , v2 , arr ); concat [ 0 ] = "hello" ; // access and write for ( auto & elem : concat ) std :: print ( "{} " , elem ); } See at @Compiler Explorer The output: hello world abc xyz one two three The example below shows how to concatenate three ranges, v1 is reversed and then combined with v2 and arr. Notice that we can also access the value at position 0 and update it. And a bit more complex example: #include #include #include #include #include struct Transaction { std :: string type ; double amount ; }; int main () { std :: vector Transaction > bank_transactions { { "Deposit" , 100.0 }, { "Withdraw" , 50.0 }, { "Deposit" , 200.0 } }; std :: list Transaction > credit_card_transactions { { "Charge" , 75.0 }, { "Payment" , 50.0 } }; auto filtered_bank = bank_transactions | std :: views :: filter ([]( const Transaction & t ) { return t . amount >= 100.0 ; }); auto filtered_credit = credit_card_transactions | std :: views :: filter ([]( const Transaction & t ) { return t . amount > 60.0 ; }); auto all_transactions = std :: views :: concat ( filtered_bank , filtered_credit ); for ( const auto & t : all_transactions ) std :: println ( "{} - {}$" , t . type , t . amount ); } Run @Compiler Explorer std::ranges::join_view (C++20) The join_view is designed for flattening a single range of ranges into a single sequence. It removes the structural boundaries between nested ranges. Works on a single range of ranges (e.g., std::vector > ). Does not support operator[] (no random access). Eliminates boundaries between sub-ranges. Lazy evaluation, avoiding memory copies. A simple example: #include #include #include int main () { std :: vector std :: vector int >> nested {{ 1 , 2 }, { 3 , 4 , 5 }, { 6 , 7 }}; auto joined = std :: views :: join ( nested ); for ( int i : joined ) std :: println ( i ); } Run @Compiler Explorer The output: 1 2 3 4 5 6 7 Of course, we can have different nested rangesβ¦ and this can be handy for string processing: #include #include #include #include #include int main () { std :: vector std :: string > words { "Hello" , "World" , "Coding" }; // regular: std :: map char , int > freq ; for ( auto & w : words ) for ( auto & c : w ) freq [ :: tolower ( c )] ++ ; // join: std :: map char , int > freq2 ; for ( auto & c : words | std :: views :: join ) freq2 [ :: tolower ( c )] ++ ; for ( auto & [ key , val ] : freq2 ) std :: println ( "{} -> {}" , key , val ); } Run @Compiler Explorer As you can see, thanks to views_join we can save one nested loop and iterate through a single range of characters. std::ranges::join_with_view (C++23) The join_with_view works like join_view , but it allows inserting a delimiter between flattened sub-ranges. Works on a single range of ranges. Allows specifying a delimiter (single element or a range). Does not support random access. Useful for formatting strings or separating collections. See the example below: #include #include #include #include #include std :: string to_uppercase ( std :: string_view word ) { std :: string result ( word ); for ( char & c : result ) c = std :: toupper ( static_cast unsigned char > ( c )); return result ; } int main () { std :: vector std :: string_view > words { "The" , "C++" , "ranges" , "library" }; auto words_up = words | std :: views :: transform ( to_uppercase ); auto joined = std :: views :: join_with ( words_up , std :: string_view ( " " )); for ( auto c : joined ) std :: cout c ; } See at Compiler Explorer Hereβs the expected output: THE C++ RANGES LIBRARY Creating new containers from the view I think I overlooked one important aspect of our experiments. Itβs good that we can print flattened or concatenated rangesβ¦ but what if you want to create another container from that view? A simple example could be as follows: std :: vector int > make_flat ( const std :: vector std :: vector int >> & nested ) { // ?? } auto new_vector = make_flat ( vec_vec ); We have at least four options here: Before C++23, we can push data to the new container in some loop, Or pass begin() and end() iterators, For C++23, we can use ranges::to() , Or, also for C++23, create container directly from a range/view. See the example here: #include #include #include #include #include std :: vector int > make_flat_loop ( const std :: vector std :: vector int >>& nested ) { std :: vector int > out ; for ( int value : nested | std :: views :: join ) out . push_back ( value ); return out ; } std :: vector int > make_flat_iters ( const std :: vector std :: vector int >>& nested ) { auto joined = nested | std :: views :: join ; return { joined . begin (), joined . end () }; } std :: vector int > make_flat_to ( const std :: vector std :: vector int >>& nested ) { return nested | std :: views :: join | std :: ranges :: to std :: vector int >> (); } std :: vector int > make_flat_from_range ( const std :: vector std :: vector int >>& nested ) { auto joined = nested | std :: views :: join ; return std :: vector int > ( std :: from_range , joined ); } int main () { std :: vector std :: vector int >> nested {{ 1 , 2 }, { 3 , 4 , 5 }, { 6 , 7 }}; auto flat1 = make_flat_loop ( nested ); auto flat2 = make_flat_iters ( nested ); auto flat3 = make_flat_to ( nested ); auto flat4 = make_flat_from_range ( nested ); for ( auto && flat : { flat1 , flat2 , flat3 , flat4 }) { for ( int value : flat ) std :: print ( "{} " , value ); std :: println ( "" ); } std :: vector std :: string > words { "C++" , "ranges" , "are" , "powerful" }; auto sentence = std :: string ( std :: from_range , std :: views :: join_with ( words , std :: string_view ( " " )) ); std :: println ( "{}" , sentence ); } See @Compiler Explorer The output: 1 2 3 4 5 6 7 1 2 3 4 5 6 7 1 2 3 4 5 6 7 1 2 3 4 5 6 7 C++ ranges are powerful The C++23 changes came from the following proposal: P1206R7 - Conversions from ranges to containers . Comparing concat_view , join_view , and join_with_view Feature concat_view β
join_view β
join_with_view β
Works on multiple independent ranges? β
β β Flattens nested ranges? β β
β
Supports separators between sub-ranges? β β β
Random access support? β
(if all inputs support it) β β Summary C++βs range adaptors provide efficient ways to manipulate collections without unnecessary copying. Hereβs a quick summary of when to use each view: Use concat_view when merging multiple independent ranges. Use join_view when flattening a range of ranges. Use join_with_view when flattening a range of ranges but needing a separator between elements. References Books: C++23 Best Practices - by Jason Turner Modern C++ Programming Cookbook - by Marius Bancila Programming: Principles and Practice Using C++ - by Bjarne Stroustrup Other: std::ranges::join_view - cppreference.com std::ranges::join_with_view - cppreference.com std::ranges::concat_view - cppreference.com Back to you Do you use ranges? What are your most useful views ald algorithms on ranges? Share your comments belowπC++ StoriesFriday, May 15, 2026
Principle Misunderstandings Of C++ Software Design - Kevlin Henney - C++Online 2026π₯CppOnline
The case of the CreateΒFileΒMapping that always reported ERROR_ALREADY_EXISTSMaybe because it already exists? The post The case of the CreateΒFileΒMapping that always reported ERROR_ ALREADY_ EXISTS appeared first on The Old New Thing .πThe Old New Thing
Lightning Talk: Bool - Implicitly Dangerous - Jeff Garland - CppCon 2025π₯CppCon
When to copy instead of move - threads & containersπ₯MeetingCpp
Qt Interface Framework with a new Control PanelYou've just implemented a new feature on the project you're working on. Now, it's time to test how does it work when the data is connected. In case you're working on a device which needs to listen to external devices or sensors, this might not be a trivial problem to solve.πQt Blog
Cross-Platform Music Software with Rust - Ian Hobson - ADC 2025π₯audiodevconThursday, May 14, 2026
Classes and RAII with βscopeβ - part 2 of N [D Language - Dlang Episode 140]π₯Mike Shah
Segment Heap support for C++ projects in Visual StudioLearn how Visual Studio enables Segment Heap by default for new C++ projects and how to adopt and verify it in existing builds. The post Segment Heap support for C++ projects in Visual Studio appeared first on C++ Team Blog .πC++ Team Blog
A constant-space linear-time algorithm for deleting all but the 10 most recent files in a directoryUsing data structures you already knew. The post A constant-space linear-time algorithm for deleting all but the 10 most recent files in a directory appeared first on The Old New Thing .πThe Old New Thing
Lightning Talk: Proof Searching in DepC - Raffaele Rossi - CppCon 2025π₯CppCon
Manipulating URLs with Boost URLπ₯Utah Cpp Programmers
Let's make a programming language!π₯PVS-StudioWednesday, May 13, 2026
SIMD-Accelerated Data Processingπ₯GlobalCpp
MSVC Build Tools Preview updates β May 2026Try the latest updates to MSVC Build Tools Preview The post MSVC Build Tools Preview updates β May 2026 appeared first on C++ Team Blog .πC++ Team Blog
The case of the hang when the user changed keyboard layoutsKeeping things moving. The post The case of the hang when the user changed keyboard layouts appeared first on The Old New Thing .πThe Old New Thing
Lightning Talk: The Classic Missed-Signal! - Gopal Rander - CppCon 2025π₯CppCon
Raga as Data: Symbolic Music Representations for Analysis, Visualization & Audio Tools - ADCx Indiaπ₯audiodevcon
Make move constructors noexcept or vectors will copy #cplusplusπ₯MeetingCpp
Happy 8th anniversary C++ InsightsThis year, we celebrate the 8th anniversary of C++ Insights! Thank you all for the wonderful years of support! The current status I've been a bit slower in updating C++ Insights to work with the latest Clang version. As a birthday gift I released the latest C++ Insights version which β¦πAndreasFertig.com