- Learning Rust
- Paul Johnson Vesa Kaihlavirta
- 401字
- 2021-07-02 23:07:20
A practical example
In the example code, matrix, we can see how to use a 2D array and how to pass by a reference, with the receiving function calculating the result of a matrix multiplication. Let's examine the code:
fn main() { // first create a couple of arrays - these will be used // for the vectors let line1: [i32; 4] = [4, 2, 3, 3]; let line2: [i32; 4] = [3, 4, 5, 7]; let line3: [i32; 4] = [2, 9, 6, 2]; let line4: [i32; 4] = [5, 7, 2, 4]; // create two holding arrays and assign // we are creating an array of references let array_one = [&line1, &line3, &line4, &line2]; let array_two = [&line2, &line1, &line3, &line4]; // let's do the multiply // we are passing in a ref array containing ref arrays let result = matrix_multiply(&array_one, &array_two); println!("{:?}", result); } fn matrix_multiply(vec1: &[&[i32;4];4], vec2: &[&[i32;4];4]) -> [[i32; 4];4] { // we need to create the arrays to put the results into let mut result = [[0i32; 4]; 4]; // loop through the two vectors for vone in 0..4 { for vtwo in 0..4 { let mut sum = 0; for k in 0..4 { sum += vec1[vone][k] * vec2[k][vtwo]; } result[vone][vtwo] = sum; } } result }
When compiled, you will get the following output:

What we need to really consider here is the definition line for the matrix_multiply function:
fn matrix_multiply(vec1: &[&[i32;4];4], vec2: &[&[i32;4];4]) -> [[i32; 4];4]
If you recall how we told a function the name of the variable and the type earlier, we said it was variable_name: variable_type. The preceding line may look very much different, but it really isn't:

We are passing in a reference to a holding array, which holds references to other arrays. The array is defined using [i32;4]; therefore, the reference is &[i32;4]. This is the inner array. The outer array [i32;4] is also a reference (&[i32;4]), which has a size of 4. Therefore, when we put these together, we have the following:

The preceding example shows how to pass by a reference quite nicely, though in reality, it is most likely that the compiler will optimize this out to something faster for such a small data sample. It does show, however, how it's done.
The golden rule is that what you send over to the function has to marry up with what the function is expecting.
- Designing Machine Learning Systems with Python
- ClickHouse性能之巔:從架構設計解讀性能之謎
- Intel Galileo Essentials
- Rust編程從入門到實戰
- HTML5+CSS3網站設計教程
- Building Cross-Platform Desktop Applications with Electron
- Windows Server 2012 Unified Remote Access Planning and Deployment
- Visual C++開發入行真功夫
- Learning Probabilistic Graphical Models in R
- AIRIOT物聯網平臺開發框架應用與實戰
- Swift 4 Protocol-Oriented Programming(Third Edition)
- 從零開始:C語言快速入門教程
- PHP項目開發全程實錄(第4版)
- 游戲設計的底層邏輯
- VMware vRealize Orchestrator Essentials