Share to: share facebook share twitter share wa share telegram print page

Rust (linguaxe de programación)

Rust (linguaxe de programación)


Instancia delinguaxe de programación procedural, linguaxe de programaxión funcional, linguaxe de programación multiparadigma, linguaxe de programación imperativa, linguaxe de programación de sistemas, software libre e de código aberto, Linguaxe compilada e linguaxe de programación Editar o valor en Wikidata
EpónimoPucciniales Editar o valor en Wikidata
Influído porAlef, C++, C♯, Cyclone (pt) Traducir, Erlang, Haskell, Limbo (pt) Traducir, Newsqueak, Ocaml, Ruby, Scheme, Standard ML (pt) Traducir e Swift Editar o valor en Wikidata
LicenzaASL 2.0 e Licenza MIT Editar o valor en Wikidata
Características
PlataformaMicrosoft Windows, Linux, macOS, FreeBSD, iOS, Android, multiplataforma e WebAssembly Editar o valor en Wikidata
Paradigma de programaciónprogramación funcional, programação concorrente (pt) Traducir, programação genérica (pt) Traducir, programación imperativa e programación orientada a obxectos Editar o valor en Wikidata
Extensión de ficheirors e rlib Editar o valor en Wikidata
Sistema de tiposinference typing (en) Traducir, nominative typing (en) Traducir, static typing (en) Traducir, strong typing, linear typing (en) Traducir e Hindley–Milner (en) Traducir Editar o valor en Wikidata
Datas e localizacións
Publicación7 de xullo de 2010 e 16 de xuño de 2010 Editar o valor en Wikidata
Creación2006 e 23 de xullo de 2006 Editar o valor en Wikidata
Persoas e organizacións
Inventor/aGraydon Hoare Editar o valor en Wikidata
Deseñador/aGraydon Hoare Editar o valor en Wikidata
DesenvolvedorMozilla, Graydon Hoare e Rust Foundation Editar o valor en Wikidata
Fontes e ligazóns
Blog oficialblog.rust-lang.org Editar o valor en Wikidata
Páxina WEBrust-lang.org Editar o valor en Wikidata
RedesTwitter: rustlang Bluesky: rust-lang.org Youtube: UCaYhcUwRBNscFNUKTjgPFiA BNE: XX6456854 GitHub: rust-lang Editar o valor en Wikidata
Repositoriogithub.com… Editar o valor en Wikidata
Wikidata ] C:Commons ]

Rust é unha linguaxe de programación de propósito xeral que resalta rendemento, seguridade de tipos e concorrencia. Aplica seguridade da memoria, o que significa que todas as referencias que apuntan a memoria válida. Faino sen un colector de lixo convencional; en vez diso, erros de seguridade da memoria e condicións de carreira en acceso a datos son evitados polo "borrow checker", que rastrexa a duración dos obxectos das referencias en tempo de compilación.

Rust soporta múltiples paradigmas de programación. Foi influído por ideas dende programación funcional, incluíndo inmutabilidade, funcións de orde superior, tipos de datos alxebraicos, e "pattern matching". Tamén soporta programación orientada a obxectos vía structs, enums, traits, e métodos.

O desenvolvedor de software Graydon Hoare creou Rust como proxecto persoal mentres traballaba en Mozilla Research en 2006. Mozilla oficialmente patrocinou o proxecto en 2009. A primeira liberación estábel de Rust, Rust 1.0, foi publicado en maio de 2015. Tras un despido masivo de persoal en Mozilla en agosto de 2020, varias empresas unironse a Mozilla para patrocinar Rust coa creación da Rust Fundation en febreiro de 2021. En decembro de 2022, Rust converteuse na primeira linguaxe ademais de C e ensamblador en ser soportada no desenvolvemento do Linux kernel.

Rust destacou pola súa adopción en moitos proxectos de software, especialmente en servizos web e software de sistema. Foi obxecto de estudo académico e conta cunha comunidade crecente de desenvolvedores.

Historia

2006–2009: primeiros anos

Sede da Fundación Mozilla, 650 Castro Street, en Mountain View, California, xuño de 2009

Rust comezou como un proxecto persoal do empregado de Mozilla Graydon Hoare en 2006[1]. Hoare iniciou o proxecto debido á súa frustración cun ascensor avariado no seu edificio de apartamentos[1]. Hoare afirmou que Rust recibiu ese nome polo grupo de fungos de ferruxe que están "sobredeseñados para a supervivencia"[1]. Durante o período comprendido entre 2006 e 2009, Rust non se fixo público dentro de Mozilla e foi escrito no tempo libre de Hoare[2]; Hoare empezou falar publicamente da linguaxe cara a 2009, despois de que un pequeno grupo de Mozilla mostrase interese no proxecto. Hoare enfatizou a prioridade de aproveitar boas ideas de linguaxes antigas en lugar de desenvolver novas, citando linguaxes como CLU (1974), BETA (1975), Mesa (1977), NIL (1981), Erlang (1987), Newsqueak (1988), Napier (1988), Hermes (1990), Sather (1990), Alef (1992), e Limbo (1996) como influencias, afirmando que "moitas linguaxes vellas [son] mellores que as novas", e describindo Rust como "tecnoloxía do pasado que vén a salvar o futuro de si mesmo"[2]. Un dos primeiros desenvolvedores de Rust, Manish Goregaokar, describiu de xeito similar que Rust se baseaba en “investigación principalmente de varias décadas atrás”.[1]

Durante os anos temperáns, o compilador de Rust foi escrito en aproximadamente 38,000 liñas de OCaml[1]. A versión inicial de Rust incluía características como programación orientada a obxectos explícita mediante unha palabra clave obj

(máis tarde eliminada)[1], e un sistema de "tipos-estados" que permitía seguimento das variables dun tipo xunto cos cambios de estado (por exemplo, de non inicializada a inicializada)[2].

2009–2012: patrocinio de Mozilla

Mozilla patrocinou oficialmente o proxecto Rust en 2009.[1] Brendan Eich e outros directivos, intrigados pola posibilidade de empregar Rust para un motor de navegador de web seguro, asignaron enxeñeiros ao proxecto, incluíndo a Patrick Walton, Niko Matsakis, Felix Klock e Manish Goregaokar.[1] Unha sala de conferencias ocupada polos desenvolvedores do proxecto foi bautizada como «the nerd cave», cun cartel colocado fóra da porta.[1]

Durante este período, o traballo trasladouse do compilador inicial en OCaml a un compilador autorreferido, é dicir, escrito en Rust e baseado en LLVM.[3][note 1] O sistema de propiedade de Rust tamén estaba en funcionamento cara a 2010.[1] O logotipo de Rust desenvolveuse en 2011 inspirado nun anel dentado de cadea de bicicleta.[5]

O primeiro lanzamento público, Rust 0.1, saíu o 20 de xaneiro de 2012[6] para Windows, Linux e macOS.[7] A principios da década de 2010 incrementouse a participación de voluntarios de código aberto fóra de Mozilla e fóra dos Estados Unidos. En Mozilla, os directivos acabarían contratando a máis dunha ducia de enxeñeiros para traballar a tempo completo en Rust durante a seguinte década.[1]

2012–2015: Evolución

Os anos de 2012 a 2015 estiveron marcados por cambios substanciais no sistema de tipos de Rust, en particular a eliminación do sistema de typestate, a consolidación doutros recursos da linguaxe e a supresión do colector de lixo.[2][1] A xestión de memoria mediante o sistema de propiedade consolidouse e ampliouse gradualmente para previr erros relacionados coa memoria. En 2013 a funcionalidade do colector de lixo empregábase moi raramente e foi eliminada polo equipo en favor do sistema de propiedade.[1] Outros cambios durante este período incluíron a eliminación das funcións puras—que se declaraban cunha anotación explícita pure

—en marzo de 2013.[8] Así mesmo, suprimiuse a sintaxe especializada para canles e varios tipos de punteiros co obxectivo de simplificar a linguaxe.[2]

A expansión e consolidación de Rust estivo influenciada por desenvolvedores procedentes de C++ (por exemplo, o rendemento de baixo nivel das características), linguaxes de script (por exemplo, Cargo e a xestión de paquetes) e a programación funcional (por exemplo, o desenvolvemento de sistemas de tipos).[2]

Graydon Hoare abandonou o proxecto Rust en 2013.[1] Isto permitiu que evolucionase de xeito orgánico baixo unha estrutura de gobernanza máis federada, cun “equipo núcleo” inicial de seis persoas,[2] arredor de 30–40 desenvolvedores en diversos equipos,[2] e un proceso de Request for Comments (RFC) para novas características da linguaxe engadido en marzo de 2014.[2] O equipo núcleo medrou ata nove persoas en 2016[2] , con máis de 1600 RFCs propostos.[2]

Segundo Andrew Binstock, escribindo para a revista Dr. Dobb’s Journal en xaneiro de 2014, aínda que Rust «era amplamente considerado como unha linguaxe extraordinariamente elegante», a súa adopción ralentizouse porque cambiaba radicalmente dunha versión a outra.[9] Nese momento, o desenvolvemento de Rust centrárase en rematar as funcionalidades da linguaxe e avanzar cara á versión 1.0, de modo que se puidese comezar a garantir compatibilidade cara atrás.[2]

Seis anos despois de que Mozilla patrocinase o seu desenvolvemento, a primeira versión estable, Rust 1.0, publicouse o 15 de maio de 2015.[1] Un ano despois do lanzamento, o compilador de Rust acumulou máis de 1400 contribuíntes e había máis de 5000 bibliotecas de terceiros publicadas no sitio de xestión de paquetes de Rust, Crates.io.[2]

2015–2020: Servo e adopción inicial

Primeira páxina de inicio do motor de navegación Servo de Mozilla

O desenvolvemento do motor de navegador Servo continuou en paralelo con Rust, financiado conxuntamente por Mozilla e Samsung.[10] Os equipos detrás de ambos proxectos traballaron en estreita colaboración; as novas funcionalidades en Rust foron probadas polo equipo de Servo, e as novas funcionalidades en Servo empregábanse para proporcionar retroalimentación ao equipo de Rust.[2] A primeira versión de Servo lanzouse en 2016.[1] O navegador Firefox incluíu código en Rust dende 2016 (versión 45),[2][11] pero compoñentes de Servo non apareceron en Firefox ata setembro de 2017 (versión 57) como parte dos proxectos Gecko e Quantum.[12]

Durante os anos posteriores á versión 1.0, mellorouse o ecosistema da cadea de ferramentas de Rust, incluíndo Rustfmt, a integración con contornos de desenvolvemento integrado;[2] un ciclo regular de probas e publicacións do compilador; un código de conduta comunitario; e as discusións da comunidade organizadas mediante IRC.[2]

As primeiras adopciones fóra de Mozilla foron realizadas por proxectos individuais en Samsung, Facebook (agora Meta Platforms), Dropbox e outros, incluíndo Tilde, Inc. (a empresa detrás de ember.js).[2][1] Amazon Web Services uniuse en 2020.[1] Os enxeñeiros argumentaron que escolleron Rust polas súas prestacións, pola ausencia dun colector de lixo, pola seguridade e pola agradable experiencia de desenvolvemento que ofrece a linguaxe, aínda que recoñecían que era unha aposta arriscada por tratarse dunha tecnoloxía nova. Os desenvolvedores de Amazon citaron un achado de investigadores portugueses que demostraba que o código Rust consome menos enerxía en comparación con código similar escrito en Java e C++, só superado por C.[1][13][note 2]

2020–presente: despidos en Mozilla e Fundación Rust

En agosto de 2020, Mozilla despediu a 250 dos seus 1 000 empregados en todo o mundo como parte dunha reestruturación corporativa provocada pola pandemia de COVID-19.[14][15] O equipo detrás de Servo foi desmantelado. Este acontecemento xerou preocupacións sobre o futuro de Rust debido á superposición entre ambos proxectos.[16] Na semana seguinte, o Rust Core Team recoñeceu o grave impacto destes despedimentos e anunciou que se estaban a elaborar plans para crear unha fundación Rust. O primeiro obxectivo da fundación sería facerse cargo de todas as marcas rexistradas e nomes de dominio, así como asumir a responsabilidade financeira dos seus custos.[17]

O 8 de febreiro de 2021 anunciouse a formación da Rust Foundation polos cinco patrocinadores fundadores: Amazon Web Services, Google, Huawei, Microsoft e Mozilla.[18][19] A fundación, dirixida por Shane Miller durante os seus primeiros dous anos, ofreceu subvencións de 20.000$ e outro apoio para programadores que traballasen en funcións principais de Rust.[1] Nunha entrada no blog publicada o 6 de abril de 2021, Google anunciou o soporte de Rust no proxecto de código aberto de Android como alternativa a C/C++.[20]

O 22 de novembro de 2021, o Equipo de Moderación, responsable de facer cumprir o código de conduta da comunidade, anunciou a súa renuncia “en protesta de que o Equipo Núcleo se poñese sen rendición de contas ante ninguén máis que ante eles mesmos”.[21] En maio de 2022, o Equipo Núcleo de Rust, outros programadores líderes e certos membros da xunta da Rust Foundation implementaron reformas de gobernanza en resposta a este incidente.[22]

A Rust Foundation publicou o 6 de abril de 2023 un borrador dunha nova política de marcas rexistradas, que incluía regras sobre como se pode empregar o logotipo e o nome de Rust, o que provocou reaccións negativas por parte de usuarios e colaboradores de Rust.[23]

O 26 de febreiro de 2024, a Casa Branca dos Estados Unidos, a través da Oficina do Director Nacional de Ciberseguridade, publicou un informe de prensa de 19 páxinas instando ao desenvolvemento de software a afastarse de C e C++ e fomentando o uso de linguaxes seguras para a memoria como C#, Go, Java, Ruby, Swift e Rust.[24][25] O informe foi interpretado como un impulso ao interese por Rust.[26][27]

Sintaxe e características

  A sintaxe de Rust é semellante á de C e C++;[28] aínda que moitas das súas características foron influenciadas por linguaxes de programación funcional como OCaml.[2] Hoare describiu Rust como dirixido a programadores frustrados de C++ e enfatizou características como a seguridade, o control do deseño da memoria e a concorrencia.[2] A seguridade en Rust inclúe as garantías de seguridade de memoria, seguridade de tipos e a ausencia de condicións de carreira de datos.

Programa Ola Mundo

Embaixo tes un programa “Ola mundo” en Rust. A palabra clave fn indica unha función, e a macro println! imprime a mensaxe na saída estándar.[29] As instrucións en Rust sepáranse por punto e coma.

fn main() {
    println!("Ola, Mundo!");
}

Variables

As variables en Rust defínense mediante a palabra clave let.[30] O seguinte exemplo asigna un valor á variable chamada foo e amosa o seu valor.

fn main() {
    let foo = 10;
    println!("O valor de foo é {foo}");
}

As variables son inmutables por defecto, pero engadir a palabra clave mut permite mutar a variable.[1] O seguinte exemplo usa //, que denota o inicio dun comentario.[1]

fn main() {
    // Este código non compilaría sen engadir "mut".
    let mut foo = 10; 
    println!("O valor de foo é {foo}");
    foo = 20;
    println!("O valor de foo é {foo}");
}

Varias expresións let poden definir múltiples variables co mesmo nome, fenómeno coñecido como sombreado de variables. O sombreado de variables permite transformar valores sen ter que empregar nomes distintos para as variables.[31] No exemplo seguinte declárase unha nova variable co mesmo nome que ten o dobre do valor orixinal:

fn main() {
    let foo = 10;
    // Isto imprimirá "O valor de foo é 10"
    println!("O valor de foo é {foo}");
    let foo = foo * 2;
    // Isto imprimirá "O valor de foo é 20"
    println!("O valor de foo é {foo}");
}


O sombreado de variables tamén é posible con valores de tipos diferentes. Por exemplo, pasar dunha cadea de caracteres á súa lonxitude:

fn main() {
    let letras = "abc";
    let letras = letras.len();
}

Expresións de bloque e fluxo de control

Unha expresión de bloque delimítase con chaves {}. Cando a última expresión dentro dun bloque non remata con punto e coma, o bloque evalúase co valor desa expresión final:[32]

fn main() {
    let x = {
        println!("isto está dentro do bloque");
        1 + 2
    };
    println!("1 + 2 = {x}");
}

As expresións finais dos corpos de función utilízanse como valor de retorno:[33]

fn engadir_dous(x: i32) -> i32 {
    x + 2
}

expresións if

Unha expresión condicional if executa código en función de se o valor dado é verdadeiro. else úsase cando o valor evalúase a falso, e else if permite combinar múltiples condicións.[34]

fn main() {
    let x = 10;
    if x > 5 {
        println!("o valor é maior que cinco");
    }

    if x % 7 == 0 {
        println!("o valor é divisible por 7");
    } else if x % 5 == 0 {
        println!("o valor é divisible por 5");
    } else {
        println!("o valor non é divisible por 7 nin por 5");
    }
}

Os bloques if e else poden avaliarse nun valor, que despois se pode asignar a unha variable:[35]

fn main() {
    let x = 10;
    let novo_x = if x % 2 == 0 { x / 2 } else { 3 * x + 1 };
    println!("{novo_x}");
}

bucles while

O while pódese usar para repetir un bloque de código mentres se cumpra unha condición.[36]

 

fn main() {
    // Itera sobre todos os enteiros de 4 a 10
    let mut valor = 4;
    while valor <= 10 {
         println!("valor = {valor}");
         valor += 1;
    }
}

Os bucles e iteradores for

Os bucles for en Rust percorren os elementos dunha colección. As expresións for funcionan con calquera tipo de iterador.[37]

fn main() {
    let r;                    // ------------------+- Tempo de vida 'a
                              //                   |
    {                         //                   |
        let x = 5;            // -+-- Tempo de vida 'b  |
        r = &x; // ERRO: x non vive o tempo suficiente
    }           //                             |
                //                             |
    println!("r: {}", r);     //                   |
}                             // ------------------+
fn main() {
    // Usando `for` con sintaxe de rango para a mesma funcionalidade ca enriba
    // A sintaxe 4..=10 significa o rango de 4 a 10, incluíndo o 10.
    for valor in 4..=10 {
        println!("valor = {valor}");
    }
}

No código anterior, 4..=10 é un valor do tipo Range que implementa o trait Iterator. O código dentro das chaves aplícase a cada elemento que devolve o iterador. Os iteradores pódense combinar con funcións sobre iteradores como map, filter e sum. Por exemplo, o seguinte suma todos os números entre 1 e 100 que son múltiplos de 3:

(1..=100).filter(|&x| x % 3 == 0).sum()

As instrucións loop e break

En xeral, a palabra clave loop permite repetir unha parte do código ata que se produza un break.

break pode, opcionalmente, saír do bucle devolvendo un valor. No caso de bucles anidados, pódense empregar etiquetas denominadas 'nome_etiqueta para romper un bucle exterior en lugar do máis interno.[38]

fn main() {
    let valor = 456;
    let mut potencia = 1;
    let resultado = loop {
        potencia *= 10;
        if potencia > valor {
            break potencia / 10;
        }
    };
    println!("A maior potencia de dez que é menor ou igual a valor: {resultado}");

    let mut arriba = 1;
    'exterior: loop {
        let mut abaixo = 120;
        loop {
            if arriba > 100 {
                break 'exterior;
            }

            if abaixo < 4 {
                break;
            }

            abaixo /= 2;
            arriba += 1;
            println!("arriba: {arriba}, abaixo: {abaixo}");
        }
        arriba *= 2;
    }
}

Coincidencia de patróns Pattern matching

As expresións match e if let poden empregarse para a coincidencia de patróns. Por exemplo, match pode usarse para duplicar un valor enteiro opcional se está presente, e devolver cero en caso contrario:

fn dobre(x: Option<u64>) -> u64 {
    match x {
        Some(y) => y * 2,
        None => 0,
    }
}

Equivalentemente, isto pódese escribir con if let e else:

trait Zero: Sized {
    fn zero() -> Self;
    fn is_zero(&self) -> bool
    where
        Self: PartialEq,
    {
        self == &Zero::zero()
    }
}

impl Zero for u32 {
    fn zero() -> u32 { 0 }
}

impl Zero for f32 {
    fn zero() -> Self { 0.0 }
}
fn dobre(x: Option<u64>) -> u64 {
    if let Some(y) = x {
        y * 2
    } else {
        0
    }
}

Tipos

Rust é fortemente tipado e estáticamente tipado, o que significa que os tipos de todas as variables deben ser coñecidos en tempo de compilación. Asignar un valor dun tipo particular a unha variable dun tipo distinto provoca un erro de compilación. A inferencia de tipos emprégase para determinar o tipo das variables se non se especifica.[39]

O tipo enteiro por defecto é i32, e o tipo de punto flotante por defecto é f64. Se o tipo dun literal numérico non se proporciona explicitamente, infírese do contexto ou utilízase o tipo por defecto.[40]

Tipos primitivos

Os tipos enteiros en Rust chámanse en función da sinalidade e do número de bits que ocupa o tipo. Por exemplo, i32 é un enteiro con sinal que ocupa 32 bits de almacenamento, mentres que u8 é sen sinal e só ocupa 8 bits de almacenamento. isize e usize ocupan espazo segundo a arquitectura do ordenador que executa o código; por exemplo, en computadores con arquitecturas de 32 bits, ambos os tipos ocuparán 32 bits.

Por defecto, os literais enteiros están en base 10, pero están soportadas diferentes bases mediante prefixos; por exemplo, 0b11 para números binarios, 0o567 para octais e 0xDB para hexadecimais. Por defecto, os literais enteiros toman i32 como tipo. Pódense usar sufixos como 4u32 para establecer explicitamente o tipo dun literal.[41] Literais de bytes como b'X' están dispoñibles para representar o valor ASCII (como un u8) dun carácter concreto.[42]

O tipo booleano denomínase bool e pode tomar os valores true ou false. Un char ocupa 32 bits de espazo e representa un valor escalar Unicode: un punto de código Unicode que non é un surrogate.[43] Os números en punto flotante segundo o estándar IEEE 754 son compatibles, con f32 para precisión simple e f64 para precisión dobre.[44]

Tipos compostos

Os tipos compostos poden conter varios valores. As tuplas son listas de tamaño fixo que poden conter valores de tipos distintos. Os arrays (arranxos) son listas de tamaño fixo cuxos valores son do mesmo tipo. As expresións dos tipos tupla e array poden escribirse listando os valores, e pódense acceder mediante .index ou [index].[45]

let tupla: (u32, bool) = (3, true);
let array: [i8; 5] = [1, 2, 3, 4, 5];
let valor = tupla.1; // true
let valor = array[2]; // 3

Os arrays tamén poden construírse copiando un único valor un número de veces[46]  

let array2: [char; 10] = [' '; 10];

Propiedade e referencias

O sistema de propiedade de Rust consiste nun conxunto de regras que garanten a seguridade da memoria sen empregar un colector de lixo. En tempo de compilación, cada valor debe estar ligado a unha variable chamada propietario dese valor, e cada valor debe ter exactamente un propietario.[47] Os valores móvense entre propietarios distintos mediante asignación ou pasando un valor como parámetro dunha función. Os valores tamén poden ser prestados, é dicir, pásanse temporalmente a outra función antes de ser devoltos ao propietario.[1] Con estas regras, Rust pode evitar a creación e o uso de punteiros colgantes.[1][48]

 

fn print_string(s: String) {
    println!("{}", s);
}

fn main() {
    let s = String::from("Hello, World");
    print_string(s); // s consumido por print_string
    // s foi movida, polo que xa non se pode usar
    // outro print_string(s); produciría un erro de compilación
}

A función print_string toma a propiedade do valor String que se lle pasa; como alternativa, & pode empregarse para indicar un tipo referencia (en &String) e para crear unha referencia (en &s).[49]  

fn print_string(s: &String) {
    println!("{}", s);
}

fn main() {
    let s = String::from("Hello, World");
    print_string(&s); // s prestado por print_string
    print_string(&s); // s non foi consumida; podemos chamar a función varias veces
}

Debido a estas regras de propiedade, os tipos en Rust chámanse lineares ou afíns, o que significa que cada valor pode utilizarse exactamente unha vez. Isto impón unha forma de illamento de erros do software, xa que o propietario dun valor é o único responsable da súa corrección e da súa liberación.[50]

Cando un valor sae do seu alcance, libérase executando o seu destructor. O destructor pódese definir programaticamente implementando o trait Drop. Isto axuda a xestionar recursos como manexos de ficheiros, sockets de rede e bloqueos, xa que cando os obxectos se eliminan, os recursos asociados péchanse ou libéranse automaticamente.

Lifetimes

O tempo de vida dun obxecto refírese ao período durante o cal unha referencia é válida; é dicir, o intervalo entre a creación e a destrución do obxecto.[51] Estes tempos de vida (os chamados lifetimes) asócianse de forma implícita a todos os tipos de referencia en Rust. Aínda que o compilador moitos veces os infire, tamén poden indicarse de forma explícita mediante parámetros de lifetime nomeados (habitualmente denotados 'a, 'b, etc.).[52]

Os tempos de vida (lifetimes) en Rust poden entenderse como lexicamente acoutados, o que significa que a duración do tempo de vida dun obxecto infírese a partir do conxunto de localizacións no código fonte (é dicir, función, número de liña e columna) nas que unha variable é válida.[1] Por exemplo, unha referencia a unha variable local ten un tempo de vida correspondente ao bloque no que está definida.[1]

 

fn main() {
    let x = 5;                // ------------------+- Vida 'a
                              //                   |
    let r = &x;               // -+-- Vida 'b      |
                              //  |                |
    println!("r: {}", r);     //  |                |
                              //  |                |
                              // -+                |
}                             // ------------------+

O borrow checker do compilador de Rust impón que as referencias só se utilicen nas localizacións do código fonte nas que o tempo de vida asociado sexa válido.[53] No exemplo anterior, almacenar unha referencia á variable x en r é válido, porque x ten un tempo de vida máis longo ('a) que r ('b). Con todo, cando x ten un tempo de vida máis curto, o borrow checker rexeitaría o programa.  

fn main() {
    let r;                    // ------------------+- Vida 'a
                              //                   |
    {                         //                   |
        let x = 5;            // -+-- Vida 'b      |
        r = &x; // ERRO: x non vive o suficiente   |
    }           //                              ---|
                // non vive o tempo necesario      |
    println!("r: {}", r);     //                   |
}                             // ------------------+

Dado que o tempo de vida da variable referenciada ('b) é máis curto ca o tempo de vida da variable que garda a referencia ('a), o borrow checker produce un erro, evitando que x se use fóra do seu ámbito.[54] Os tempos de vida (lifetimes) pódense indicar usando parámetros de tempo de vida explícitos nos argumentos dunha función. Por exemplo, o seguinte código especifica que a referencia devolta pola función ten o mesmo tempo de vida que original (e non necesariamente o mesmo tempo de vida que prefix):[55]

fn eliminar_prefixo<'a>(mut original: &'a str, prefix: &str) -> &'a str {
    if original.starts_with(prefix) {
        original = &original[prefix.len()..];
    }
    original
}

No compilador, a propiedade e os tempos de vida traballan xuntos para previr problemas de seguridade da memoria, como os dangling pointers (punteros colgantes).[56]

Tipos definidos polo usuario

Os tipos definidos polo usuario créanse coas palabras clave struct ou enum. A palabra clave struct úsase para indicar un tipo rexistro que agrupa varios valores relacionados.[57] Os enum poden adoptar diferentes variantes en tempo de execución, con capacidades similares aos tipos de datos alxebraicos que se atopan en linguaxes de programación funcionais.[58] Tanto os rexistros como as variantes de enum poden conter campos con diferentes tipos. Pódense definir nomes alternativos, ou alias, para o mesmo tipo coa palabra clave type.[59]

A palabra clave impl pode definir métodos para un tipo definido polo usuario. Os datos e as funcións defínense por separado. As implementacións cumpren un papel similar ao das clases noutros linguaxes.[60]

Biblioteca estándar

A biblioteca estándar de Rust define e implementa moitos tipos de datos personalizados amplamente usados, incluíndo estruturas de datos principais como Vec, Option e HashMap, así como tipos de punteiros intelixentes.

Rust tamén fornece un xeito de excluír a maior parte da biblioteca estándar empregando o atributo #!#!; isto permite crear aplicacións, como dispositivos embebidos, que queiran eliminar código dependente ou fornecer as súas propias estruturas de datos básicas.

Internamente, a biblioteca estándar divídese en tres partes: core, alloc e std, onde std e alloc son excluídas por #!#!.[61]

Rust utiliza Option para definir valores opcionais, os cales poden ser comparados empregando if let ou match para acceder ao valor interior:[62]

fn main() {
    let name1: Option<&str> = None;
    // Neste caso, non se imprimirá nada
    if let Some(name) = name1 {
        println!("{name}");
    }

    let name2: Option<&str> = Some("Matthew");
    // Neste caso, imprimirase a palabra "Matthew"
    if let Some(name) = name2 {
        println!("{name}");
    }
}

Punteiros

Os tipos de referencia & e &mut garantíase que non son nulos e apuntan a memoria válida. Os tipos de punteiro cru *const e *mut non teñen estas garantías de seguridade, polo que poden ser nulos ou inválidos; con todo, é imposible desreferencialos a menos que o código se declare explicitamente como inseguro mediante o uso dun bloque unsafe.[63] A diferenza da desreferenciación, a creación de punteiros crus está permitida dentro de código Rust seguro.[64]

Conversión de tipos

Rust non prove conversión implícita de tipos (coerción) entre a maioría dos tipos primitivos. Pero pode facerse unha conversión explícita de tipo (casting) empregando a palabra clave as

let x: i32 = 1000;
println!("1000 como u16 é: {}", x as u16);

Polymorphism

Rust permite o polimorfismo paramétrico acoutado mediante traits e funcións xenéricas.[65] En primeiro lugar, o comportamento común entre tipos pode declararse usando traits e impls:[66]

trait Cero: Sized {
    fn cero() -> Self;
    fn e_cero(&self) -> bool
    where
        Self: PartialEq,
    {
        self == &Cero::cero()
    }
}

impl Cero for u32 {
    fn cero() -> u32 { 0 }
}

impl Cero for f32 {
    fn cero() -> Self { 0.0 }
}

O exemplo anterior tamén inclúe un método e_cero que proporciona unha implementación por defecto, polo que non é necesario definilo ao implementar o trait.[67] Unha función pode entón facerse xenérica engadindo parámetros de tipo dentro de chaves angulares (<Num>), que só permiten tipos que implementen o trait:

// cero é unha función xenérica cun parámetro de tipo, Num
fn cero<Num: Cero>() -> Num {
    Num::cero()
}

fn main() {
    let a: u32 = cero();
    let b: f32 = cero();
    assert!(a.e_cero() && b.e_cero());
}

Nos exemplos anteriores, Num: Cero así como where Self: PartialEq son restricións de traits que limitan o tipo para que só se permitan aqueles tipos que implementen Cero ou PartialEq.[68] Dentro dun trait ou impl, Self refírese ao tipo que está a implementar o código.[69]

Os xeréricos poden usarse en funcións para permitir implementar un comportamento para diferentes tipos sen repetir o mesmo código. As funcións xeréricas poden escribirse en relación con outros xeréricos, sen coñecer o tipo real.[70]

Obxectos trait

As funcións xeréricas usan despacho estático, o que significa que o tipo de todos os parámetros que se usan na función debe ser coñecido en tempo de compilación. As funcións xeréricas xeran copias separadas do código para cada combinación de parámetros xeréricos empregada nun proceso chamado monomorfización.[1] Debido a que a monomorfización duplica o código para cada tipo usado, o rendemento é tan bo como escribir funcións usando tipos concretos,[1] pero o tempo de compilación e o tamaño do binario resultante poden aumentar.

Rust tamén emprega unha característica coñecida como trait objects para acadar dynamic dispatch, un tipo de polimorfismo no que a implementación dunha operación polimórfica se escolle en tempo de execución. Isto permite un comportamento semellante ao duck typing, onde todos os tipos de datos que implementen un determinado trait poden ser tratados como funcionalmente equivalentes.[71] Os trait objects decláranse empregando a sintaxe dyn Tr, onde Tr é un trait. Os trait objects teñen tamaño dinámico, polo que deben colocarse detrás dun punteiro, como por exemplo Box.[72] O seguinte exemplo crea unha lista de obxectos onde cada obxecto pode ser impreso empregando o trait Display:

use std::fmt::Display;

let v: Vec<Box<dyn Display>> = vec![
    Box::new(3),
    Box::new(5.0),
    Box::new("ola"),
];

for x in v {
    println!("{x}");
}

Se un elemento da lista non implementa o trait Display, provocará un erro en tempo de compilación.[73]

Seguridade da memoria

Rust está deseñado para ser seguro na xestión da memoria. Non permite punteiros nulos, punteiros colgantes nin condicións de carreira de datos.[74][75][76] Os valores de datos só se poden inicializar a través dun conxunto fixo de formas, todas as cales requiren que as súas entradas estean xa inicializadas.[77]

Administración da memoria

Rust non emprega recollida de lixo (garbage collection). A xestión da memoria e doutros recursos faise a través da convención de “adquisición de recursos é inicialización” (RAII),[78] con un contador de referencias opcional. Rust ofrece unha xestión determinística dos recursos, con moi baixa sobrecarga.[79] Os valores alócanse na pila por defecto, e todas as alocacións dinámicas deben ser explícitas.[80] Os tipos de referencia incorporados que usan o símbolo & non implican un recuento de referencias en tempo de execución. A seguridade e validez dos punteiros subxacentes verifícanse en tempo de compilación, evitando punteiros colgantes e outras formas de comportamento indefinido.[81] O sistema de tipos de Rust separa as referencias compartidas e inmutables do tipo &T das referencias únicas e mutables do tipo &mut T. Unha referencia mutable pode ser convertida a unha referencia inmutable, pero non ao contrario.[82]

Unsafe

Rust permite realizar varias operacións inseguras mediante o uso de bloques unsafe. Isto permite aos programadores desreferenciar punteiros crus arbitrarios, chamar código externo ou executar outras funcións de baixo nivel que non están cubertas polo Rust seguro.[1] Algunhas das funcionalidades de baixo nivel que habilita o código unsafe inclúen acceso a memoria volátil, instrínsicos específicos da arquitectura, punning de tipos e ensamblaxe en liña.[1] O código inseguro tamén é utilizado polos desenvolvedores para implementar estruturas de datos complexas.[83]

Macros

As macros permiten xerar e transformar código en Rust para reducir a repetición. As macros existen en dúas formas: as macros declarativas, definidas mediante macro_rules!, e as macros procedimentais, que se definen en crates separados.[84][85]

Macros declarativas

Unha macro declarativa (tamén chamada “macro por exemplo”) é unha macro definida empregando a palabra clave macro_rules!, que utiliza pattern matching para determinar a súa expansión.[86][87] A continuación móstrase un exemplo que suma todos os seus argumentos:

fn main() {
    // Usando `for` coa sintaxe de rango para a mesma funcionalidade que arriba
    // A sintaxe 4..=10 significa o rango de 4 a 10, ata e incluíndo o 10.
    for valor in 4..=10 {
        println!("valor = {valor}");
    }
}
macro_rules! sum {
    ( $initial:expr $(, $expr:expr )* $(,)? ) => {
        $initial $(+ $expr)*
    }
}

fn main() {
    let x = sum!(1, 2, 3);
    println!("{x}"); // mostra 6
}

Macros procedimentais

As macros procedimentais son funcións en Rust que se executan e modifican o fluxo de tokens de entrada do compilador antes de que se compile calquera outro compoñente. Xeralmente son máis flexibles que as macros declarativas, pero son máis difíciles de manter debido á súa complexidade.[88][89]

As macros procedimentais teñen tres variedades:

  • Macros do tipo función: custom!(...)
  • Macros derive: #[derive(CustomDerive)]
  • Macros de atributo: #[custom_attribute]

Interface con C e C++

Rust soporta a creación de interfaces de funcións externas (FFI) mediante a palabra clave extern. Unha función que use a convención de chamadas de C pode escribirse empregando extern "C" fn. Os símbolos poden ser exportados desde Rust a outros idiomas mediante o atributo #[no_mangle], e os símbolos poden ser importados a Rust mediante bloques extern:[note 3]

#[unsafe(no_mangle)]
pub extern "C" fn exportada_dende_rust(x: i32) -> i32 { x + 1 }

unsafe extern "C" {
    fn importada_en_rust(x: i32) -> i32;
}

O atributo #[repr(C)] permite disposicións de memoria determinísticas para structs e enums para o seu uso a través de límites FFI. Bibliotecas externas como bindgen e cxx poden xerar enlaces (bindings) de Rust para C/C++.[91]

Ecosistema

Compilando un programa de Rust con Cargo

O ecosistema de Rust inclúe o seu compilador, a súa biblioteca estándar e compoñentes adicionais para o desenvolvemento de software. A instalación dos compoñentes xestiónase normalmente mediante rustup, un instalador de toolchain de Rust desenvolvido polo proxecto Rust.[92]

Compilador

O compilador de Rust, rustc, traduce o código Rust a LLVM IR de baixo nivel. LLVM é entón invocado como un subcompoñente para aplicar optimizacións e traducir o IR resultante a código obxecto. Despois utilízase un linker para combinar os obxectos nunha única imaxe executable ou arquivo binario.Ademais de LLVM, o compilador tamén soporta o uso de backends alternativos como GCC e Cranelift para a xeración de código.[93] A intención destes backends alternativos é aumentar a cobertura de plataformas de Rust ou mellorar os tempos de compilación.[94][95]

Cargo

Screenshot de crates.io en xuño de 2022

Cargo é o sistema de compilación e xestor de paquetes de Rust. Descarga, compila, distribúe e sube paquetes—chamados crates—que se manteñen nun rexistro oficial. Tamén actúa como interface para Clippy e outros compoñentes de Rust.[96]

Por defecto, Cargo obtén as súas dependencias do rexistro contribuído por usuarios crates.io, pero tamén se poden especificar como dependencias repositorios Git, crates no sistema de ficheiros local e outras fontes externas.

Rustfmt

Rustfmt é un formateador de código para Rust. Formatea espazos en branco e sangrado para producir código conforme a un estilo común, a menos que se especifique outro. Pode ser invocado como un programa independente ou desde un proxecto Rust mediante Cargo.[97]

Clippy

Exemplo de saída de Clippy sobre un programa Rust de 'ola mundo'

Clippy é a ferramenta de linting integrada de Rust para mellorar a corrección, o rendemento e a lexibilidade do código Rust. A partir de 2024, conta con máis de 700 regras.[98][99]

Sistema de control de versións

Tras Rust 1.0, as novas funcionalidades desenvolvéronse nas versións nightly, que se publican diariamente. Durante cada ciclo de lanzamento de seis semanas, os cambios das versións nightly publícanse na versión beta, mentres que os cambios da versión beta anterior publícanse nunha nova versión estable.[100]

Cada dous ou tres anos, publícase unha nova “edición”. As edicións lévanse a cabo para permitir realizar cambios rompentes limitados, como promover await a unha palabra clave para soportar funcionalidades async/await. Os crates orientados a distintas edicións poden interoperar entre si, polo que un crate pode actualizarse a unha nova edición mesmo se os seus chamadores ou as súas dependencias aínda apuntan a edicións anteriores. A migración a unha nova edición pode asistirse con ferramentas automáticas.[101]

Soporte de IDE

Rust-analyzer é un conxunto de utilidades que proporciona ás contornas de desenvolvemento integrados (IDEs) e editores de texto información sobre un proxecto Rust mediante o Language Server Protocol. Isto habilita funcionalidades como autocompletado e visualización de erros de compilación mentres se edita o código.[102]

Rendemento

Como non realiza recollida de lixo (garbage collection), Rust é a miúdo máis rápido que outros idiomas seguros na xestión de memoria.[103][104][105] A maior parte das garantías de seguridade de memoria de Rust non impoñen sobrecarga en tempo de execución, agás a indexación de arrays, que por defecto se comproba en tempo de execución.[106] O impacto no rendemento das comprobacións de límites de arrays varía, pero pode ser significativo en algúns casos.[106]

Moitas das funcionalidades de Rust son chamadas abstraccións de custo cero, o que significa que se optimizan en tempo de compilación e non supoñen penalización en tempo de execución. O sistema de propiedade e préstamo permite implementacións sen copias para certas tarefas sensibles ao rendemento, como o parsing.[107] Por defecto utilízase static dispatch para eliminar chamadas a métodos, agás para métodos chamados sobre obxectos trait dinámicos. O compilador tamén emprega expansión en liña para eliminar chamadas a funcións e invocacións de métodos despachadas estaticamente.[108]

Como Rust usa LLVM, todas as melloras de rendemento en LLVM tamén se aplican a Rust.[109] Ao contrario que C e C++, Rust permite reordenar os elementos de structs e enums[110] para reducir o tamaño das estruturas na memoria, mellorando o aliñamento e a eficiencia da memoria.

Adopción

Firefox ten compoñentes escritos en Rust como parte do motor de navegador subxacente Gecko.

Rust úsase en software en distintos ámbitos. Compoñentes do motor de navegador Servo (financiado por Mozilla e Samsung) foron incorporados no motor de navegador Gecko, que subxace en Firefox.[111] En xaneiro de 2023, Google (Alphabet) anunciou soporte para usar librarías Rust de terceiros en Chromium.[112][113]

Rust úsase en varios proxectos de software de backend de grandes servizos web. OpenDNS, un servizo de resolución DNS propiedade de Cisco, utiliza Rust internamente.[114][115] Amazon Web Services emprega Rust en “compoñentes sensibles ao rendemento” de varios dos seus servizos. En 2019, AWS liberou como código aberto Firecracker, unha solución de virtualización escrita principalmente en Rust.[116] Microsoft Azure IoT Edge, unha plataforma usada para executar servizos de Azure en dispositivos IoT, ten compoñentes implementados en Rust.[117] Microsoft tamén emprega Rust para executar módulos conteinerizados con WebAssembly e Kubernetes.[118] Cloudflare, unha compañía que ofrece servizos de rede de distribución de contidos, utilizou Rust para construír un novo proxy web chamado Pingora, mellorando o rendemento e a eficiencia.[119] O xestor de paquetes npm utilizou Rust para o seu servizo de autenticación en produción en 2019.[120][121]

O proxecto Rust para Linux está soportado no núcleo Linux desde 2022.

Nos sistemas operativos, o proxecto Rust para Linux, lanzado en 2020, fusionou o soporte inicial no núcleo Linux versión 6.1 a finais de 2022.[122][123] O proxecto está activo cun equipo de 6–7 desenvolvedores e engadiu máis código en Rust coas versións do núcleo de 2022 a 2024,[124] co obxectivo de demostrar a viabilidade mínima do proxecto e resolver bloqueos clave de compatibilidade.[122][125] Os primeiros controladores escritos en Rust foron fusionados no núcleo para a versión 6.8.[122] Os desenvolvedores de Android empregaron Rust en 2021 para reescribir compoñentes existentes.[126][127] Microsoft reescribiu partes de Windows en Rust.[128] O proxecto r9 pretende reimplementar Plan 9 de Bell Labs en Rust.[129] Rust tamén se empregou no desenvolvemento de novos sistemas operativos como Redox, un sistema operativo e microkernel “Unix-like”,[130] Theseus, un sistema operativo experimental con xestión modular do estado,[131][132] e a maior parte de Fuchsia.[133] Rust tamén se usa para ferramentas de liña de comandos e compoñentes de sistemas operativos, incluíndo stratisd, un xestor de sistemas de ficheiros[134][135], e COSMIC, un escritorio desenvolvido por System76.[136] No desenvolvemento web, Deno, unha contorna segura de execución para JavaScript e TypeScript, está construída sobre V8 empregando Rust e Tokio.[137] Outras adopcións notables neste ámbito inclúen Ruffle, un emulador SWF de código aberto,[138] e Polkadot, unha plataforma de blockchain e criptomoeda de código aberto.[139]

Discord, unha empresa de software de mensaxería instantánea, reescribiu partes do seu sistema en Rust para aumentar o rendemento en 2020. No mesmo ano, Dropbox anunciou que a súa sincronización de ficheiros fora reescrita en Rust. Facebook (Meta) utilizou Rust para redeseñar o seu sistema que xestiona o código fonte dos proxectos internos.[140]

Na enquisa a desenvolvedores de Stack Overflow de 2024, o 12,6 % dos entrevistados realizara recentemente un desenvolvemento extensivo en Rust.[141] A enquisa nomeou a Rust como a “linguaxe de programación máis admirada” anualmente de 2016 a 2024 (inclusive), medida polo número de desenvolvedores existentes interesados en continuar traballando coa linguaxe.[142] En 2024, o 28,7 % dos desenvolvedores que actualmente non traballan con Rust expresaron interese en facelo.[141]

DARPA ten un proxecto chamado TRACTOR (Translating All C to Rust) que traduce automaticamente C a Rust empregando técnicas como análise estática, análise dinámica e modelos de linguaxe grande.[143]

Na investigación académica

A seguridade e o rendemento de Rust foron investigados en investigacións sobre teoría das linguaxes de programación.[144][83][145] A aplicabilidade de Rust para escribir software de investigación examinouse noutros campos. Un artigo publicado nos Proceedings of the International Astronomical Union utilizou Rust para simular sistemas de múltiples planetas.[146] Un artigo publicado en Nature compartiu historias de bioinformáticos que empregan Rust.[96] Ambos os artigos concluíron que Rust presenta vantaxes polo seu rendemento e seguridade, e citaron a curva de aprendizaxe como a principal desvantaxe para a súa adopción.

Comunidade

A bright orange crab icon
Algúns usuarios de Rust refírense a si mesmos como Rustaceans (semellante á palabra crustacean) e adoptaron un cangrexo laranxa, Ferris, como mascota non oficial.[147]

Segundo a MIT Technology Review, a comunidade de Rust foi considerada “infrecuentemente amigable” para os novos membros e atraeu particularmente a persoas da comunidade queer, en parte debido ao seu código de conduta, que establecía un conxunto de expectativas que os membros da comunidade Rust debían seguir.[140] A inclusión na comunidade foi citada como un factor importante por algúns desenvolvedores de Rust.[96] Datos demográficos sobre a comunidade foron recollidos e publicados no blog oficial de Rust.[148]

Segundo o proxecto State of the Octoverse de GitHub, a comunidade de Rust medrou un 50,5 % en 2022, converténdoa nunha das comunidades de máis rápido crecemento,[149] aínda que non está entre as 10 comunidades máis grandes a partir de 2024.[150]

Fundación Rust

fn main() {
    let x = 5;                // ------------------+- Tempo de vida 'a
                              //                   |
    let r = &x;               // -+-- Tempo de vida 'b  |
                              //  |                |
    println!("r: {}", r);     //  |                |
                              //  |                |
                              // -+                |
}                             // ------------------+

A Rust Foundation é unha organización sen ánimo de lucro con membros incorporada nos Estados Unidos, cuxos principais obxectivos son apoiar o proxecto técnico como entidade legal e axudar a xestionar a marca rexistrada e os activos de infraestrutura.[151][152]

Foi establecida o 8 de febreiro de 2021, con cinco membros corporativos fundadores (Amazon Web Services, Huawei, Google, Microsoft e Mozilla).[153] O consello da fundación está presidido por Shane Miller.[154] Desde finais de 2021, a súa Directora Executiva e CEO é Rebecca Rumbul.[155] Antes diso, Ashley Williams foi directora executiva interina.[152]

Equipos de gobernanza

O proxecto Rust está composto por equipos responsables de diferentes subáreas do desenvolvemento. O equipo do compilador desenvolve, xestiona e optimiza os elementos internos do compilador; e o equipo de linguaxe deseña novas funcionalidades da linguaxe e axuda a implementalas. O sitio web do proxecto Rust lista 6 equipos de nivel superior a partir de xullo de 2024.[156] Representantes dos distintos equipos forman o Consello de Liderado, que supervisa o proxecto Rust no seu conxunto.[157]

Notas

  1. A lista de versións do compilador de Rust (coñecida como cadea de arranque) ten unha historia que se remonta a 2012.[4]
  2. En comparación con C, o consumo de enerxía foi un 3 % maior en Rust e un 34 % maior en C++; o tempo de execución foi un 4 % maior e un 56 % maior, respectivamente.
  3. wrapping
    no_mangle
    
    with Modelo:Rust as well as prefacing the Modelo:Rust block with Modelo:Rust are required in the 2024 edition or later.[90]

Referencias

  1. 1,00 1,01 1,02 1,03 1,04 1,05 1,06 1,07 1,08 1,09 1,10 1,11 1,12 1,13 1,14 1,15 1,16 1,17 1,18 1,19 1,20 1,21 1,22 1,23 1,24 1,25 1,26 1,27 1,28 1,29 "How Rust went from a side project to the world’s most-loved programming language". MIT Technology Review (en inglés). Consultado o 2025-08-06. 
  2. 2,00 2,01 2,02 2,03 2,04 2,05 2,06 2,07 2,08 2,09 2,10 2,11 2,12 2,13 2,14 2,15 2,16 2,17 2,18 2,19 Klabnik, Steve (02-06-2016). The History of Rust. 
  3. "rust-lang/rust". 2025-08-06. Consultado o 2025-08-06. 
  4. Nelson, Jynn (2022-08-05). RustConf 2022 - Bootstrapping: The once and future compiler. Portland, Oregon: Rust Team. Consultado o 2024-10-29 – vía YouTube. 
  5. "680521 - Rust logo(type)". bugzilla.mozilla.org (en inglés). Consultado o 2025-08-06. 
  6. "[rust-dev] The Rust compiler 0.1 is unleashed". mail.mozilla.org. Consultado o 2025-08-06. 
  7. Anthony, Sebastian (2012-01-24). "Mozilla releases Rust 0.1, the language that will eventually usurp Firefox's C++". ExtremeTech (en inglés). Consultado o 2025-08-06. 
  8. rust-lang. "Purity by pcwalton · Pull Request #5412 · rust-lang/rust". GitHub (en inglés). Consultado o 2025-08-06. 
  9. "The Rise And Fall of Languages in 2013". Dr. Dobb's. Consultado o 2025-08-06. 
  10. Lardinois, Frederic. "Mozilla And Samsung Team Up To Develop Servo, Mozilla’s Next-Gen Browser Engine For Multicore Processors". TechCrunch (en inglés). Consultado o 2025-08-06. 
  11. "Firefox — Notes (45.0)". Mozilla (en inglés). Consultado o 2025-08-06. 
  12. Lardinois, Frederic (2017-09-29). "It's time to give Firefox another chance | TechCrunch". TechCrunch (en inglés). Consultado o 2025-08-06. 
  13. Pereira, Rui; Couto, Marco; Ribeiro, Francisco; Rua, Rui; Cunha, Jácome; Fernandes, João Paulo; Saraiva, João (2017-10-23). "Energy efficiency across programming languages: how do energy, time, and memory relate?". Proceedings of the 10th ACM SIGPLAN International Conference on Software Language Engineering. SLE 2017 (New York, NY, USA: Association for Computing Machinery): 256–267. ISBN 978-1-4503-5525-4. doi:10.1145/3136014.3136031. 
  14. Cimpanu, Catalin. "Mozilla lays off 250 employees while it refocuses on commercial products | ZDNet". ZDNet (en inglés). Consultado o 2025-08-06. 
  15. "Mozilla lays off 250 employees due to the pandemic". Engadget (en inglés). Consultado o 2025-08-06. 
  16. Tung, Liam. "Programming language Rust: Mozilla job cuts have hit us badly but here's how we'll survive | ZDNet". ZDNet (en inglés). Consultado o 2025-08-06. 
  17. "Laying the foundation for Rust's future | Rust Blog". blog.rust-lang.org (en inglés). Consultado o 2025-08-06. 
  18. "Rust Foundation". foundation.rust-lang.org (en inglés). Consultado o 2025-08-06. 
  19. "Mozilla Welcomes the Rust Foundation – The Mozilla Blog". The Mozilla Blog (en inglés). Consultado o 2025-08-06. 
  20. "Google is now writing low-level Android code in Rust". Ars Technica (en inglés). Consultado o 2025-08-06. 
  21. "Entire Rust moderation team resigns" (en inglés). Consultado o 2025-08-06. 
  22. "Governance Update | Inside Rust Blog". blog.rust-lang.org (en inglés). Consultado o 2025-08-06. 
  23. "Rust Foundation apologizes for trademark policy confusion" (en inglés). Consultado o 2025-08-06. 
  24. "White House urges developers to dump C and C++". InfoWorld (en inglés). Consultado o 2025-08-06. 
  25. "After decades of memory-related software bugs, White House calls on industry to act". therecord.media (en inglés). Consultado o 2025-08-06. 
  26. Jack, Bobby (2024-02-29). "The White House Wants Memory-Safe Programming, but What Is That?". MUO (en inglés). Consultado o 2025-08-06. 
  27. "In Rust we trust? White House Office urges memory safety - Stack Overflow". stackoverflow.blog (en inglés). 2024-12-30. Consultado o 2025-08-06. 
  28. "Rebecca Rumbul named new CEO of The Rust Foundation" (en inglés). Consultado o 2025-08-07. 
  29. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  30. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  31. "Scope and Shadowing - Rust By Example". doc.rust-lang.org. Consultado o 2025-08-07. 
  32. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  33. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  34. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  35. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  36. "Control Flow - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-08. 
  37. "Control Flow - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-08. 
  38. "Control Flow - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-08. 
  39. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  40. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  41. Klabnik; Nichols. The Rust Programming Language. p. 36-38. 
  42. Klabnik; Nichols. The Rust Programming Language. p. 502. 
  43. "Glossary". www.unicode.org. Consultado o 2025-08-08. 
  44. Klabnik; Nichols. The Rust Programming Language. p. 38–40. 
  45. Klabnik; Nichols. The Rust Programming Language. p. 40-42. 
  46. Klabnik; Nichols. The Rust Programming Language. p. 42. 
  47. Klabnik; Nichols. The Rust Programming Language. p. 59–61. 
  48. Klabnik; Nichols. The Rust Programming Language. p. 74–75. 
  49. Klabnik; Nichols. The Rust Programming Language. p. 71–72. 
  50. Balasubramanian, Abhiram; Baranowski, Marek S.; Burtsev, Anton; Panda, Aurojit; Rakamarić, Zvonimir; Ryzhyk, Leonid (2017-05-07). "System Programming in Rust". Proceedings of the 16th Workshop on Hot Topics in Operating Systems. HotOS '17. New York, NY, US: Association for Computing Machinery. pp. 156–161. ISBN 978-1-4503-5068-6. doi:10.1145/3102980.3103006. Arquivado dende o orixinal o 11 de xuño de 2022. Consultado o 1 de xuño de 2022. 
  51. "Lifetimes". Rust by Example. Arquivado dende o orixinal o 2024-11-16. Consultado o 2024-10-29. 
  52. "Explicit annotation". Rust by Example. Consultado o 2024-10-29. 
  53. Shamrell-Harrington, Nell (2022-04-15). "The Rust Borrow Checker – a Deep Dive". InfoQ (en inglés). Arquivado dende o orixinal o 2022-06-25. Consultado o 2022-06-25. 
  54. Klabnik; Nichols. The Rust Programming Language. p. 194. 
  55. "The Rust Programming Language - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-07. 
  56. Pearce, David (17 de abril de 2021). "A Lightweight Formalism for Reference Lifetimes and Borrowing in Rust". ACM Transactions on Programming Languages and Systems 43: 1–73. doi:10.1145/3443420. Arquivado dende o orixinal o 15 de abril de 2024. Consultado o 11 de decembro de 2024. 
  57. Klabnik, Carol; Nichols. The Rust Programming Language. p. 83. 
  58. Klabnik, Carol; Nichols. The Rust Programming Language. p. 97. 
  59. Klabnik; Nichols. The Rust Programming Language. p. 438–440. 
  60. Klabnik; Nichols. The Rust Programming Language. p. 93. 
  61. "Standard Library - Comprehensive Rust 🦀". google.github.io. Consultado o 2025-08-08. 
  62. Klabnik; Nichols. The Rust Programming Language. p. 108-110,113-114,116-117. 
  63. Klabnik; Nichols. The Rust Programming Language. p. 421-423. 
  64. Klabnik; Nichols. The Rust Programming Language. p. 418–427. 
  65. Klabnik; Nichols. The Rust Programming Language. p. 378. 
  66. Klabnik; Nichols. The Rust Programming Language. p. 192-198. 
  67. Klabnik; Nichols. The Rust Programming Language. p. 192-198. 
  68. Klabnik; Nichols. The Rust Programming Language. p. 192-198. 
  69. Klabnik; Nichols. The Rust Programming Language. p. 98. 
  70. Klabnik; Nichols. The Rust Programming Language. p. 171–172,205. 
  71. "Using Trait Objects That Allow for Values of Different Types - The Rust Programming Language". doc.rust-lang.org. Consultado o 2025-08-28. 
  72. "rust-lang/rust". 2025-08-06. Consultado o 2025-08-06. 
  73. Klabnik; Nichols. The Rust Programming Language. p. 379–380. 
  74. "A taste of Rust [LWN.net]". lwn.net. Consultado o 2025-08-07. 
  75. "Races -". doc.rust-lang.org (en inglés). Consultado o 2025-08-07. 
  76. Vandervelden, Thibaut; De Smet, Ruben; Deac, Diana; Steenhaut, Kris; Braeken, An (7 de setembro de 2024). "Overview of Embedded Rust Operating Systems and Frameworks". Sensors 24 (17): 5818. Bibcode:2024Senso..24.5818V. PMC 11398098. PMID 39275729 |pmid= incorrecto (Axuda). doi:10.3390/s24175818. 
  77. "The Rust Language FAQ". static.rust-lang.org (en inglés). Consultado o 2025-08-07. 
  78. "RAII - Rust By Example". doc.rust-lang.org (en inglés). Consultado o 2025-08-07. 
  79. "Abstraction without overhead: traits in Rust | Rust Blog". blog.rust-lang.org (en inglés). Consultado o 2025-08-07. 
  80. "Box, stack and heap". Rust by Example. Arquivado dende o orixinal o 2022-05-31. Consultado o 2022-06-13. 
  81. Klabnik; Nichols. The Rust Programming Language. p. 70–75. 
  82. Klabnik; Nichols. The Rust Programming Language. p. 323. 
  83. 83,0 83,1 Astrauskas, Vytautas; Matheja, Christoph; Poli, Federico; Müller, Peter; Summers, Alexander J. (2020-11-13). "How do programmers use unsafe rust?". Proceedings of the ACM on Programming Languages (en inglés) 4 (OOPSLA): 1–27. ISSN 2475-1421. doi:10.1145/3428204. hdl:20.500.11850/465785. 
  84. Rust Programming Language. p. 449–455. 
  85. Rust Programming Language. p. 101-102. 
  86. "Macros By Example". The Rust Reference. Arquivado dende o orixinal o 2023-04-21. Consultado o 21 de abril de 2023. 
  87. Rust Programming Language. p. 446–448. 
  88. "Procedural Macros". The Rust Programming Language Reference. Arquivado dende o orixinal o 7 de novembro de 2020. Consultado o 23 Mar 2021. 
  89. Rust Programming Language. p. 449–455. 
  90. Baumgartner, Stefan (2025-05-23). "Programming language: Rust 2024 is the most comprehensive edition to date". heise online (en inglés). Consultado o 2025-06-28. 
  91. "Safe Interoperability between Rust and C++ with CXX". InfoQ (en inglés). 2020-12-06. Arquivado dende o orixinal o 22 de xaneiro de 2021. Consultado o 2021-01-03. 
  92. "Introduction - The rustup book". rust-lang.github.io. Consultado o 2025-08-28. 
  93. "Code Generation". Rust Compiler Development Guide. Rust project contributors. Consultado o 3 de marzo de 2024. 
  94. "rust-lang/rustc_codegen_gcc". GitHub. The Rust Programming Language. 2 de marzo de 2024. Consultado o 3 de marzo de 2024. 
  95. "rust-lang/rustc_codegen_cranelift". GitHub. The Rust Programming Language. 2 de marzo de 2024. Consultado o 3 de marzo de 2024. 
  96. 96,0 96,1 96,2 Perkel, Jeffrey M. (2020-12-01). "Why scientists are turning to Rust". Nature (en inglés) 588 (7836): 185–186. Bibcode:2020Natur.588..185P. PMID 33262490. doi:10.1038/d41586-020-03382-2. Arquivado dende o orixinal o 6 de maio de 2022. Consultado o 15 de maio de 2022. 
  97. Rust Programming Language. p. 511–512. 
  98. "Clippy". GitHub. The Rust Programming Language. 2023-11-30. Arquivado dende o orixinal o 2021-05-23. Consultado o 2023-11-30. 
  99. "Clippy Lints". The Rust Programming Language. Consultado o 2023-11-30. 
  100. Klabnik & Nichols 2019, Appendix G – How Rust is Made and "Nightly Rust"
  101. "Transitioning an existing project to a new edition - The Rust Edition Guide". doc.rust-lang.org. Consultado o 2025-08-28. 
  102. Rust Programming Language. p. 623. 
  103. Anderson, Tim (2021-11-30). "Can Rust save the planet? Why, and why not". The Register (en inglés). Arquivado dende o orixinal o 2022-07-11. Consultado o 2022-07-11. 
  104. Balasubramanian, Abhiram; Baranowski, Marek S.; Burtsev, Anton; Panda, Aurojit; Rakamarić, Zvonimir; Ryzhyk, Leonid (2017-05-07). "System Programming in Rust". Proceedings of the 16th Workshop on Hot Topics in Operating Systems. HotOS '17. New York, NY, US: Association for Computing Machinery. pp. 156–161. ISBN 978-1-4503-5068-6. doi:10.1145/3102980.3103006. Arquivado dende o orixinal o 11 de xuño de 2022. Consultado o 1 de xuño de 2022. 
  105. Yegulalp, Serdar (2021-10-06). "What is the Rust language? Safe, fast, and easy software development". InfoWorld (en inglés). Arquivado dende o orixinal o 2022-06-24. Consultado o 2022-06-25. 
  106. 106,0 106,1 Popescu, Natalie; Xu, Ziyang; Apostolakis, Sotiris; August, David I.; Levy, Amit (2021-10-15). "Safer at any speed: automatic context-aware safety enhancement for Rust". Proceedings of the ACM on Programming Languages 5 (OOPSLA). Section 2. doi:10.1145/3485480. We observe a large variance in the overheads of checked indexing: 23.6% of benchmarks do report significant performance hits from checked indexing, but 64.5% report little-to-no impact and, surprisingly, 11.8% report improved performance ... Ultimately, while unchecked indexing can improve performance, most of the time it does not. 
  107. Couprie, Geoffroy (2015). "Nom, A Byte oriented, streaming, Zero copy, Parser Combinators Library in Rust". 2015 IEEE Security and Privacy Workshops. pp. 142–148. ISBN 978-1-4799-9933-0. doi:10.1109/SPW.2015.31. 
  108. "Code generation". The Rust Reference. Arquivado dende o orixinal o 2022-10-09. Consultado o 2022-10-09. 
  109. "How Fast Is Rust?". The Rust Programming Language FAQ. Arquivado dende o orixinal o 28 de outubro de 2020. Consultado o 11 de abril de 2019. 
  110. Farshin, Alireza; Barbette, Tom; Roozbeh, Amir; Maguire, Gerald Q. Jr; Kostić, Dejan (2021). "PacketMill: Toward per-Core 100-GBPS networking". Proceedings of the 26th ACM International Conference on Architectural Support for Programming Languages and Operating Systems (en inglés). pp. 1–17. ISBN 9781450383172. doi:10.1145/3445814.3446724. Arquivado dende o orixinal o 2022-07-12. Consultado o 2022-07-12. ... While some compilers (e.g., Rust) support structure reordering [82], C & C++ compilers are forbidden to reorder data structures (e.g., struct or class) [74] ... 
  111. Keizer, Gregg (2016-10-31). "Mozilla plans to rejuvenate Firefox in 2017". Computerworld (en inglés). Arquivado dende o orixinal o 2023-05-13. Consultado o 2023-05-13. 
  112. Claburn, Thomas (2023-01-12). "Google polishes Chromium code with a layer of Rust". The Register. Consultado o 2024-07-17. 
  113. Jansens, Dana (2023-01-12). "Supporting the Use of Rust in the Chromium Project". Google Online Security Blog (en inglés). Arquivado dende o orixinal o 2023-01-13. Consultado o 2023-11-12. 
  114. Shankland, Stephen (2016-07-12). "Firefox will get overhaul in bid to get you interested again" (en inglés). CNET. Arquivado dende o orixinal o 2022-07-14. Consultado o 2022-07-14. 
  115. Security Research Team (2013-10-04). "ZeroMQ: Helping us Block Malicious Domains in Real Time". Cisco Umbrella (en inglés). Arquivado dende o orixinal o 2023-05-13. Consultado o 2023-05-13. 
  116. Cimpanu, Catalin (2019-10-15). "AWS to sponsor Rust project". ZDNET (en inglés). Consultado o 2024-07-17. 
  117. Nichols, Shaun (27 de xuño de 2018). "Microsoft's next trick? Kicking things out of the cloud to Azure IoT Edge". The Register (en inglés). Arquivado dende o orixinal o 2019-09-27. Consultado o 2019-09-27. 
  118. Tung, Liam (2020-04-30). "Microsoft: Why we used programming language Rust over Go for WebAssembly on Kubernetes app". ZDNET (en inglés). Arquivado dende o orixinal o 21 de abril de 2022. Consultado o 2022-04-21. 
  119. Claburn, Thomas (20 de setembro de 2022). "In Rust We Trust: Microsoft Azure CTO shuns C and C++". The Register. Consultado o 7 de xullo de 2024. 
  120. Simone, Sergio De (2019-03-10). "NPM Adopted Rust to Remove Performance Bottlenecks". InfoQ (en inglés). Arquivado dende o orixinal o 2023-11-19. Consultado o 2023-11-20. 
  121. Lyu, Shing (2020). "Welcome to the World of Rust". En Lyu, Shing. Practical Rust Projects: Building Game, Physical Computing, and Machine Learning Applications (en inglés). Berkeley, CA: Apress. pp. 1–8. ISBN 978-1-4842-5599-5. doi:10.1007/978-1-4842-5599-5_1. Consultado o 2023-11-29. 
  122. 122,0 122,1 122,2 Li, Hongyu; Guo, Liwei; Yang, Yexuan; Wang, Shangguang; Xu, Mengwei (2024-06-30). "An Empirical Study of Rust-for-Linux: The Success, Dissatisfaction, and Compromise". USENIX (en inglés). Consultado o 2024-11-28. 
  123. Corbet, Jonathan (2022-10-13). "A first look at Rust in the 6.1 kernel". LWN.net. Arquivado dende o orixinal o 2023-11-17. Consultado o 2023-11-11. 
  124. Corbet, Jonathan (2022-11-17). "Rust in the 6.2 kernel". LWN.net. Consultado o 2024-11-28. 
  125. Corbet, Jonathan (2024-09-24). "Committing to Rust in the kernel". LWN.net. Consultado o 2024-11-28. 
  126. Amadeo, Ron (2021-04-07). "Google is now writing low-level Android code in Rust". Ars Technica (en inglés). Arquivado dende o orixinal o 8 de abril de 2021. Consultado o 2022-04-21. 
  127. Darkcrizt (2 de abrli de 2021). "Google Develops New Bluetooth Stack for Android, Written in Rust". Desde Linux. Arquivado dende o orixinal o 25 de agosto de 2021. Consultado o 31 de agosto de 2024. 
  128. Proven, Liam (1 de decembro de 2023). "Small but mighty, 9Front's 'Humanbiologics' is here for the truly curious". The Register. Consultado o 7 de marzo de 2024. 
  129. Proven, Liam (1 de decembro de 2023). "Small but mighty, 9Front's 'Humanbiologics' is here for the truly curious". The Register. Consultado o 7 de marzo de 2024. 
  130. Yegulalp, Serdar (21 de marzo de 2016). "Rust's Redox OS could show Linux a few new tricks". InfoWorld. Arquivado dende o orixinal o 21 de marzo de 2016. Consultado o 21 de marzo de 2016. 
  131. Anderson, Tim (2021-01-14). "Another Rust-y OS: Theseus joins Redox in pursuit of safer, more resilient systems". The Register (en inglés). Arquivado dende o orixinal o 2022-07-14. Consultado o 2022-07-14. 
  132. Boos, Kevin; Liyanage, Namitha; Ijaz, Ramla; Zhong, Lin (2020). Theseus: an Experiment in Operating System Structure and State Management (en inglés). pp. 1–19. ISBN 978-1-939133-19-9. Arquivado dende o orixinal o 2023-05-13. Consultado o 2023-05-13. 
  133. Zhang, HanDong (2023-01-31). "2022 Review | The adoption of Rust in Business". Rust Magazine (en inglés). Consultado o 7 de febreiro de 2023. 
  134. Sei, Mark (10 de outubro de 2018). "Fedora 29 new features: Startis now officially in Fedora". Marksei, Weekly sysadmin pills. Arquivado dende o orixinal o 2019-04-13. Consultado o 2019-05-13. 
  135. Proven, Liam (2022-07-12). "Oracle Linux 9 released, with some interesting additions". The Register (en inglés). Arquivado dende o orixinal o 2022-07-14. Consultado o 2022-07-14. 
  136. Proven, Liam (2023-02-02). "System76 teases features coming in homegrown Rust-based desktop COSMIC". The Register (en inglés). Arquivado dende o orixinal o 2024-07-17. Consultado o 2024-07-17. 
  137. Hu, Vivian (2020-06-12). "Deno Is Ready for Production". InfoQ (en inglés). Arquivado dende o orixinal o 2020-07-01. Consultado o 2022-07-14. 
  138. Abrams, Lawrence (2021-02-06). "This Flash Player emulator lets you securely play your old games". Bleeping Computer (en inglés). Arquivado dende o orixinal o 2021-12-25. Consultado o 2021-12-25. 
  139. Kharif, Olga (17 de outubro de 2020). "Ethereum Blockchain Killer Goes By Unassuming Name of Polkadot". Bloomberg News. Bloomberg L.P. Arquivado dende o orixinal o 2020-10-17. Consultado o 14 de xullo de 2021. 
  140. 140,0 140,1 Thompson, Clive (2023-02-14). "How Rust went from a side project to the world's most-loved programming language". MIT Technology Review (en inglés). Arquivado dende o orixinal o 2024-09-19. Consultado o 2023-02-23. 
  141. 141,0 141,1 "2024 Stack Overflow Developer Survey – Technology". Stack Overflow. Consultado o 2024-11-28. 
  142. Claburn, Thomas (2022-06-23). "Linus Torvalds says Rust is coming to the Linux kernel". The Register (en inglés). Arquivado dende o orixinal o 2022-07-28. Consultado o 2022-07-15. 
  143. Wallach, Dan. "TRACTOR: Translating All C to Rust". DARPA. Consultado o 3 de agosto de 2025. 
  144. Jung, Ralf; Jourdan, Jacques-Henri; Krebbers, Robbert; Dreyer, Derek (2017-12-27). "RustBelt: securing the foundations of the Rust programming language". Proceedings of the ACM on Programming Languages (en inglés) 2 (POPL): 1–34. ISSN 2475-1421. doi:10.1145/3158154. hdl:21.11116/0000-0003-34C6-3. 
  145. Popescu, Natalie; Xu, Ziyang; Apostolakis, Sotiris; August, David I.; Levy, Amit (2021-10-20). "Safer at any speed: automatic context-aware safety enhancement for Rust". Proceedings of the ACM on Programming Languages (en inglés) 5 (OOPSLA): 1–23. ISSN 2475-1421. doi:10.1145/3485480. 
  146. Blanco-Cuaresma, Sergi; Bolmont, Emeline (2017-05-30). "What can the programming language Rust do for astrophysics?". Proceedings of the International Astronomical Union (en inglés) 12 (S325): 341–344. Bibcode:2017IAUS..325..341B. ISSN 1743-9213. arXiv:1702.02951. doi:10.1017/S1743921316013168. Arquivado dende o orixinal o 2022-06-25. Consultado o 2022-06-25. 
  147. "Getting Started". The Rust Programming Language. Arquivado dende o orixinal o 1 de novembro de 2020. Consultado o 11 de outubro de 2020. 
  148. "2024 State of Rust Survey Results". Rust-lang.org Blog (en inglés). Consultado o 2025-04-06. 
  149. "The top programming languages". The State of the Octoverse (en inglés). Consultado o 2025-06-25. 
  150. Staff, GitHub (2024-10-29). "Octoverse: AI leads Python to top language as the number of global developers surges". The GitHub Blog (en inglés). Consultado o 2025-06-25. 
  151. Tung, Liam (2021-02-08). "The Rust programming language just took a huge step forwards". ZDNET (en inglés). Arquivado dende o orixinal o 2022-07-14. Consultado o 2022-07-14. 
  152. 152,0 152,1 Vigliarolo, Brandon (2021-02-10). "The Rust programming language now has its own independent foundation". TechRepublic (en inglés). Arquivado dende o orixinal o 2023-03-20. Consultado o 2022-07-14. 
  153. Krill, Paul (9 de febreiro de 2021). "Rust language moves to independent foundation". InfoWorld. Arquivado dende o orixinal o 10 de abril de 2021. Consultado o 10 de abril de 2021. 
  154. Krill, Paul (9 de febreiro de 2021). "Rust language moves to independent foundation". InfoWorld. Arquivado dende o orixinal o 10 de abril de 2021. Consultado o 10 de abril de 2021. 
  155. Vaughan-Nichols, Steven J. (17 de novembro de 2021). "Rust Foundation appoints Rebecca Rumbul as executive director". ZDNET. Arquivado dende o orixinal o 18 de novembro de 2021. Consultado o 18 de novembro de 2021. 
  156. "Governance". The Rust Programming Language (en inglés). Arquivado dende o orixinal o 10 de maio de 2022. Consultado o 2024-07-18. 
  157. "Introducing the Rust Leadership Council". Rust Blog (en inglés). Consultado o 2024-01-12. 

Véxase tamén

Bibliografía

Ligazóns externas

Kembali kehalaman sebelumnya