• úvod
  • témata
  • události
  • tržiště
  • diskuze
  • nástěnka
  • přihlásit
    registrace
    ztracené heslo?
    SPIRALIRust - Programovací jazyk

    A language empowering everyone to build reliable and efficient software.

    The Rust Programming Language - The Rust Programming Language
    The book of Rust
    Idiomatic rust
    GitHub - usagi/rust-memory-container-cs: Rust Memory Container Cheat-sheet
    Memory container cheat sheet
    rozbalit záhlaví
    BONEFLUTE
    BONEFLUTE --- ---
    FALL: Mám projekt, novej, pro který jsem hledal vhodné nástroje. Chtěl jsem něco snadnýho, rychlýho, etc. Po epizodě s dynamickými jazyky (nic proti, jen se to neukázalo jako vhodné) jsem dokonce ze zoufalství zvažoval C++. Oprášil jsem své znalosti a jal se to aplikovat. Po té, co mi to začalo náhodně padat jsem trochu zpanikařil.
    Dospěl jsem k úvaze, že mám-li tomu obětovat čas, chci za to dostat víc, než co mi C++ nabízí.
    Zatím jsem pokaždé, když mi program v Rustu na něčem spadl, zjistil, že to bylo proto, protože jsem se ho pokoušel nějak přečůrat. Až mi to bude magicky zamrzat budu se učit jak to řešit, s tím jsem smířenej.
    Nejde o to, že by snad Rust dal 100%. Jde o to, že Rust je tak dobrej, že C++ přestává být smysluplná alternativa. Nechť ti, co C++ umí dělají v legaci ale nová generace IMHO nemá důvod se ho vůbec učit.


    FALL: Pokud se učíš nový jazyk, tak máš stejné množství času na získání skillu. Co vám přijde racionální volba C++, nebo Rust, a proč?

    Já neuvažuju o tom, že by firmy měli hromadně přecházet na Rust a všechno přepisovat. Ale psát _novou_ aplikaci v C++ považuju za nerozum.

    A to se bavíme o jazyku jako takovém. Ekosystém kolem, v podobě crates + cargo je další téma, které mu IMHO přidávají další body.
    FALL
    FALL --- ---
    BONEFLUTE: tohle funguje, pokud máš dost (ideálně nekonečně) času na tu fázi učení a vývoje produktu. Výhoda toho prvního modelu je, že dodáváš věci zákazníkům docela rychle. Ano, jsou tam chyby a dostaneš to víckrát zpátky. Ale upřímně, dokud bude většina věcí na světě běhat s chybama a stejně se svět nezboří (= demonstrováno tím, že žádný email ani telefon od naštvaného zákazníka nepřichází), není jednoduché miliony vývojářů a tisíce firem přesvědčit, že je teď čas investovat do učení se nového jazyka, předělávání build procesů a přepisování starého kódu, knihoven nebo celých produktů...

    Abychom si rozměli, učit se Rust rozhodně za to stojí, je to podle mě budoucnost několika částí tohohle našeho "vývojářského" odvěví (viz. Bryan Cantrill z Oxide Computer: "I'm a C developer for 25 years but after developing 2 years in Rust I know I will never go back to C for embedded SW application..."), jen chápu, proč to bude trvat dlouho, než se překlopí majorita. Protože psaní kódu v C děláme 50 let a díky tomu tu máme většinu všeho softwaru, co na světě běží. A +- funguje.
    BONEFLUTE
    BONEFLUTE --- ---
    VELDRANE: Představuju si to takhle:
    Když píšeš v C, tak splodíš svůj první program, ten funguje, ty odevzdáš klientovi, a on ti ho vrátí, že to padá. A tak postupně získáváš skill, jak napsat v C program tak, aby to nepadalo. Když jsi fakt dobrej, tak jsi schopen to tak napsat, a ten program je třeba z 80% bezchybnej.
    Když píšeš v Rustu, tak týdny a měsíce bojuješ s tím, aby ten kompilátor nedržkoval. Získáváš zkušenosti, a postupně už tomu začínáš trochu rozumět, dokonce už dokážeš napsat HelloWorld... A teď když konečně s velkou slávou to přeložíš, tak to předáš klientovi a funguje to. Riziko, že to spadne je tak kolik, 0.1%?
    V obou případech utrácíš spousta času a námahy, aby si se naučil zvládat jazyk. Ale zatímco v C i když máš skill, tak stejně tam někde vzadu hlodá červík, 20%nejistotu, tak v Rustu jakmile ukecáš kompilátor, tak máš 99% jistotu.
    V ten den pro mě C přestal být zajímavej.
    VELDRANE
    VELDRANE --- ---
    SHINING_KATE: Pro me jako systemaka bude zajimave sledovat, zda se Rust etabluje jako linux kernel language nebo ne. Koukal sem na prvni vlastovku v podobe prepsaneho driveru pro e1000 a vypada to luxusne hlavne co se citelnosti tyka citelnosti kodu a jeho pochopeni:

    GitHub - fujita/rust-e1000
    https://github.com/fujita/rust-e1000

    Na druhou stranu i kdyz ten jazyk je fakt super a vylozene me bavi zkoumat vsechna jeho zakouti (btw Rust book je uplne bozi a nema smysl kupovat predrazeny knizky), obavam se, ze ta komplexita spoustu lidi proste odradi. Prijde mi, ze spousta uz vcelku advanced veci je spis “must have”, aby clovek v Rustu moh vubec nejak pracovat. Mozna je muj pohled zkreslenej tim, ze zkratka nejsem kovanej programator (i kdyz me to vlastne ted zivi a spis se povazuju za sys admina.

    Co mam na mysli konkretne ? Hlavne zaziti typovyho sytemu, generik a traitu, protoze bez toho je imho clovek casto dost ztracenej kdyz chce pouzit nejakou komplexnejsi knihovnu, framework apod. viz:

    How to read complicated Rust types
    https://youtu.be/uh9i3be2wIE
    SHINING_KATE
    SHINING_KATE --- ---
    Ugh, úplně jsem zapomněla zmínit https://eurorust.eu/
    Konference to była fakt dobrá, zvlášť na první ročník. Spousta přednášek byla na mě až trochu moc basic, ale i tam bylo příjemné porovnat best practices s ostatními. Přednáška o governingu Rust projektu byla super, byla tam i panelová debata se zástupci několika firem, mimo jiné Ferrous Systems a Meta.

    Zvlášť to co bylo řečeno od Ferrous Systems bylo celkem zajímavé - Ferrous Systems se zabývají mimo jiné školeními a konzultacemi pro další firmy zvažující adopci Rustu, zejména v embedded. Zmínili že pracovní trh může vypadat v téhle době ještě celkem prázdně, ale opak je pravdou. Jen se firmy zatím moc nehrnou do náboru celých nových Rust teamů, ale přeučují stávající. Znělo to, že do budoucna o práci pro Rust devy nouze nebude :) A kdyby někdo zkušenější hledal už teď, Mainmatter, hlavní pořádající organizace, nabírá :) https://gist.github.com/marcoow/0a1ad1a18462e536e655043687a3e024
    SPIKE411
    SPIKE411 --- ---
    GitHub - smallnest/concurrency-programming-via-rust
    https://github.com/smallnest/concurrency-programming-via-rust

    I have a plan to write a book about conncurrency programming via rust. The below is the contents of it and this repo contains all source codes.
    SPIKE411
    SPIKE411 --- ---
    Avoiding allocations in Rust to shrink Wasm modules
    https://nickb.dev/blog/avoiding-allocations-in-rust-to-shrink-wasm-modules/
    SPIKE411
    SPIKE411 --- ---
    Rust programming language outlines plan for updates to style guide | ZDNET
    https://www.zdnet.com/article/rust-programming-language-outlines-plan-for-updates-to-style-guide/
    SPIKE411
    SPIKE411 --- ---
    Rust programming language: Driving innovation in unexpected places | ZDNET
    https://www.zdnet.com/article/programming-languages-why-these-developers-like-rust-in-their-cars/
    SPIKE411
    SPIKE411 --- ---
    Hot Reloading Rust — for Fun and Faster Feedback Cycles | Robert Krahn
    https://robert.kra.hn/posts/hot-reloading-rust/
    SPIKE411
    SPIKE411 --- ---
    PrettySize 0.3 release and a weakness in rust’s type system
    https://neosmart.net/blog/2022/prettysize-0-3-release-and-a-weakness-in-rusts-type-system/
    SPIKE411
    SPIKE411 --- ---
    GitHub brings supply chain security features to the Rust community | The GitHub Blog
    https://github.blog/2022-06-06-github-brings-supply-chain-security-features-to-the-rust-community/
    SPIKE411
    SPIKE411 --- ---
    SPIKE411
    SPIKE411 --- ---
    GitHub - quambene/rust-concurrency: Rust Concurrency Cheat Sheet
    https://github.com/quambene/rust-concurrency
    SPIKE411
    SPIKE411 --- ---
    SPIKE411
    SPIKE411 --- ---
    Rust's Unsafe Pointer Types Need An Overhaul - Faultlore
    https://gankra.github.io/blah/fix-rust-pointers/
    SPIKE411
    SPIKE411 --- ---
    Writing Rust the Elixir way - 18 months later | Lunatic
    https://lunatic.solutions/blog/writing-rust-the-elixir-way-1.5-years-later/
    BONEFLUTE
    BONEFLUTE --- ---
    Ahoj. Rád bych do svého projektu zakomponoval scriptovací jazyk na řešení handlerů a rutin. V repozitářích je několik zajímavých projektů. Konkrétně mě zaujali: https://crates.io/crates/gluon a https://crates.io/crates/dyon
    Máte s tím nějaké praktické zkušenosti? Nebo i s jinými?
    BONEFLUTE
    BONEFLUTE --- ---
    SPIRALI: Moc děkuji za vysvětlení.
    SPIRALI
    SPIRALI --- ---
    BONEFLUTE: Cilem hry je ziskat:
    (1) Uvoleneni zdroju kdyz uz je nikdo nevyuziva
    (2) Zabranit tomu aby nekdo ziskal zaroven read and write referenci nebo dve write.

    Rc resi (1) tim ze ma counter ktery pocita kolik je uzivatelu te reference, kdyz spadne na 0 tak uvolnuje. "get_mut" na Rc pak ve specialnim pripade kdy counter ma hodnotu prave 1 umoznuje vratit &mut referenci, protoze tim ze vime ze jsme jedini kdo ma tuto referenci, tak je to bezpecne i vzhledem k (2). Pokud uz ale Root ma alespon dva Itemy tak Rc counter bude alespon na 2 a tedy get_mut selze (i kdyz nikdo zrovna nema read/write pristup). Proto je tam nutne dat RefCell, ktery slouzi k reseni (2) a zavede dalsi counter, ktery pocita rozpujcovane reference.

    Zkracene: Rc pocita kolik existuje mist na kterych o nas vedi, RefCell pocita kolik mist cte, pripadne jestli do nas nekdo zrovna nezapisuje.
    Oboji idealne hlida prekladac v dobe prekladu, ale nekdy to nejde vyjadrit a je treba tyto kontrolu shodit pomoci Rc/RefCellu do runtimu.
    BONEFLUTE
    BONEFLUTE --- ---
    SPIRALI: Ou! Paráda. A já se s tím tady mořím.
    Díky moc!

    Mohl by jsi mi prosím vysvětlit princip, proč to s get_mut() nefungovalo, a filozofii toho RefCell? Abych to pochopil, co za tím je.
    Kliknutím sem můžete změnit nastavení reklam