91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

std::function簡(jiǎn)介及模板類聲明

5jek_harmonyos ? 來(lái)源:編程學(xué)習(xí)總站 ? 作者:寫代碼的牛頓 ? 2021-07-28 15:30 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

01

std::function簡(jiǎn)介

std::function是一個(gè)函數(shù)包裝器,該函數(shù)包裝器模板能包裝任何類型的可調(diào)用實(shí)體,如普通函數(shù),函數(shù)對(duì)象,lamda表達(dá)式等。包裝器可拷貝,移動(dòng)等,并且包裝器類型僅僅依賴于調(diào)用特征,而不依賴于可調(diào)用元素自身的類型。

std::function是C++11的新特性,包含在頭文件《functional》中。一個(gè)std::function類型對(duì)象實(shí)例可以包裝下列這幾種可調(diào)用實(shí)體:函數(shù)、函數(shù)指針、成員函數(shù)、靜態(tài)函數(shù)、lamda表達(dá)式和函數(shù)對(duì)象。

std::function對(duì)象實(shí)例可被拷貝和移動(dòng),并且可以使用指定的調(diào)用特征來(lái)直接調(diào)用目標(biāo)元素。當(dāng)std::function對(duì)象實(shí)例未包含任何實(shí)際可調(diào)用實(shí)體時(shí),調(diào)用該std::function對(duì)象實(shí)例將拋出std::bad_function_call異常。02

std::function實(shí)戰(zhàn)

std::function模板類聲明

template《class _Rp, class 。。._ArgTypes》 class _LIBCPP_TEMPLATE_VIS function《_Rp(_ArgTypes.。。)》 : public __function::__maybe_derive_from_unary_function《_Rp(_ArgTypes.。。)》, public __function::__maybe_derive_from_binary_function《_Rp(_ArgTypes.。。)》 { 。。. }std::function模板類成員函數(shù)聲明

typedef _Rp result_type; // construct/copy/destroy: _LIBCPP_INLINE_VISIBILITY function() _NOEXCEPT { } _LIBCPP_INLINE_VISIBILITY function(nullptr_t) _NOEXCEPT {} function(const function&); function(function&&) _NOEXCEPT; template《class _Fp, class = _EnableIfCallable《_Fp》》 function(_Fp); #if _LIBCPP_STD_VER 《= 14 template《class _Alloc》 _LIBCPP_INLINE_VISIBILITY function(allocator_arg_t, const _Alloc&) _NOEXCEPT {} template《class _Alloc》 _LIBCPP_INLINE_VISIBILITY function(allocator_arg_t, const _Alloc&, nullptr_t) _NOEXCEPT {} template《class _Alloc》 function(allocator_arg_t, const _Alloc&, const function&); template《class _Alloc》 function(allocator_arg_t, const _Alloc&, function&&); template《class _Fp, class _Alloc, class = _EnableIfCallable《_Fp》》 function(allocator_arg_t, const _Alloc& __a, _Fp __f); #endif function& operator=(const function&); function& operator=(function&&) _NOEXCEPT; function& operator=(nullptr_t) _NOEXCEPT; template《class _Fp, class = _EnableIfCallable《_Fp》》 function& operator=(_Fp&&); ~function(); // function modifiers: void swap(function&) _NOEXCEPT; #if _LIBCPP_STD_VER 《= 14 template《class _Fp, class _Alloc》 _LIBCPP_INLINE_VISIBILITY void assign(_Fp&& __f, const _Alloc& __a) {function(allocator_arg, __a, _VSTD::forward《_Fp》(__f)).swap(*this);} #endif // function capacity: _LIBCPP_INLINE_VISIBILITY _LIBCPP_EXPLICIT operator bool() const _NOEXCEPT { return static_cast《bool》(__f_); } // deleted overloads close possible hole in the type system template《class _R2, class.。。 _ArgTypes2》 bool operator==(const function《_R2(_ArgTypes2.。。)》&) const = delete; template《class _R2, class.。。 _ArgTypes2》 bool operator!=(const function《_R2(_ArgTypes2.。。)》&) const = delete; public: // function invocation: _Rp operator()(_ArgTypes.。。) const; #ifndef _LIBCPP_NO_RTTI // function target access: const std::type_info& target_type() const _NOEXCEPT; template 《typename _Tp》 _Tp* target() _NOEXCEPT; template 《typename _Tp》 const _Tp* target() const _NOEXCEPT; #endif // _LIBCPP_NO_RTTI從成員函數(shù)里我們知道std::function對(duì)象實(shí)例不允許進(jìn)行==和!=比較操作,std::function模板類實(shí)例最終調(diào)用成員函數(shù)_Rp operator()(_ArgTypes.。。) const進(jìn)而調(diào)用包裝的調(diào)用實(shí)體。1、std::function包裝函數(shù)指針定義一個(gè)std::function《int(int)》對(duì)象實(shí)例

std::function《int(int)》 callback;std::function對(duì)象實(shí)例包裝函數(shù)指針

int (*fun_ptr)(int); int fun1(int a){ return a; } int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; fun_ptr = fun1; //函數(shù)指針fun_ptr指向fun1函數(shù) callback = fun_ptr; //std::function對(duì)象包裝函數(shù)指針 std::cout 《《 callback(10) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的實(shí)體 return 0; }2、std::function包裝函數(shù)

int fun1(int a){ return a; } int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; callback = fun1; //std::function包裝函數(shù) std::cout 《《 callback(42) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }3、std::function包裝模板函數(shù)

template《typename T》 T fun2(T a){ return a + 2; } int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; callback = fun2《int》; //std::function包裝模板函數(shù) std::cout 《《 callback(10) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }4、std::function包裝函數(shù)對(duì)象

struct add{ int operator()(int x){ return x + 9; } }; int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; callback = add(); //std::function包裝對(duì)象函數(shù) std::cout 《《 callback(2) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }5、std::function包裝lamda表達(dá)式

int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; auto fun3 = [](int a) {return a * 2;}; //lamda表達(dá)式 callback = fun3; //std::function包裝lamda表達(dá)式 std::cout 《《 callback(9) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }

6、std::function包裝模板對(duì)象函數(shù)

template 《typename T》 struct sub{ T operator()(T a){ return a - 8; } }; int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; callback = sub《int》(); //std::function包裝模板對(duì)象函數(shù) std::cout 《《 callback(2) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }

7、std::function包裝模板對(duì)象靜態(tài)函數(shù)

template 《typename T》 struct foo2{ static T foo(T a){ return a * 4; } }; int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; callback = foo2《int》::foo; //std::function包裝模板對(duì)象靜態(tài)函數(shù) std::cout 《《 callback(3) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }

8、std::function包裝對(duì)象靜態(tài)函數(shù)

struct foo1{ static int foo(int a){ return a * 3; } }; int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; callback = foo1::foo; //std::function包裝對(duì)象靜態(tài)函數(shù) std::cout 《《 callback(5) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }

9、std::function包裝類成員函數(shù)

struct foo3{ int foo(int a){ return a * a; } }; int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; foo3 test_foo1; callback = std::bind(&foo3::foo, test_foo1, std::_1); //std::function包裝類成員函數(shù) std::cout 《《 callback(9) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }

這里我們用到了std::bind,C++11中std::bind函數(shù)的意義就如字面上的意思一樣,用來(lái)綁定函數(shù)調(diào)用的某些參數(shù)。std::bind的思想其實(shí)是一種延遲計(jì)算的思想,將可調(diào)用對(duì)象保存起來(lái),然后在需要的時(shí)候再調(diào)用。而且這種綁定是非常靈活的,不論是普通函數(shù)還是函數(shù)對(duì)象還是成員函數(shù)都可以綁定,而且其參數(shù)可以支持占位符。

這里的std::_1是一個(gè)占位符,且綁定第一個(gè)參數(shù),若可調(diào)用實(shí)體有2個(gè)形參,那么綁定第二個(gè)參數(shù)的占位符是std::_2。

10、std::function包裝模板類成員函數(shù)

template 《typename T》 struct foo4{ T foo(T a){ return a * 6; } }; int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; foo4《int》 test_foo2; callback = std::bind(&foo4《int》::foo, test_foo2, std::_1); //std::function包裝模板類成員函數(shù) std::cout 《《 callback(7) 《《 std::endl; //std::function對(duì)象實(shí)例調(diào)用包裝的調(diào)用實(shí)體 return 0; }

11、std::function拷貝、移動(dòng)

int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; std::function《int(int)》 callback2 = callback; //拷貝賦值運(yùn)算符 std::cout 《《 callback2(7) 《《 std::endl; std::function《int(int)》&& callback3 = std::move(callback); //移動(dòng)賦值運(yùn)算符 std::cout 《《 callback3(7) 《《 std::endl; std::cout 《《 callback(7) 《《 std::endl; std::function《int(int)》 callback4(callback); //拷貝 std::cout 《《 callback4(7) 《《 std::endl; return 0; }

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • STD
    STD
    +關(guān)注

    關(guān)注

    0

    文章

    39

    瀏覽量

    14700

原文標(biāo)題:C++ std::function詳解與實(shí)戰(zhàn)

文章出處:【微信號(hào):harmonyos_developer,微信公眾號(hào):harmonyos_developer】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    基于凌羽派的OpenHarmony北向應(yīng)用開(kāi)發(fā):ArkTS語(yǔ)法-數(shù)據(jù)類型和變量聲明

    一、簡(jiǎn)介 ArkTS是一種設(shè)計(jì)用于構(gòu)建高性能應(yīng)用的編程語(yǔ)言。它在繼承TypeScript語(yǔ)法的基礎(chǔ)上進(jìn)行了優(yōu)化,以提供更高的性能和開(kāi)發(fā)效率。 環(huán)境配置如下所示: API:18 SDK
    發(fā)表于 02-26 14:24

    結(jié)構(gòu)體聲明與定義

    1、聲明 結(jié)構(gòu)體的聲明使用struct關(guān)鍵字,如果我們想要把我們的學(xué)籍信息組織一下的話,可以這樣表示: struct Info { unsigned long identifier;//學(xué)號(hào)
    發(fā)表于 12-11 07:52

    發(fā)布元服務(wù)配置隱私聲明

    元服務(wù)必須先使用AGC的隱私聲明托管服務(wù)生成自己的隱私聲明,才能在版本信息頁(yè)面選擇到。詳細(xì)內(nèi)容參見(jiàn)配置隱私聲明(元服務(wù))和配置用戶協(xié)議。 登錄AppGallery Connect,點(diǎn)擊“APP與元
    發(fā)表于 11-25 11:24

    STD2000X:半導(dǎo)體分立器件靜態(tài)電性測(cè)試的全場(chǎng)景解決方案

    的分立器件、復(fù)合器件及部分 IC 類產(chǎn)品的綜合測(cè)試平臺(tái),覆蓋從研發(fā)驗(yàn)證到量產(chǎn)篩選的全流程需求。 一、廣泛適配的測(cè)試器件與參數(shù) STD2000X 支持多達(dá) 20 常見(jiàn)半導(dǎo)體器件 的靜態(tài)參數(shù)測(cè)試,包括
    的頭像 發(fā)表于 11-21 11:16 ?230次閱讀
    <b class='flag-5'>STD</b>2000X:半導(dǎo)體分立器件靜態(tài)電性測(cè)試的全場(chǎng)景解決方案

    一文了解3C認(rèn)證自我聲明制度

    一、什么是3C認(rèn)證自我聲明3C認(rèn)證自我聲明(CCCSelf-Declaration),是國(guó)家市場(chǎng)監(jiān)督管理總局自2019年起推行的新型管理方式。它允許部分低風(fēng)險(xiǎn)產(chǎn)品企業(yè)不再通過(guò)第三方認(rèn)證機(jī)構(gòu)發(fā)證,而是
    的頭像 發(fā)表于 11-11 11:58 ?1127次閱讀
    一文了解3C認(rèn)證自我<b class='flag-5'>聲明</b>制度

    STD80N240K6功率MOSFET技術(shù)解析與應(yīng)用指南

    開(kāi)關(guān)速度和低損耗。集成ESD保護(hù)二極管提高了STD80N240K6 MOSFET的整體耐用性,高達(dá)2人體模型(HBM)。與上一代的MDmesh K5相比,MDmesh K6 MOSFET具有更低
    的頭像 發(fā)表于 10-30 11:39 ?780次閱讀
    <b class='flag-5'>STD</b>80N240K6功率MOSFET技術(shù)解析與應(yīng)用指南

    使用CubeMX移植nano編譯時(shí)提示大量未聲明,為什么?

    編譯時(shí)出現(xiàn)大量報(bào)錯(cuò)。報(bào)錯(cuò)集中在core/src/syscalls.c以及sysmem.c文件中。 報(bào)錯(cuò)內(nèi)容如下所示,主要是提示找不到errno.h中的相關(guān)聲明。 但是errno.h使用f12可以打開(kāi)
    發(fā)表于 09-26 06:29

    【匯思博SEEK100開(kāi)發(fā)板試用體驗(yàn)】3/第一次使用OpenHarmony

    本分享貼,聚焦第一次上手的時(shí)候,可能出現(xiàn)的一些問(wèn)題,希望對(duì)其他小伙伴也有幫助。 ??一、創(chuàng)建首個(gè)OpenHarmony工程?? ??選擇開(kāi)發(fā)范式?? ??聲明式開(kāi)發(fā)(eTS)??:主流推薦,高性能
    發(fā)表于 08-20 22:21

    基于LockAI視覺(jué)識(shí)別模塊:C++人臉識(shí)別

    人臉模板進(jìn)行比較來(lái)實(shí)現(xiàn)識(shí)別。 2. C++ API 文檔 2.1 FaceRecognitionSystem 2.1.1 頭文件 #include <
    發(fā)表于 07-01 12:01

    在IAR Arm開(kāi)發(fā)工具鏈中--function_sections編譯選項(xiàng)的使用

    本文主要介紹在IAR Arm開(kāi)發(fā)工具鏈中不修改源代碼的情況下使用??function_sections編譯選項(xiàng)把函數(shù)放到單獨(dú)的section。
    的頭像 發(fā)表于 06-13 13:53 ?1780次閱讀
    在IAR Arm開(kāi)發(fā)工具鏈中--<b class='flag-5'>function</b>_sections編譯選項(xiàng)的使用

    HarmonyOS5云服務(wù)技術(shù)分享--Serverless抽獎(jiǎng)模板部署

    手把手教你部署HarmonyOS Serverless抽獎(jiǎng)活動(dòng)模板(附貼心提醒) 嘿,小伙伴們!今天給大家分享一個(gè)超實(shí)用的教程——如何用華為HarmonyOS的Serverless模板快速搭建抽獎(jiǎng)
    發(fā)表于 05-22 20:25

    基于LockAI視覺(jué)識(shí)別模塊:C++多模板匹配

    ; ? using namespace cv; using namespace std; ? // 多模板匹配函數(shù)(支持彩色或灰度圖像,僅繪制匹配度最高的框) void
    發(fā)表于 05-14 15:00

    基于LockAI視覺(jué)識(shí)別模塊:C++多模板匹配

    模板匹配是一種在圖像中同時(shí)尋找多個(gè)模板的技術(shù)。通過(guò)對(duì)每個(gè)模板逐一進(jìn)行匹配,找到與輸入圖像最相似的區(qū)域,并標(biāo)記出匹配度最高的結(jié)果。本實(shí)驗(yàn)提供了一個(gè)簡(jiǎn)單的多模板匹配案例,并將其封裝為一個(gè)
    的頭像 發(fā)表于 05-14 14:37 ?1618次閱讀
    基于LockAI視覺(jué)識(shí)別模塊:C++多<b class='flag-5'>模板</b>匹配

    基于LockAI視覺(jué)識(shí)別模塊:C++模板匹配

    ; #include <iostream> ? using namespace cv; using namespace std; ? // 模板匹配函數(shù) bool
    發(fā)表于 05-13 14:40

    基于LockAI視覺(jué)識(shí)別模塊:C++模板匹配

    模板匹配是一種在圖像中尋找特定模式的技術(shù)。它通過(guò)滑動(dòng)一個(gè)模板圖像(較小的圖像)在輸入圖像上進(jìn)行比較,找到最相似的區(qū)域。本實(shí)驗(yàn)提供了一個(gè)簡(jiǎn)單的模板匹配案例,并將其封裝為一個(gè)自定義函數(shù)performTemplateMatching,
    的頭像 發(fā)表于 05-13 14:14 ?781次閱讀
    基于LockAI視覺(jué)識(shí)別模塊:C++<b class='flag-5'>模板</b>匹配