【C++20新特性】ranges::sort()使用方法,優勢,注意點

以下是關于 ranges::sort() 的詳細說明:

1. ranges::sort() 的使用方法

ranges::sort()C++20 引入的基于范圍(Ranges)的排序函數,其語法更簡潔,支持直接操作容器或范圍對象。

(1)基本用法

#include <vector>
#include <ranges>
#include <algorithm>int main() {std::vector<int> numbers = {3, 1, 4, 1, 5};std::ranges::sort(numbers); // 直接對容器排序return 0;
}

(2)逆序排序

通過傳遞 std::greater<> 實現降序:

std::ranges::sort(numbers, std::greater<>());

(3)自定義排序規則

使用 Lambda 表達式或自定義比較函數:

std::ranges::sort(numbers, [](int a, int b) {return a % 3 < b % 3; // 按模3的余數排序
});

2. 相比于傳統 std::sort 的優勢

(1) 更簡潔的語法

傳統 std::sort 需要手動指定迭代器范圍:

std::sort(numbers.begin(), numbers.end());

ranges::sort 直接操作容器,省去迭代器:

std::ranges::sort(numbers); // 無需 begin/end 

(2) 支持范圍概念(Concepts)

ranges::sort 在編譯期通過概念(Concepts)檢查參數合法性,錯誤提示更清晰。例如,若元素類型不支持比較,編譯器會直接報錯。

(3) 與范圍庫的無縫結合

可與其他范圍適配器(如視圖 views)結合使用,實現鏈式操作:

// 過濾偶數后排序
auto filtered = numbers | std::views::filter([](int x) { return x % 2 == 0; });
std::ranges::sort(filtered);

(4) 性能優化

對大型數據集可能有性能優化,因底層實現可能采用更高效的策略。

3. 使用注意點

(1) C++20 兼容性

需確保編譯器支持 C++20 標準(如 GCC 10+、Clang 13+、MSVC 19.29+)。

(2) 元素類型需支持比較

元素類型必須定義 < 運算符或提供自定義比較函數。否則編譯失敗。

(3) 比較函數的嚴格弱序

自定義比較函數需滿足嚴格弱序(Strict Weak Ordering),否則行為未定義。

(4) 視圖的惰性計算

若對視圖(如 views::filter 結果)調用 ranges::sort,需注意視圖可能是惰性計算的,可能導致意外結果3。
總結

ranges::sort 通過簡化語法、增強類型安全和優化性能,成為 C++20 中更現代的排序選擇。在支持 C++20 的項目中優先使用,可提升代碼可讀性和健壯性。傳統 std::sort 仍適用于舊代碼或低版本編譯器環境。

4. 實際分析

看靈神的代碼的時候發現一個排序是這樣寫的:

vector<vector<int>> queries;
//...
ranges::sort(queries, {}, [](auto& q) { return q[0]; });

這段代碼的作用是對二維向量 queries 按每行第一個元素(即 q)進行升序排序。以下是詳細分析:


4.1 代碼解析

ranges::sort(queries, {}, [](auto& q) { return q; });
  • 參數含義

    • queries:待排序的二維向量(vector<vector<int>>)。
    • {}:占位符,表示使用默認比較規則(std::less,即升序)。
    • [](auto& q) { return q; }:投影函數(Projection),指定排序依據為每行的第一個元素 q
  • 等效傳統寫法(使用 std::sort):

    std::sort(queries.begin(), queries.end(), [](const auto& a, const auto& b) {return a < b;
    });
    

4.2 優勢:ranges::sort 的簡潔性

  1. 直接操作容器:無需手動傳遞 begin/end 迭代器(傳統寫法需 queries.begin(), queries.end())。
  2. 投影函數:通過 [](auto& q) { return q; } 直接指定排序字段,避免了在比較函數中重復提取 ab,代碼更簡潔。
  3. 類型安全:C++20 的 ranges::sort 通過概念(Concepts)檢查參數合法性,確保投影后的值可比較。

3. 注意點

  1. 子向量非空:必須確保每行子向量至少有一個元素,否則 q 會導致未定義行為(如越界訪問)。
  2. 嚴格弱序:默認使用 std::less 升序排序,若需降序,需顯式傳遞 std::greater{} 作為第二個參數:
    ranges::sort(queries, std::greater{}, [](auto& q) { return q; });
    
  3. 兼容性:需編譯器支持 C++20(如 GCC 10+、Clang 13+)。

4. 與傳統 std::sort 的對比

特性ranges::sort傳統 std::sort
語法簡潔性直接操作容器,無需迭代器需手動傳遞 begin/end 迭代器
投影函數支持,簡化字段提取邏輯需在比較函數中顯式提取字段
類型檢查編譯期概念檢查,錯誤提示更友好運行時可能因類型錯誤崩潰

總結

這段代碼利用 C++20 的 ranges::sort 對二維向量按首元素升序排序,通過投影函數簡化了邏輯,是更現代的寫法。注意確保子向量非空,并根據需求調整升/降序規則。在支持 C++20 的項目中推薦優先使用 ranges::sort

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/82149.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/82149.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/82149.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深入理解設計模式之適配器模式

深入理解設計模式之適配器模式 1. 適配器模式概述 適配器模式(Adapter Pattern)是一種結構型設計模式&#xff0c;它允許將一個類的接口轉換為客戶端所期望的另一個接口。適配器模式使得原本由于接口不兼容而不能一起工作的類能夠協同工作&#xff0c;扮演了"轉換器&quo…

【數據結構 · 初階】- 快速排序

目錄 一. Hoare 版本 1. 單趟 2. 整體 3. 時間復雜度 4. 優化&#xff08;搶救一下&#xff09; 4.1 隨機選 key 4.2 三數取中 二. 挖坑法 格式優化 三. 前后指針&#xff08;最好&#xff09; 四. 小區間優化 五. 改非遞歸 快速排序是 Hoare 提出的一種基于二叉樹…

第2周 PINN核心技術揭秘: 如何用神經網絡求解偏微分方程

1. PDEs與傳統數值方法回顧 (Review of PDEs & Traditional Numerical Methods) 1.1 什么是偏微分方程 (Partial Differential Equations, PDEs)? 偏微分方程是描述自然界和工程領域中各種物理現象(如熱量傳播、流體流動、波的振動、電磁場分布等)的基本數學語言。 1.…

Neo4j(二) - 使用Cypher操作Neo4j

文章目錄 前言一、Cypher簡介二、數據庫操作1. 創建數據庫2. 查看數據庫3. 刪除數據庫4. 切換數據庫 三、節點、關系及屬性操作1. 創建節點與關系1.1 語法1.2 示例 2. 查詢數據2.1 語法2.2 示例 3. 更新數據3.1 語法3.2 示例 4. 刪除節點與關系4.1 語法4.2 示例 5. 合并數據5.1…

RabbitMQ的Web管理頁面給我看懵了,這都什么意思啊

文章目錄 OverviewTotalsMessage RatesQueued Messages NodesChurn StatisticsPorts and ContextsExport DefinitionsImport Definitions ConnectionsChannelsExchangesQueuesAdmin他們之間的關聯 在上一篇文章中我們講到了如何在Windows中安裝Rabbitmq&#xff0c; 小白也能搞…

安全基礎與協議分析

5.1 Web安全基礎 5.1.1 Web安全基礎概覽&#xff08;一、二&#xff09; Web安全的核心目標是保護Web應用及其數據免受攻擊&#xff0c;涵蓋以下關鍵領域&#xff1a; 攻擊面&#xff1a; 前端漏洞&#xff08;XSS、CSRF&#xff09;。 后端漏洞&#xff08;SQL注入、RCE&a…

STM32項目實戰:ADC采集

STM32F103C8T6的ADC配置。PB0對應的是ADC1的通道8。在標準庫中&#xff0c;需要初始化ADC&#xff0c;設置通道&#xff0c;時鐘&#xff0c;轉換模式等。需要配置GPIOB的第0腳為模擬輸入模式&#xff0c;然后配置ADC1的通道8&#xff0c;設置轉換周期和觸發方式。 接下來是I2C…

第十四章:數據治理之數據源:數據源的數據接入、業務屬性梳理及監控

本章開始&#xff0c;將進入9大模塊的介紹。第一個模塊我們先介紹&#xff1a;數據源。數據源是整個數據中臺數據的來源&#xff0c;是一個起點。更好的管理好數據源這個起點&#xff0c;是數據治理的一個好的開始。 在【數據&#xff1a;業務生數據&#xff0c;數據生“萬物”…

【C/C++】多線程開發:wait、sleep、yield全解析

文章目錄 多線程開發&#xff1a;wait、sleep、yield全解析1 What簡要介紹詳細介紹wait() — 條件等待&#xff08;用于線程同步&#xff09;sleep() — 睡覺&#xff0c;定時掛起yield() — 自愿讓出 CPU 2 區別以及建議區別應用場景建議 3 三者協作使用示例 多線程開發&#…

阿里云CDN刷新預熱--刷新URL

文章目錄 一、全英文URL刷新預熱二、摻雜中文的URL刷新預熱2.1 對帶中文URL進行編碼2.2 預熱刷新 三、CDN刷新-核心作用與價值3.1 核心作用3.2 核心價值3.3 典型使用場景 *最后我想說&#xff1a;請你不要相信我說的每一句話&#xff0c;這只是我的個人經驗* 一、全英文URL刷新…

Oracle 19c DG備庫報錯ORA-00313、ORA-00312、ORA-27037

Oracle 19c DG備庫報錯ORA-00313、ORA-00312、ORA-27037 錯誤排查問題處理錯誤排查 DG同步完成后,DG Broker show database發現以下告警信息: Database Warning(s):ORA-16826: apply service state is inconsistent with the DelayMins propertyORA-16789: standby redo log…

開源與閉源之爭:AI時代的創新博弈與未來抉擇

在人工智能技術狂飆突進的今天&#xff0c;開源與閉源之爭已不再局限于技術圈的討論&#xff0c;而是演變為一場關乎技術倫理、商業格局乃至人類文明走向的深度博弈。當Meta的Llama 3開源模型下載量突破百萬&#xff0c;當OpenAI的GPT-5繼續加固技術壁壘&#xff0c;這場沒有硝…

NIFI的處理器:JSLTTransformJSON 2.4.0

該處理器使用JSLT轉換FlowFile JSON有效負載的格式。使用轉換后的內容創建新的FlowFile&#xff0c;并將其路由到“成功”關系。如果JSLT轉換失敗&#xff0c;則將原始FlowFile路由到“失敗”關系。 需要注意的是&#xff0c;編譯JSLT轉換可能相當昂貴。理想情況下&#xff0c…

MySQL 索引失效及其解決辦法

一、前言 在數據庫優化中,索引(Index)是一項至關重要的技術手段,可以顯著提升查詢性能。然而,在實際開發過程中,MySQL 索引并不總是如預期生效。本文將從原理出發,系統地介紹索引失效的常見場景及其解決方案,幫助開發者有效規避性能陷阱。 二、索引基礎回顧 MySQL 支…

趨勢觸發策略

趨勢觸發策略(TS版)是一種基于TrendTriggerFactor(TTF)的交易策略,通過柱狀圖顏色變化指示市場趨勢的強度,并根據TTF的穿越信號進行買賣操作。 TTF是通過計算買方力量和賣方力量的差值除以兩者之和的一半再乘以100得到的。 當TTF大于100時,柱狀圖顯示為綠色,表示市場…

DeepSeek-R1 模型現已在亞馬遜云科技上推出

亞馬遜云科技提供眾多免費云產品&#xff0c;可以訪問&#xff1a;亞馬遜云科技 在剛剛過去的 Amazon re&#xff1a;Invent 期間&#xff0c;Amazon 首席執行官 Andy Jassy 分享了從 Amazon 自己在全公司開發近 1000 個生成式 AI 應用程序的經驗中汲取的寶貴經驗。從這種廣泛…

中臺項目-微前端qiankun-umimax

學習視頻&#x1f50a; 基礎&#xff1a; 黑馬前端基于qiankun搭建微前端項目實戰教程_嗶哩嗶哩_bilibili 路由、部署配置注意&#xff1a;qiankunvite微前端上線注意事項&#xff0c;base公共路徑設置_嗶哩嗶哩_bilibili 微前端 什么是微前端&#xff1f; 微前端是將前端應…

【Java學習筆記】代碼塊

代碼塊 介紹&#xff1a;代碼塊又稱為初始化塊&#xff0c;屬于類中的成員&#xff08;即是類的一部分&#xff09;&#xff0c;類似于方法&#xff0c;將邏輯語句封裝在方法體中&#xff0c;通過{}包圍起來 與類方法的不同點 無方法名 無返回類型 無參數 只有方法體&#…

spring boot 2.7集成舊的springfox-boot-starter swagger oas 3.0

舊版本目前已經不維護推薦使用 springdoc-openapi-ui&#xff0c;這里為了演示使用舊的最新依賴 <dependency><groupId>io.springfox</groupId><artifactId>springfox-boot-starter</artifactId><version>3.0.0</version> </dep…

Linux按鍵驅動測試方式詳細介紹

Linux按鍵驅動測試可采用以下分層方法&#xff1a; 基礎事件檢測 使用輸入子系統調試工具&#xff1a; sudo apt install evtest # 安裝事件測試工具 evtest # 選擇對應設備編號觸發按鍵后觀察終端輸出&#xff0c;正常情況應顯示&#xff1a; Event:…