是否可以为编译时类型安全和函数重载创建“虚拟”值类型?
E.g。一个greet函数总是带一个字符串,但是根据产生字符串的方法,它会调用正确的变体。
我想这样做是为了简化库的API。 例如,代替greetByFirstName和greetByLastName,我只有一个greet方法,如下所示:
import std.array;
import std.format;
import std.stdio;
string firstName(string name) {
return name.split(" ")[0];
}
string lastName(string name) {
return name.split(" ")[1];
}
string greet(FirstName name) {
return "Hi %s!".format(name);
}
string greet(LastName name) {
return "Hello Mr. %s!".format(name);
}
unittest {
string name = "John Smith";
assert(firstName(name) == "John");
assert(firstName(name).greet() == "Hi John!");
assert(lastName(name).greet() == "Hello Mr. Smith!");
}
void main() {}
答案 0 :(得分:2)
您可以创建一个对基本类型alias this
的新类型,然后在更具体的类型上重载。别名这可以被认为是一种使用结构进行继承的方法,将隐式转换回基础"接口"类型。
// these are the new types
struct FirstName {
string name;
alias name this; // this allows implicit conversion back to string when needed
}
struct LastName {
string name;
alias name this;
}
FirstName firstName(string name) { // these return the more specific type
return FirstName(name.split(" ")[0]);
}
LastName lastName(string name) {
return LastName(name.split(" ")[1]);
}
现在,其余代码将根据需要运行,您仍然可以在需要时将FirstName和LastName视为字符串。