模板是泛型程式設計,涉及編寫程式碼的方式,獨立於任何特定型別的基礎。
模板是藍圖或公式建立一個泛型類或函式。
模板的功能,允許描述的程式碼作為一種模式,讓編譯器自動生成的程式程式碼。的原始碼部分可留至要填充,直到該部分是在程式實際使用的編譯器。編譯器填補了缺失的部分。
定義一個函式作為模板離開一個或多個使用作為非特定的型別,可以由編譯器後面推匯出來。正在未指定的型別模板形參表上,它的函式的名稱,函式引數列表之間進行定義。出於這個原因,函式模板有兩個引數列表:模板形參表和函式引數列表:
import std.stdio; void print(T)(T value) { writefln("%s", value); } void main() { print(42); print(1.2); print("test"); }
如果我們編譯並執行上面的程式碼,這會產生以下結果:
42 1.2 test
可以有多個引數型別和它示出被顯示在下面的例子。
import std.stdio; void print(T1, T2)(T1 value1, T2 value2) { writefln(" %s %s", value1, value2); } void main() { print(42, "Test"); print(1.2, 33); }
如果我們編譯並執行上面的程式碼,這會產生以下結果:
42 Test 1.2 33
正如我們可以定義函式模板,我們也可以定義類別範本。下面是例子定義類Stack和實現泛型方法,推動並從彈出堆疊中的元素。
import std.stdio; import std.string; class Stack(T) { private: T[] elements; public: void push(T element) { elements ~= element; } void pop() { --elements.length; } T top() const @property { return elements[$ - 1]; } size_t length() const @property { return elements.length; } } void main() { auto stack = new Stack!string; stack.push("Test1"); stack.push("Test2"); writeln(stack.top); writeln(stack.length); stack.pop; writeln(stack.top); writeln(stack.length); }
如果我們編譯並執行上面的程式碼,這會產生以下結果:
Test2 2 Test1 1