C++ invoke
invoke是C++17標準引入的一個函數(shù)模板,用來調(diào)用可調(diào)用對象(Callable Object,如函數(shù)指針、函數(shù)對象、成員函數(shù)指針等)并返回結(jié)果。
invoke提供了統(tǒng)一的調(diào)用語法,無論可調(diào)用對象的類型是什么,都可以使用同一種方式進行調(diào)用。
在C++17之前,調(diào)用不同類型的可調(diào)用對象需要使用不同的語法,比如直接調(diào)用函數(shù)、使用類對象的運算符重載操作符()來調(diào)用函數(shù)對象、使用成員函數(shù)指針來調(diào)用類成員函數(shù)等等。這些調(diào)用方式雖然能用,但是不夠靈活,而invoke解決了這種不一致的問題。
invoke函數(shù)的實現(xiàn)原理是通過使用SFINAE(Substitution Failure Is Not An Error)技術(shù)來判斷可調(diào)用對象的類型,并根據(jù)類型調(diào)用對應(yīng)的調(diào)用方式。因此,無論可調(diào)用對象的類型是什么,都可以使用invoke函數(shù)來調(diào)用,而不需要使用不同的語法。
下面是invoke的示例代碼:
#include#include void foo(int a, int b) { std::cout << "a + b = " << a + b << std::endl; } class Bar { public: void operator()(int a, int b) { std::cout << "a - b = " << a - b << std::endl; } }; int main() { int a = 10, b = 5; std::invoke(foo, a, b); // 調(diào)用普通函數(shù) Bar bar; std::invoke(bar, a, b); // 調(diào)用函數(shù)對象 std::invoke(&Bar::operator(), bar, a, b); // 調(diào)用成員函數(shù) std::function f = foo; std::invoke(f, a, b); // 調(diào)用std::function對象 return 0; }
總結(jié):std::invoke 提供了一種通用的函數(shù)調(diào)用語法,可以方便地調(diào)用各種可調(diào)用對象。
function與invoke的區(qū)別
std::function和std::invoke是兩個不同的東西,功能也不同。std::function是一個函數(shù)對象的封裝器,可以用來封裝任意類型的可調(diào)用對象,比如函數(shù)指針、lambda表達式等,而 std::invoke 則是一個函數(shù)模板,用于在統(tǒng)一的接口下調(diào)用可調(diào)用對象。
比如,我們可以使用std::function來存儲一個函數(shù)指針:
#include#include void foo(int a, int b) { std::cout << "foo(" << a << ", " << b << ")" << std::endl; } int main() { std::function f = foo; f(1, 2); }
上述代碼中,我們將函數(shù)指針foo封裝成了一個std::function對象f,然后通過調(diào)用f(1, 2)來調(diào)用函數(shù)foo。
std::invoke的作用是提供一種通用的函數(shù)調(diào)用語法,可以用統(tǒng)一的方式來調(diào)用各種可調(diào)用對象,而不必關(guān)心它們具體是什么類型。
比如,可以使用std::invoke來調(diào)用一個東西,無論這個東西是函數(shù)指針、函數(shù)對象還是成員函數(shù)指針:
#include#include void foo(int a, int b) { std::cout << "foo(" << a << ", " << b << ")" << std::endl; } class Bar { public: void bar(int a, int b) const { std::cout << "Bar::bar(" << a << ", " << b << ")" << std::endl; } }; int main() { std::invoke(foo, 1, 2); Bar b; std::invoke(&Bar::bar, &b, 1, 2); }
上面代碼,使用std::invoke分別調(diào)用了函數(shù)foo和類Bar的成員函數(shù)bar,并傳遞了相應(yīng)的參數(shù)。
總結(jié),std::function和std::invoke的使用場景是不同的。std::function 適用于需要存儲可調(diào)用對象的場景,而std::invoke則適用于統(tǒng)一調(diào)用各種不同類型的可調(diào)用對象的場景。
審核編輯:劉清
-
存儲器
+關(guān)注
關(guān)注
38文章
7492瀏覽量
163842 -
C++語言
+關(guān)注
關(guān)注
0文章
147瀏覽量
6992 -
封裝器
+關(guān)注
關(guān)注
0文章
7瀏覽量
5877
原文標題:C++ invoke與function的區(qū)別
文章出處:【微信號:程序喵大人,微信公眾號:程序喵大人】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論