您好,登錄后才能下訂單哦!
本篇內容介紹了“如何編寫代碼實現外部閉包中下”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
在函數定義點:
需要在虛擬包裝器類型內定義函數,
需要從偽類型上下文指針轉換為所需的實際類型;
這會丟棄上下文指針類型的所有類型安全性,并導致運行時開銷
在函數調用點:
需聲明個虛擬類型實例;請注意,此聲明除了獲得該函數的閉包外沒有其他用途.
提取到閉包后,將ptr其設置為獨立的語句,該語句為運行時錯誤創建新位置
要設置閉包上下文指針,必須將類型強制轉換為(空*);像定義點一樣,這會丟棄上下文指針類型的任何類型安全性,并會導致一些運行時開銷.
而外(閉包)解決方法很簡單,清晰,類型安全.沒有偽包裝器類型,沒有在定義點或調用點進行轉換,沒有運行時開銷,并且在類型安全語句中提取閉包.
外(閉包)空 writelnWithTime(ref File file,string msg)
{
file.writeln(Clock.currTime," ",msg);
}
文件 文件;
動 我們閉包=&file.writelnWithTime;
重大更改/棄用過程
該建議僅要求用不會破壞d的新語法.
例子
==
演示用法的示例:
構 Foo
{
空 巴(int x)
{
}
}
外(閉包)空 baz(ref Foo foo,int x)
{
}
//注意,即使在`foo構`內定義`bar`成員函數
//`baz`函數也與`bar`ABI相同.
空 閉包(int)dg;
Foo foo;
dg=&foo.bar; //普通成員函數閉包
dg(42); //調用foo.bar(42)
dg=&foo.baz; //使用UFCS提取`外(閉包)`baz函數的閉包
dg(42);//調用baz(foo,42);
dg=&baz;//錯誤:無法將`外(閉包)`類型空函數(ref Foo,int)類型的表達式(baz)隱式轉換為`空 閉包(int)`
更現實例子:
導入 std.stdio,std.datetime ;
外(閉包)空 writelnWithTime(T)(ref File foo,T[]buffer)
{
foo.writeln(Clock.currTime," ",buffer);
}
空 main()
{
dumpInfo(&stdout.writeln!(const(char)[])));
//使用UFCS獲取閉包給`外(閉包)`writelnWithTime函數
dumpInfo(&stdout.writelnWithTime!(const(char)[]))
}
空 dumpInfo(空 閉包(const(char)[])writer)
{
writer(" 一 Info:");
writer(" 2 = 2 ");
writer(" 3!= 4 ");
}
“如何編寫代碼實現外部閉包中下”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。