template<typename R = void> 意義

在 C++ 中,template<typename R = void>?表示定義一個模板參數?R,其默認類型為?void。這意味著:

  1. 如果用戶沒有顯式指定?R,則?R?默認為?void
  2. 如果用戶顯式指定了?R(如?template<typename R = void>?后面跟著?<int>),則?R?會被替換為指定的類型(如?int)。

1. 基本用法

1.1 默認模板參數?void

template<typename R = void>
class MyClass {
public:
using ResultType = R; // 定義一個類型別名
};
int main() {
MyClass<> obj1; // R 默認為 void
MyClass<int> obj2; // R 顯式指定為 int
// 檢查類型
static_assert(std::is_same_v<MyClass<>::ResultType, void>); // true
static_assert(std::is_same_v<MyClass<int>::ResultType, int>); // true
}
  • MyClass<>?使用默認模板參數?void
  • MyClass<int>?顯式指定?R?為?int

1.2 結合函數模板

template<typename R = void>
R default_value() {
if constexpr (std::is_void_v<R>) {
return; // void 返回類型不能有返回值
} else {
return R{}; // 默認構造 R 類型
}
}
int main() {
default_value(); // R = void,無返回值
int x = default_value<int>(); // R = int,返回 0(默認構造)
}
  • 當?R = void?時,函數不能返回任何值。
  • 當?R = int?時,函數返回?int{}(即?0)。

2. 常見應用場景

2.1 回調函數(Callback)的默認返回類型

template<typename R = void>
class Callback {
public:
using ReturnType = R;
virtual R execute() = 0; // 純虛函數
};
// 特化 void 返回類型的情況
template<>
class Callback<void> {
public:
void execute() { /* 不需要返回值 */ }
};
  • 如果回調函數不需要返回值,可以使用?Callback<>(默認?void)。
  • 如果需要返回值,可以指定?Callback<int>?等。

2.2 函數對象(Functor)的默認行為

template<typename R = void>
struct Identity {
R operator()(R x) { return x; }
};
template<>
struct Identity<void> {
void operator()(auto x) { /* 不返回任何值 */ }
};
int main() {
Identity<int> id_int;
int a = id_int(42); // 返回 42
Identity<> id_void;
id_void(42); // 無返回值
}
  • Identity<int>?返回輸入值。
  • Identity<>(即?Identity<void>)不返回任何值。

2.3 通用函數包裝器(類似?std::function

template<typename R = void, typename... Args>
class FunctionWrapper {
public:
virtual R invoke(Args... args) = 0;
};
// 特化 void 返回類型
template<typename... Args>
class FunctionWrapper<void, Args...> {
public:
virtual void invoke(Args... args) = 0;
};
  • 如果?R = void,則?invoke()?不返回任何值。
  • 否則,invoke()?返回?R?類型的值。

3. 與?std::function?的對比

C++ 標準庫中的?std::function?也使用了類似的技巧:

std::function<int()> func1; // 返回 int
std::function<void()> func2; // 返回 void
std::function<> func3; // 錯誤!必須指定返回類型
  • std::function?不能省略返回類型(必須顯式指定?R)。
  • 但自定義模板可以設置默認?R = void,使?MyFunction<>?合法。

4. 總結

特性說明
template<typename R = void>定義一個默認類型為?void?的模板參數
適用場景回調函數、函數對象、通用包裝器
與?void?相關的特殊處理void?不能用于返回值(如?return;)或構造(如?R{}
C++17?if constexpr?結合可以針對?void?和非?void?類型做不同處理

關鍵點

  1. void?是一個不完整的類型,不能直接實例化(如?void x;?非法)。
  2. void?用于函數返回類型時,表示不返回任何值
  3. 模板默認參數?可以簡化代碼,避免重復指定常見類型(如?void)。

這種技巧在泛型編程中非常有用,特別是需要處理“可能無返回值”的情況。

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

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

相關文章

國產3D大型裝配設計新突破①:圖紙打開設計雙加速 | 中望3D 2026

本文為CAD芯智庫整理&#xff0c;未經允許請勿復制、轉載&#xff01;在中望3D 2026的新版中&#xff0c;不僅在設計效率上進行了重大優化&#xff0c;更是在裝配方面實現了突破性的改進&#xff0c;讓每一個項目都能快速、精確地從概念變為現實。 中望3D2026亮點速遞裝配篇將…

游戲開發狀態機與行為樹的優缺點

在游戲開發中&#xff0c;狀態機&#xff08;Finite State Machine, FSM&#xff09; 和行為樹&#xff08;Behavior Tree, BT&#xff09; 是兩種常用的 AI 邏輯控制框架&#xff0c;分別適用于不同場景&#xff0c;其優缺點對比可從靈活性、維護成本、適用場景等多個維度分析…

Linux下ELF文件的介紹

目錄 1.溫故知新 2.ELF文件介紹 3.ELF文件組成 4.ELF文件形成到加載 5.連接過程 1.溫故知新 上一篇博客&#xff0c;我們介紹了我們的動靜態&#xff0c;知道了我們的庫其實也是文件&#xff0c;如果我們想寫一個庫也是可以的&#xff0c;我們的把我們的庫文件編譯成.o文件…

人工智能領域、圖歐科技、IMYAI智能助手2025年6月更新月報

2025年6月AI領域重要模型更新與平臺優化匯總 摘要&#xff1a; 本文匯總了2025年6月期間AI領域發布的多項重要模型更新及平臺功能優化信息&#xff0c;涵蓋Google Gemini、阿里通義萬相、字節豆包、百度文心一言、MiniMax海螺02、Google Veo3、快手可靈2.1、FLUX Kontext等模型…

從零開始學Express,理解服務器,路由于中間件

當我們初學前端時&#xff0c;常常只關注頁面效果和交互&#xff0c;但隨著項目復雜度提升&#xff0c;我們遲早會遇到“服務端”的問題&#xff1a;如何讓一個頁面的數據是從數據庫來的&#xff1f;怎么讓不同的用戶看到不同的內容&#xff1f;這時候&#xff0c;我們就需要一…

Codeforces Round 987 (Div. 2)

ABC 略D預處理出每個位置的前綴最大和后綴最小。從后向前枚舉&#xff0c;如果一個數無法后移&#xff0c;那么答案就是最大前綴&#xff0c;否則答案要不是前綴最大&#xff0c;要不就是這個數先移到前綴最大位置再移到能移到的最大的位置此處的答案。用線段樹維護#include<…

Javascript/ES6+/Typescript重點內容篇——手撕(待總結)

前端核心知識點梳理與面試題詳解 1. Promise 核心知識點 Promise 是異步編程的解決方案&#xff0c;用于處理異步操作三種狀態&#xff1a;pending&#xff08;進行中&#xff09;、fulfilled&#xff08;已成功&#xff09;、rejected&#xff08;已失敗&#xff09;狀態一旦改…

[自動化Adapt] 父子事件| 冗余過濾 | SQLite | SQLAlchemy | 會話工廠 | Alembic

第五章&#xff1a;事件處理與融合 歡迎回到OpenAdapt探索之旅~ 在第四章&#xff1a;系統配置中&#xff0c;我們掌握了如何定制化系統參數。更早的第一章&#xff1a;錄制引擎則展示了系統如何捕獲海量原始操作數據。 假設我們需要訓練機器人輸入"hello"一詞。原…

組合期權:跨式策略

文章目錄0.簡介1.買入跨式組合&#xff08;Long Straddle&#xff09;1.1 適用場景?1.2 合約選擇1.3 損益分析1.4 案例示范2.賣出跨式組合&#xff08;Short Straddle&#xff09;2.1 適用場景?2.2 合約選擇2.3 損益分析2.4 案例示范3.小結參考文獻0.簡介 跨式策略是一種交易…

Vue計算屬性詳解2

可寫計算屬性 計算屬性默認是只讀的,但在特殊場景下,我們可以創建"可寫"的計算屬性,通過同時提供getter和setter實現: <script setup>import { ref, computed } from vueconst firstName = ref(John)const lastName = ref(Doe)const fullName = computed(…

UniStorm 5.3.0 + Unity2022 + URP配置說明

一、前言 以前我用的是UniStorm3.0&#xff0c;主要用在內置管線里面&#xff0c;最近想在URP管線里面使用UniStorm天氣系統&#xff0c;于是弄了UniStorm5.3.0的包&#xff0c;在Unity2022.3的URP模式下配置&#xff0c;直接導入package&#xff0c;兩次宣告失敗。最后看了官方…

力扣經典算法篇-44-組合總和(回溯問題)

1、題干 給你一個無重復元素的整數數組candidates和一個目標整數 target &#xff0c;找出 candidates 中可以使數字和為目標數 target 的 所有 不同組合 &#xff0c;并以列表形式返回。你可以按 任意順序 返回這些組合。 candidates 中的 同一個 數字可以 無限制重復被選取 。…

矩陣與高斯消元:數學算法在計算機領域的應用

一、概述和基本概念 矩陣&#xff0c;類似于在 C 中我們看到的二維數組。它有兩個維度&#xff0c;行和列。下面是一個典型的矩陣&#xff1a; M[12342345445610111213] M \begin{bmatrix} 1 & 2 & 3 & 4 \\ 2 & 3 & 4 & 5 \\ 4 & 4 & 5 &…

【補題】CodeTON Round 1 (Div. 1 + Div. 2, Rated, Prizes!) D. K-good

題意&#xff1a;給一個n&#xff0c;如果能被k個數整除&#xff0c;要求這k個數%k后不相同&#xff0c;問如果可以&#xff0c;任意k是多少&#xff0c;如果不可以輸出-1 思路&#xff1a; D. K-good_牛客博客 從來沒見過&#xff0c;太詭異了&#xff0c;做題做少了 1.…

LLM推理框架的“權力的游戲”:vLLM之后的群雄逐鹿

既然我們已經深入探討了本地與云端的兩大代表Ollama和vLLM&#xff0c;是時候將視野拓寬&#xff0c;檢視一下在高性能推理這片“高手如云”的競技場中&#xff0c;還有哪些重量級的玩家。vLLM的出現點燃了戰火&#xff0c;但遠非終點。 歡迎來到LLM推理框架的“后vLLM時代”—…

TDengine IDMP 背后的技術三問:目錄、標準與情景

過去十年&#xff0c;#工業 和#物聯網 場景經歷了快速的#數字化 建設&#xff1a;傳感器接入、系統聯網、數據上云……數據平臺已能輕松承載每秒千萬級別的寫入&#xff0c;每天幾 TB 的存儲量。但今天再回頭看&#xff0c;這些看似“完成”的系統&#xff0c;實際上只解決了一…

MyBatis基礎操作完整指南

文章目錄MyBatis簡介環境搭建Maven依賴數據庫表結構核心配置MyBatis配置文件數據庫配置文件實體類基礎CRUD操作Mapper接口Mapper XML映射文件工具類測試類動態SQL常用標簽高級特性一對一關聯映射一對多關聯映射分頁查詢使用注解方式MyBatis簡介 MyBatis是Apache的一個開源項目…

go與grpc

目錄下載與安裝遇到的問題cmd中protoc找不到命令cmd中--go_out: protoc-gen-go: Plugin failed with status code 1.下載與安裝 下載protoc&#xff1a; https://github.com/protocolbuffers/protobuf/releases 點擊下載相應電腦版本即可&#xff0c;我是windows系統下載了pro…

2025年AI面試重構招聘新生態

當企業面臨業務擴張與人才競爭的雙重壓力&#xff0c;傳統招聘模式已難以滿足高效、精準、公平的人才篩選需求。尤其在校招季、藍領用工潮等關鍵節點&#xff0c;面試官超負荷運轉、跨地域協調困難、評估標準模糊等問題頻發。AI技術的深度介入正推動招聘行業從“經驗驅動”向“…

Rust進階-part5-trait

Rust進階[part5]_trait trait概述 在 Rust 中,trait 是一種定義共享行為的方式。它類似于其他語言中的接口,允許我們定義一組方法簽名,然后讓不同的類型去實現這些方法。通過 trait,我們可以實現多態性,即不同類型可以以統一的方式處理。 普通實現 使用 trait 關鍵字來…