女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

std::function簡介及模板類聲明

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

掃碼添加小助手

加入工程師交流群

01

std::function簡介

std::function是一個函數包裝器,該函數包裝器模板能包裝任何類型的可調用實體,如普通函數,函數對象,lamda表達式等。包裝器可拷貝,移動等,并且包裝器類型僅僅依賴于調用特征,而不依賴于可調用元素自身的類型。

std::function是C++11的新特性,包含在頭文件《functional》中。一個std::function類型對象實例可以包裝下列這幾種可調用實體:函數、函數指針、成員函數、靜態函數、lamda表達式和函數對象。

std::function對象實例可被拷貝和移動,并且可以使用指定的調用特征來直接調用目標元素。當std::function對象實例未包含任何實際可調用實體時,調用該std::function對象實例將拋出std::bad_function_call異常。02

std::function實戰

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模板類成員函數聲明

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從成員函數里我們知道std::function對象實例不允許進行==和!=比較操作,std::function模板類實例最終調用成員函數_Rp operator()(_ArgTypes.。。) const進而調用包裝的調用實體。1、std::function包裝函數指針定義一個std::function《int(int)》對象實例

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

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; //函數指針fun_ptr指向fun1函數 callback = fun_ptr; //std::function對象包裝函數指針 std::cout 《《 callback(10) 《《 std::endl; //std::function對象實例調用包裝的實體 return 0; }2、std::function包裝函數

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

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包裝模板函數 std::cout 《《 callback(10) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }4、std::function包裝函數對象

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包裝對象函數 std::cout 《《 callback(2) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }5、std::function包裝lamda表達式

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

6、std::function包裝模板對象函數

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包裝模板對象函數 std::cout 《《 callback(2) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }

7、std::function包裝模板對象靜態函數

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包裝模板對象靜態函數 std::cout 《《 callback(3) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }

8、std::function包裝對象靜態函數

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包裝對象靜態函數 std::cout 《《 callback(5) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }

9、std::function包裝類成員函數

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包裝類成員函數 std::cout 《《 callback(9) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }

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

這里的std::_1是一個占位符,且綁定第一個參數,若可調用實體有2個形參,那么綁定第二個參數的占位符是std::_2。

10、std::function包裝模板類成員函數

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包裝模板類成員函數 std::cout 《《 callback(7) 《《 std::endl; //std::function對象實例調用包裝的調用實體 return 0; }

11、std::function拷貝、移動

int main(int argc, char *argv[]){ std::cout 《《 “Hello world” 《《 std::endl; std::function《int(int)》 callback2 = callback; //拷貝賦值運算符 std::cout 《《 callback2(7) 《《 std::endl; std::function《int(int)》&& callback3 = std::move(callback); //移動賦值運算符 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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • STD
    STD
    +關注

    關注

    0

    文章

    36

    瀏覽量

    14542

原文標題:C++ std::function詳解與實戰

文章出處:【微信號:harmonyos_developer,微信公眾號:harmonyos_developer】歡迎添加關注!文章轉載請注明出處。

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

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    在IAR Arm開發工具鏈中--function_sections編譯選項的使用

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

    HarmonyOS5云服務技術分享--Serverless抽獎模板部署

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

    基于LockAI視覺識別模塊:C++多模板匹配

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

    基于LockAI視覺識別模塊:C++多模板匹配

    模板匹配是一種在圖像中同時尋找多個模板的技術。通過對每個模板逐一進行匹配,找到與輸入圖像最相似的區域,并標記出匹配度最高的結果。本實驗提供了一個簡單的多模板匹配案例,并將其封裝為一個
    的頭像 發表于 05-14 14:37 ?314次閱讀
    基于LockAI視覺識別模塊:C++多<b class='flag-5'>模板</b>匹配

    基于LockAI視覺識別模塊:C++模板匹配

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

    基于LockAI視覺識別模塊:C++模板匹配

    模板匹配是一種在圖像中尋找特定模式的技術。它通過滑動一個模板圖像(較小的圖像)在輸入圖像上進行比較,找到最相似的區域。本實驗提供了一個簡單的模板匹配案例,并將其封裝為一個自定義函數performTemplateMatching,
    的頭像 發表于 05-13 14:14 ?196次閱讀
    基于LockAI視覺識別模塊:C++<b class='flag-5'>模板</b>匹配

    圖紙模板中的文本變量

    “ ?文本變量和系統自帶的內置變量,可以幫助工程師靈活、高效地配置標題欄中的信息,而不用擔心模板中的文字對象被意外修改。 ? ” 文本變量的語法 文本變量以?${VARIABLENAME}?的方式
    的頭像 發表于 11-13 18:21 ?650次閱讀
    圖紙<b class='flag-5'>模板</b>中的文本變量

    基于ArkTS語言的OpenHarmony APP應用開發:HelloOpenharmony

    1、程序簡介 該程序是基于OpenHarmony標準系統編寫的UI應用:HelloOpenHarmony。 本案例是基于API 9接口開發。 本案例已在OpenHarmony凌蒙派-RK3568
    發表于 09-14 12:47

    深入解析MIL-STD-1553B模塊卡

    MIL-STD-1553B模塊
    發表于 09-06 11:43 ?0次下載

    如何對MIL-STD-1553B進行選型

    MIL-STD-1553B產品選型是一個復雜而細致的過程,?需要綜合考慮多個因素以確保所選產品能夠滿足特定應用場景的需求。一、?引言MIL-STD-1553B作為一種廣泛應用于航空航天領域的數據總線
    的頭像 發表于 09-05 17:37 ?773次閱讀
    如何對MIL-<b class='flag-5'>STD</b>-1553B進行選型

    基于OpenHarmony標準系統的C++公共基礎庫案例:SafeQueue

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎庫的線程安全隊列:SafeQueue。線程安全隊列,是在dequeue的基礎上封裝std::lock_guard,以此實現線程的相關
    的頭像 發表于 08-30 12:41 ?682次閱讀
    基于OpenHarmony標準系統的C++公共基礎<b class='flag-5'>類</b>庫案例:SafeQueue

    基于OpenHarmony標準系統的C++公共基礎庫案例:SafeStack

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎庫的線程安全隊列:SafeQueue。線程安全隊列,是在dequeue的基礎上封裝std::lock_guard,以此實現線程的相關
    的頭像 發表于 08-30 12:41 ?688次閱讀
    基于OpenHarmony標準系統的C++公共基礎<b class='flag-5'>類</b>庫案例:SafeStack

    基于OpenHarmony標準系統的C++公共基礎庫案例:SafeBlockQueue

    1、程序簡介該程序是基于OpenHarmony的C++公共基礎庫的讀寫鎖:SafeBlockQueue。線程安全阻塞隊列SafeBlockQueue,提供阻塞和非阻塞版的入隊入隊和出隊接口,并提
    的頭像 發表于 08-30 12:41 ?578次閱讀
    基于OpenHarmony標準系統的C++公共基礎<b class='flag-5'>類</b>庫案例:SafeBlockQueue

    基于OpenHarmony標準系統的C++公共基礎庫案例:ThreadPoll

    1、程序簡介 該程序是基于OpenHarmony標準系統的C++公共基礎庫的線程池處理:ThreadPoll。 本案例完成如下工作: 創建1個線程池,設置該線程池內部有1024個線程空間。 啟動5
    發表于 08-12 11:42

    表面貼裝 TCXO 汽車電子用 DSK321STD:卓越性能,穩定可靠的汽車電子核心組件

    表面貼裝 TCXO(汽車電子用)DSK321STD:卓越性能,穩定可靠的汽車電子核心組件
    的頭像 發表于 08-01 10:22 ?1389次閱讀
    表面貼裝 TCXO 汽車電子用 DSK321<b class='flag-5'>STD</b>:卓越性能,穩定可靠的汽車電子核心組件