Tại sao tôi không thể quá tải chức năng mẫu này?Đâu là xung đột ở đây?
import std.stdio;
T[] find(T, E)(T[] haystack, E needle)
if (is(typeof(haystack[0] != needle)))
{
while(haystack.length > 0 && haystack[0] != needle) {
haystack = haystack[1 .. $];
}
return haystack;
}
// main.d(14): Error: function main.find conflicts with template main.find(T,E) if (is(typeof(haystack[0] != needle))) at main.d(5)
double[] find(double[] haystack, string needle) { return haystack; }
int main(string[] argv)
{
double[] a = [1,2.0,3];
writeln(find(a, 2.0));
writeln(find(a, "2"));
return 0;
}
Theo tôi có thể biết, hai hàm không thể chấp nhận cùng một loại đối số.
Tôi không nghĩ rằng ngôn ngữ cho phép bạn quá tải * bất kỳ * mẫu chức năng .. – Mehrdad
@Mehrdad: Bạn có thể quá tải. Cụ thể std.algorithm.find bị quá tải nhiều lần. –
@PeterAlexander: Đợi thật? Mỗi lần tôi cố gắng làm cho một chức năng thường xuyên 'quá tải' một khuôn mẫu, tôi đã nhận được một lỗi .... – Mehrdad