您好,登錄后才能下訂單哦!
這篇文章主要介紹“外部閉包上中的方法教程”,在日常操作中,相信很多人在外部閉包上中的方法教程問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”外部閉包上中的方法教程”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
此更改的第一個原因是它修復了語義上的漏洞,即在UFCS調用中取函數地址.該提議為此賦予了與現有語義一致的含義.
外(閉包)的最典型的用例是定義使用外部類型上下文指針的閉包函數("閉包函數"是可稱為閉包的函數),.
注意:此用例與標.函數.轉閉包方法不同,后者可從函數創建閉包,但不允許函數使用上下文指針.
假設我們創建std.stdio.File引用作為上下文指針的閉包函數,讓我們調用writelnWithTime,并讓它在當前時間前的文件中寫一行.通常,用作閉包的函數會按成員函數添加到類型中,但不能把成員函數添加到std.stdio.File中,因為它是在其他庫中定義的.一種方法是創建包裝器類型,并在包裝器內定義新閉包函數,例如
構 FileWrapper
{
檔案*檔案;
空 writelnWithTime(串 msg)
{
file.writeln(Clock.currTime," ",msg);
}
}
文件 文件;
動 w=FileWrapper(&file);
動 我們閉包=&w.writelnWithTime;
這可行,但是要付出代價.它增加了所有權語義的復雜性,潛在的范圍錯誤,不必要的運行時開銷,額外的間接級別,并且在調用點上需要額外的樣板代碼來提取閉包.該方法最嚴重的問題是它需要增加包裝類型.如果我們在應用程序使用的庫中定義此包裝器,并且該應用程序需要添加自己的閉包函數,則它必須創建"包裝器-包裝器"類型,從而引入另一種間接性.這不會給程序增加任何價值,但會帶來開銷和復雜性.
另一個方法:不要類型安全,例如:
構 DummyType
{
空 writelnWithTime(串 msg)
{
File*file=轉換(File*)&this ;
file.writeln(Clock.currTime," ",msg);
}
}
文件 文件;
DummyType d;
動 我們閉包=&d.writelnWithTime;
我們閉包.ptr =轉換(空*)文件;
到此,關于“外部閉包上中的方法教程”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。