C++11的函數(shù)包裝器std::function使用示例
C++中的函數(shù)包裝器(Function Wrapper)是用來(lái)封裝和管理函數(shù)或可調(diào)用對(duì)象(如函數(shù)指針、函數(shù)對(duì)象、Lambda 表達(dá)式等)的工具。它們使得函數(shù)的使用更為靈活和通用,常被用于異步編程、事件處理、回調(diào)等場(chǎng)景。
C++11引入的 std::function 是最常用的函數(shù)包裝器。它可以存儲(chǔ)任何可調(diào)用對(duì)象并提供統(tǒng)一的調(diào)用接口。以下是關(guān)于函數(shù)包裝器的詳細(xì)講解,包括它的基本用法、特點(diǎn)、限制、以及與其他相關(guān)機(jī)制的對(duì)比。
一、std::function 的基本用法
std::function 是 C++ 標(biāo)準(zhǔn)庫(kù)中的一個(gè)模板類,可以存儲(chǔ)一個(gè)可調(diào)用對(duì)象,如普通函數(shù)、函數(shù)指針、Lambda 表達(dá)式、或?qū)崿F(xiàn)了 operator() 的對(duì)象。
1. 基本語(yǔ)法
#include <iostream>
#include <functional>
void myFunction(int x) {
std::cout << "Function called with: " << x << std::endl;
}
int main() {
std::function<void(int)> func = myFunction; // 包裝普通函數(shù)
func(10); // 輸出: Function called with: 10
// 也可以包裝 Lambda 表達(dá)式
func = [](int y) {
std::cout << "Lambda called with: " << y << std::endl;
};
func(20); // 輸出: Lambda called with: 20
return 0;
}二、如何使用 std::function
1. 存儲(chǔ)不同類型的可調(diào)用對(duì)象
std::function 可以存儲(chǔ)任何可以調(diào)用的對(duì)象,包括函數(shù)、Lambda 表達(dá)式和函數(shù)對(duì)象。
#include <iostream>
#include <functional>
int add(int a, int b) {
return a + b;
}
struct Multiply {
int operator()(int a, int b) const {
return a * b;
}
};
int main() {
std::function<int(int, int)> func;
// 包裝普通函數(shù)
func = add;
std::cout << "Add: " << func(3, 4) << std::endl; // 輸出: Add: 7
// 包裝函數(shù)對(duì)象
func = Multiply();
std::cout << "Multiply: " << func(3, 4) << std::endl; // 輸出: Multiply: 12
// 包裝 Lambda 表達(dá)式
func = [](int a, int b) { return a - b; };
std::cout << "Subtract: " << func(10, 4) << std::endl; // 輸出: Subtract: 6
return 0;
}2. 使用類型推導(dǎo)
C++14引入了泛型Lambda,進(jìn)一步增強(qiáng)了 std::function 的靈活性:
#include <iostream>
#include <functional>
int main() {
// 使用 Lambda 表達(dá)式的類型推導(dǎo)
auto lambda = [](int x) { return x * 2; };
std::function<int(int)> func = lambda;
std::cout << "Lambda result: " << func(5) << std::endl; // 輸出: Lambda result: 10
return 0;
}三、特點(diǎn)與限制
1. 類型安全
std::function 提供強(qiáng)類型安全,確保傳遞的可調(diào)用對(duì)象與指定的函數(shù)簽名相符。
2. 存儲(chǔ)開(kāi)銷
std::function 是一個(gè)類型擦除(Type Erasure)機(jī)制的實(shí)現(xiàn),它會(huì)根據(jù)保存的可調(diào)用對(duì)象的類型動(dòng)態(tài)分配內(nèi)存。盡管這使得類型更靈活,但也增加了一些運(yùn)行時(shí)開(kāi)銷。
3. 性能考慮
由于類型擦除的特性,std::function 的性能通常低于直接使用函數(shù)指針或 Lambda 表達(dá)式,特別是在高頻調(diào)用的場(chǎng)景下。如果對(duì)性能有較高要求,建議直接使用函數(shù)指針或模板。
四、結(jié)合 std::bind
std::bind 是一個(gè)C++11引入的函數(shù)適配器,允許將某些參數(shù)綁定到函數(shù)對(duì)象或 Lambda 表達(dá)式。與 std::function 結(jié)合使用可以使代碼更靈活。
#include <iostream>
#include <functional>
void print(int x, int y) {
std::cout << "x: " << x << ", y: " << y << std::endl;
}
int main() {
// 使用 std::bind 綁定部分參數(shù)
auto boundFunc = std::bind(print, 10, std::placeholders::_1);
// `boundFunc` 現(xiàn)在只需要一個(gè)參數(shù)
boundFunc(20); // 輸出: x: 10, y: 20
return 0;
}五、結(jié)合標(biāo)準(zhǔn)庫(kù)的異步操作
在使用異步處理時(shí),std::function 可以存儲(chǔ)要在新線程中執(zhí)行的函數(shù)。
#include <iostream>
#include <functional>
#include <thread>
void asyncTask(int id) {
std::cout << "Task " << id << " is running." << std::endl;
}
int main() {
// 聲明 std::function
std::function<void(int)> task = asyncTask;
// 創(chuàng)建新線程
std::thread t(task, 1);
t.join(); // 等待線程結(jié)束
return 0;
}六、總結(jié)
到此這篇關(guān)于C++11的函數(shù)包裝器std::function使用示例的文章就介紹到這了,更多相關(guān)C++11的函數(shù)包裝器std::function內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)數(shù)組Vector
這篇文章主要為大家詳細(xì)介紹了使用C語(yǔ)言實(shí)現(xiàn)動(dòng)態(tài)數(shù)組Vector的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01
C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單學(xué)生管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Matlab控制電腦攝像實(shí)現(xiàn)實(shí)時(shí)人臉檢測(cè)和識(shí)別詳解
人臉識(shí)別過(guò)程主要由四個(gè)階段組成:人臉檢測(cè)、圖像預(yù)處理、面部特征提取和特征識(shí)別。這篇文章主要介紹了如何使用MATLAB控制筆記本電腦的攝像頭,并進(jìn)行實(shí)時(shí)人臉檢測(cè)和識(shí)別,需要的可以參考一下2022-10-10
C語(yǔ)言中動(dòng)態(tài)內(nèi)存管理圖文詳解
在編寫(xiě)程序時(shí),通常并不知道需要處理的數(shù)據(jù)量,或者難以評(píng)估所需處理數(shù)據(jù)量的變動(dòng)程度,下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言中動(dòng)態(tài)內(nèi)存管理的相關(guān)資料,需要的朋友可以參考下2022-06-06

