我正在尝试为二叉树编写打印函数,这是我到目前为止所做的:
impl TreeNode {
fn print(&self) {
self.print(0);
}
fn print(&self, level: u8) {
for _i in range(0,level) {
print!("\t");
}
match self.data {
Some(x) => println!("{}",x),
None => ()
};
match self.left {
Some(ref x) => x.print(level+1),
None => ()
};
match self.right {
Some(ref x) => x.print(level+1),
None => ()
};
}
}
我收到错误:重复定义值print
。所以我想知道是否有办法创建具有相同名称但不同参数的函数。或者可选参数可以解决这个问题,但我认为目前不可能(至少我无法通过Google搜索找到它)。
那么,最好的方法是什么?重命名第二个打印功能但看起来很丑,如果我想(从本例中)打印从树的中间开始,则需要记住多个函数名。
答案 0 :(得分:4)
Rust没有重载,因此不可能有两个具有相同名称和不同参数集的函数或方法。
但是,有时可以使用特征模拟过载。这种方法可能不适合您的用例,但您可以看到它是如何完成的in the standard library,其中Path::new()
构造函数可以使用类似于字节向量的东西来调用:
Path::new("/a/b/c/d") // argument is &str
Path::new(b"/a/b/c/d") // argument is &[u8]
Path::new(Path::new("/a/b/c/d")) // argument is another Path
这是通过BytesContainer
特征完成的,new()
方法定义如下:
fn new<T: BytesContainer>(bytes: T) -> Path { ... }
然后针对您想要的所有类型实施此特征:
impl<'a> BytesContainer for &'a str { ... }
impl<'a> BytesContainer for &'a [u8] { ... }
impl BytesContainer for Path { ... }
// and more
这恰好类似于重载,因为new()
完全相同,无论它提供什么样的输入;这只是一个方便的事情,使Path
构造函数更灵活。最后new()
只是将其参数转换为字节切片。但是,这不允许您使用相同名称的完全不同的功能。