目录

D Programming - 模板

模板是泛型编程的基础,它涉及以独立于任何特定类型的方式编写代码。

模板是用于创建泛型类或函数的蓝图或公式。

模板是允许将代码描述为模式的功能,以便编译器自动生成程序代码。 部分源代码可以留给编译器填写,直到该部分实际用于程序中。 编译器填写缺少的部分。

功能模板

将函数定义为模板会将其使用的一个或多个类型保留为未指定,稍后由编译器推断。 未指定的类型在模板参数列表中定义,该列表位于函数名称和函数参数列表之间。 因此,函数模板有两个参数列表 -

  • 模板参数列表
  • 功能参数列表
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 
↑回到顶部↑
WIKI教程 @2018