官术网_书友最值得收藏!

Traits

Traits are a way to specify that a type must implement some methods and/or some types. They are similar to interfaces in Java. We can implement a trait on a type and we'll be able to use the methods of this trait on this type as long as this trait is imported. This is how we can add methods to types defined in other crates or even the standard library.

Let's write a trait representing a bit set:

trait BitSet {
    fn clear(&mut self, index: usize);
    fn is_set(&self, index: usize) -> bool;
    fn set(&mut self, index: usize);
}

Here, we don't write the body of the methods, as they will be defined when we implement this trait for a type.

Now, let's implement this trait for the u64 type:

impl BitSet for u64 {
    fn clear(&mut self, index: usize) {
        *self &= !(1 << index);
    }

    fn is_set(&self, index: usize) -> bool {
        (*self >> index) & 1 == 1
    }

    fn set(&mut self, index: usize) {
        *self |= 1 << index;
    }
}

As you can see, the bitwise not operator is ! in Rust, as opposed to ~ in other languages. With this code, we can call these methods on u64:

let mut num = 0;
num.set(15);
println!("{}", num.is_set(15));
num.clear(15);

Remember the #[derive(Debug)] attribute? This actually implements the Debug trait on the following type. We could also manually implement the Debug trait on our type, using the same impl syntax, if the default implement does not suit our use case.

主站蜘蛛池模板: 玉山县| 如东县| 台北县| 沧州市| 陇西县| 祁阳县| 根河市| 南昌市| 江陵县| 故城县| 阿荣旗| 临海市| 珠海市| 昌乐县| 东兰县| 松溪县| 柳江县| 巢湖市| 武汉市| 乌鲁木齐县| 永年县| 平山县| 瑞金市| 于都县| 永清县| 桃江县| 监利县| 和林格尔县| 陵水| 疏附县| 城固县| 莒南县| 大荔县| 太仆寺旗| 盐源县| 丽江市| 龙州县| 体育| 辛集市| 连平县| 东台市|