Why doesn't Rust support trait object upcasting?

前端 未结 3 779
名媛妹妹
名媛妹妹 2020-11-22 07:34

Given this code:

trait Base {
    fn a(&self);
    fn b(&self);
    fn c(&self);
    fn d(&self);
}

trait Derived : Base {
    fn e(&sel         


        
3条回答
  •  太阳男子
    2020-11-22 07:59

    Actually, I think I got the reason. I found an elegant way to add upcasting support to any trait that desires it, and that way the programmer is able to choose whether to add that additional vtable entry to the trait, or prefer not to, which is a similar trade-off as in C++'s virtual vs. non-virtual methods: elegance and model correctness vs. performance.

    The code can be implemented as follows:

    trait Base: AsBase {
        // ...
    }
    
    trait AsBase {
        fn as_base(&self) -> &Base;
    }
    
    impl AsBase for T {
        fn as_base(&self) -> &Base {
            self
        }
    }
    

    One may add additional methods for casting a &mut pointer or a Box (that adds a requirement that T must be a 'static type), but this is a general idea. This allows for safe and simple (although not implicit) upcasting of every derived type without boilerplate for every derived type.

提交回复
热议问题