Javascript-форум (https://javascript.ru/forum/)
-   Оффтопик (https://javascript.ru/forum/offtopic/)
-   -   Язык программирования Rust (https://javascript.ru/forum/offtopic/52727-yazyk-programmirovaniya-rust.html)

Safort 03.04.2015 21:01

Итак, с небольшим опозданием, сегодня релизнулась бета версия.
Announcing Rust 1.0 Beta

Safort 12.05.2015 14:24

@FirefoxNightly has experimental support for @rustlang code.

Safort 15.05.2015 20:14

Свершилось! Вышел релиз первой версии http://blog.rust-lang.org/2015/05/15/Rust-1.0.html

kobezzza 15.05.2015 20:40

Цитата:

Сообщение от Safort (Сообщение 371037)
Свершилось! Вышел релиз первой версии http://blog.rust-lang.org/2015/05/15/Rust-1.0.html

Круто та!!!:dance:

kobezzza 29.05.2015 18:20

http://kgv.github.io/rust_book_ru/INTRODUCTION.html

Safort 29.05.2015 19:18

kobezzza,
о, спасибо, очень полезная штука. Жаль, что только версия Раста не указана.

indeterm 03.06.2015 07:55

Цитата:

Сообщение от Safort
Свершилось!

нахрен нужен язык без ООП? Детские поделия писать ?

kobezzza 03.06.2015 20:27

Цитата:

Сообщение от indeterm (Сообщение 373682)
нахрен нужен язык без ООП? Детские поделия писать ?

В Rust вообще то замечательная ОО модель. А вообще слишком жирно, то же ядро линуха написано на С, где нет никакого ООП и ничего.

Erolast 03.06.2015 20:50

kobezzza, это опять foo, если что)

indeterm 03.06.2015 20:56

Цитата:

Сообщение от kobezzza
В Rust вообще то замечательная ОО модель

Вот это говно чтоли ты называешь ООП?
trait Animal {
    // Static method signature; `Self` refers to the implementor type
    fn new(name: &'static str) -> Self;

    // Instance methods, only signatures
    fn name(&self) -> &'static str;
    fn noise(&self) -> &'static str;

    // A trait can provide default method definitions
    fn talk(&self) {
        // These definitions can access other methods declared in the same
        // trait
        println!("{} says {}", self.name(), self.noise());
    }
}

struct Dog { name: &'static str }

impl Dog {
    fn wag_tail(&self) {
        println!("{} wags tail", self.name);
    }
}

// Implement the `Animal` trait for `Dog`
impl Animal for Dog {
    // Replace `Self` with the implementor type: `Dog`
    fn new(name: &'static str) -> Dog {
        Dog { name: name }
    }

    fn name(&self) -> &'static str {
        self.name
    }

    fn noise(&self) -> &'static str {
        "woof!"
    }

    // Default trait methods can be overridden
    fn talk(&self) {
        // Traits methods can access the implementor methods
        self.wag_tail();

        println!("{} says {}", self.name, self.noise());
    }
}

struct Sheep { naked: bool, name: &'static str }

impl Sheep {
    fn is_naked(&self) -> bool {
        self.naked
    }

    fn shear(&mut self) {
        if self.is_naked() {
            // Implementor methods can use the implementor's trait methods
            println!("{} is already naked!", self.name());
        } else {
            println!("{} gets a haircut", self.name);

            self.talk();
            self.naked = true;
        }
    }
}

impl Animal for Sheep {
    fn new(name: &'static str) -> Sheep {
        Sheep { name: name, naked: false }
    }

    fn name(&self) -> &'static str {
        self.name
    }

    fn noise(&self) -> &'static str {
        if self.is_naked() {
            "baaah"
        } else {
            "baaaaaaaaaaaah"
        }
    }
}

fn main() {
    // Type annotation is necessary in this case
    let mut dolly: Sheep = Animal::new("Dolly");
    let spike: Dog = Animal::new("Spike");
    // TODO ^ Try removing the type annotations

    dolly.shear();

    spike.talk();
    dolly.talk();
}

Ты, вообще, очень удачно ник выбрал.


Часовой пояс GMT +3, время: 12:49.