Rust における構文分解と参照解除

RustRustBeginner
今すぐ練習

This tutorial is from open-source community. Access the source code

💡 このチュートリアルは英語版からAIによって翻訳されています。原文を確認するには、 ここをクリックしてください

はじめに

この実験では、Rust における構文分解と参照解除の概念を探り、C/C++ のような言語と比較したそれらの使用方法の違いを強調します。構文分解では、&ref、および ref mut を使用して参照を割り当てて一致させますが、参照解除では * を使用して参照が指す値にアクセスします。

注: 実験でファイル名が指定されていない場合は、好きなファイル名を使用できます。たとえば、main.rs を使用して、rustc main.rs &&./main でコンパイルして実行できます。


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL rust(("Rust")) -.-> rust/BasicConceptsGroup(["Basic Concepts"]) rust(("Rust")) -.-> rust/DataTypesGroup(["Data Types"]) rust(("Rust")) -.-> rust/FunctionsandClosuresGroup(["Functions and Closures"]) rust(("Rust")) -.-> rust/MemorySafetyandManagementGroup(["Memory Safety and Management"]) rust/BasicConceptsGroup -.-> rust/variable_declarations("Variable Declarations") rust/BasicConceptsGroup -.-> rust/mutable_variables("Mutable Variables") rust/DataTypesGroup -.-> rust/integer_types("Integer Types") rust/FunctionsandClosuresGroup -.-> rust/function_syntax("Function Syntax") rust/FunctionsandClosuresGroup -.-> rust/expressions_statements("Expressions and Statements") rust/MemorySafetyandManagementGroup -.-> rust/lifetime_specifiers("Lifetime Specifiers") subgraph Lab Skills rust/variable_declarations -.-> lab-99313{{"Rust における構文分解と参照解除"}} rust/mutable_variables -.-> lab-99313{{"Rust における構文分解と参照解除"}} rust/integer_types -.-> lab-99313{{"Rust における構文分解と参照解除"}} rust/function_syntax -.-> lab-99313{{"Rust における構文分解と参照解除"}} rust/expressions_statements -.-> lab-99313{{"Rust における構文分解と参照解除"}} rust/lifetime_specifiers -.-> lab-99313{{"Rust における構文分解と参照解除"}} end

ポインタ/参照

ポインタに関しては、構文分解と参照解除を区別する必要があります。これらは異なる概念であり、C/C++ のような言語とは異なる方法で使用されます。

  • 参照解除には * を使用します
  • 構文分解には &ref、および ref mut を使用します
fn main() {
    // `i32` 型の参照を割り当てます。`&` は、割り当てられている参照があることを示しています。
    let reference = &4;

    match reference {
        // `reference` が `&val` とパターンマッチする場合、次のような比較が行われます。
        // `&i32`
        // `&val`
        // ^ 一致する `&` を削除すると、`i32` が `val` に割り当てられるはずです。
        &val => println!("構文分解を通じて値を取得しました: {:?}", val),
    }

    // `&` を回避するには、マッチングする前に参照解除します。
    match *reference {
        val => println!("参照解除を通じて値を取得しました: {:?}", val),
    }

    // 参照で始まらない場合どうなるでしょうか。`reference` は `&` でした
    // 右辺が既に参照だったためです。これは参照ではありません
    // 右辺が参照ではないためです。
    let _not_a_reference = 3;

    // Rust はまさにこの目的のために `ref` を提供しています。これは割り当てを変更して
    // 要素に対して参照が作成されるようにします。この参照が割り当てられます。
    let ref _is_a_reference = 3;

    // したがって、参照なしで 2 つの値を定義することで、
    // `ref` と `ref mut` を使用して参照を取得できます。
    let value = 5;
    let mut mut_value = 6;

    // `ref` キーワードを使用して参照を作成します。
    match value {
        ref r => println!("値への参照を取得しました: {:?}", r),
    }

    // 同様に `ref mut` を使用します。
    match mut_value {
        ref mut m => {
            // 参照を取得しました。何かを追加する前に参照解除する必要があります。
            *m += 10;
            println!("10 を追加しました。`mut_value`: {:?}", m);
        },
    }
}

まとめ

おめでとうございます!あなたはポインタ/参照の実験を完了しました。あなたの技術を向上させるために、LabEx でさらに多くの実験を練習できます。