タプル
タプルは異なる型の値の集合です。括弧()
を用いて生成します。タプル自体がそのメンバに対する型シグネチャを保持していますので、明示すると(T1, T2, ...)
のようになります。タプルは大きさに制限がありませんので、関数が複数の値を返したい時に使われます。
// Tuples can be used as function arguments and as return values // タプルを関数の引数及び返り値として使用している。 fn reverse(pair: (i32, bool)) -> (bool, i32) { // `let` can be used to bind the members of a tuple to variables // `let`でタプルの中の値を別の変数に束縛することができる。 let (integer, boolean) = pair; (boolean, integer) } // The following struct is for the activity. // 以下の構造体は後ほど「演習」で用いる。 #[derive(Debug)] struct Matrix(f32, f32, f32, f32); fn main() { // A tuple with a bunch of different types // 様々な型を値に持つタプル let long_tuple = (1u8, 2u16, 3u32, 4u64, -1i8, -2i16, -3i32, -4i64, 0.1f32, 0.2f64, 'a', true); // Values can be extracted from the tuple using tuple indexing // インデックスを用いて、タプル内の要素を参照できる。 println!("long tuple first value: {}", long_tuple.0); println!("long tuple second value: {}", long_tuple.1); // Tuples can be tuple members // タプルはタプルのメンバになれる let tuple_of_tuples = ((1u8, 2u16, 2u32), (4u64, -1i8), -2i16); // Tuples are printable // タプルはプリント可能である。 println!("tuple of tuples: {:?}", tuple_of_tuples); // But long Tuples cannot be printed // しかし長すぎるタプルはプリントできない // let too_long_tuple = (1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13); // println!("too long tuple: {:?}", too_long_tuple); // TODO ^ Uncomment the above 2 lines to see the compiler error // TODO ^ 上記2行のコメントを外して、コンパイルエラーになることを確認 let pair = (1, true); println!("pair is {:?}", pair); println!("the reversed pair is {:?}", reverse(pair)); // To create one element tuples, the comma is required to tell them apart // from a literal surrounded by parentheses // 要素を1つしか持たないタプルを作成する場合、括弧で囲まれたただのリテラル // と区別するため、カンマが必要になる。 println!("one element tuple: {:?}", (5u32,)); println!("just an integer: {:?}", (5u32)); //tuples can be destructured to create bindings //タプルを分解して別の変数にそれぞれの値を代入 let tuple = (1, "hello", 4.5, true); let (a, b, c, d) = tuple; println!("{:?}, {:?}, {:?}, {:?}", a, b, c, d); let matrix = Matrix(1.1, 1.2, 2.1, 2.2); println!("{:?}", matrix); }
演習
-
復習 : 上にある
Matrix
という構造体に、fmt::Display
トレイトを追加しましょう。デバッグフォーマット{:?}
ではなくディスプレイフォーマット{}
でプリントすることができるようになるはずです。( 1.1 1.2 ) ( 2.1 2.2 )
必要に応じてprint displayのページに戻る必要があるかもしれません。
-
reverse
関数を雛形にしたtranspose
関数を実装してください。この関数はMatrix
を引数として受け取り、要素のうち2つを入れ替えたものを返します。つまりprintln!("Matrix:\n{}", matrix); println!("Transpose:\n{}", transpose(matrix));
は以下の様な出力になります:
Matrix: ( 1.1 1.2 ) ( 2.1 2.2 ) Transpose: ( 1.1 2.1 ) ( 1.2 2.2 )