Rouille - Structure

Les tableaux sont utilisés pour représenter une collection homogène de valeurs. De même, une structure est un autre type de données défini par l'utilisateur disponible dans Rust qui nous permet de combiner des éléments de données de différents types, y compris une autre structure. Une structure définit les données comme une paire clé-valeur.

Syntaxe - Déclaration d'une structure

Le mot - clé struct est utilisé pour déclarer une structure. Les structures étant typées statiquement, chaque champ de la structure doit être associé à un type de données. Les règles et conventions de dénomination d'une structure sont similaires à celles d'une variable. Le bloc de structure doit se terminer par un point-virgule.

struct Name_of_structure {
   field1:data_type,
   field2:data_type,
   field3:data_type
}

Syntaxe - Initialisation d'une structure

Après avoir déclaré une structure, chaque champ doit recevoir une valeur. C'est ce qu'on appelle l'initialisation.

let instance_name = Name_of_structure {
   field1:value1,
   field2:value2,
   field3:value3
}; 
//NOTE the semicolon
Syntax: Accessing values in a structure
Use the dot notation to access value of a specific field.
instance_name.field1
Illustration
struct Employee {
   name:String,
   company:String,
   age:u32
}
fn main() {
   let emp1 = Employee {
      company:String::from("TutorialsPoint"),
      name:String::from("Mohtashim"),
      age:50
   };
   println!("Name is :{} company is {} age is {}",emp1.name,emp1.company,emp1.age);
}

L'exemple ci-dessus déclare une structure Employee avec trois champs - nom, société et âge des types. Le main () initialise la structure. Il utilise le println! macro pour imprimer les valeurs des champs définis dans la structure.

Production

Name is :Mohtashim company is TutorialsPoint age is 50

Modifier une instance de struct

Pour modifier une instance, la variable d'instance doit être marquée mutable. L'exemple ci-dessous déclare et initialise une structure nommée Employee et modifie ultérieurement la valeur du champ age à 40 de 50.

let mut emp1 = Employee {
   company:String::from("TutorialsPoint"),
   name:String::from("Mohtashim"),
   age:50
};
emp1.age = 40;
println!("Name is :{} company is {} age is 
{}",emp1.name,emp1.company,emp1.age);

Production

Name is :Mohtashim company is TutorialsPoint age is 40

Passer une structure à une fonction

L'exemple suivant montre comment passer une instance de struct en tant que paramètre. La méthode d'affichage prend une instance Employee comme paramètre et imprime les détails.

fn display( emp:Employee) {
   println!("Name is :{} company is {} age is 
   {}",emp.name,emp.company,emp.age);
}

Voici le programme complet -

//declare a structure
struct Employee {
   name:String,
   company:String,
   age:u32
}
fn main() {
   //initialize a structure
   let emp1 = Employee {
      company:String::from("TutorialsPoint"),
      name:String::from("Mohtashim"),
      age:50
   };
   let emp2 = Employee{
      company:String::from("TutorialsPoint"),
      name:String::from("Kannan"),
      age:32
   };
   //pass emp1 and emp2 to display()
   display(emp1);
   display(emp2);
}
// fetch values of specific structure fields using the 
// operator and print it to the console
fn display( emp:Employee){
   println!("Name is :{} company is {} age is 
   {}",emp.name,emp.company,emp.age);
}

Production

Name is :Mohtashim company is TutorialsPoint age is 50
Name is :Kannan company is TutorialsPoint age is 32

Renvoyer une structure depuis une fonction

Considérons une fonction who_is_elder () , qui compare l'âge de deux employés et renvoie le plus âgé.

fn who_is_elder (emp1:Employee,emp2:Employee)->Employee {
   if emp1.age>emp2.age {
      return emp1;
   } else {
      return emp2;
   }
}

Voici le programme complet -

fn main() {
   //initialize structure
   let emp1 = Employee{
      company:String::from("TutorialsPoint"),
      name:String::from("Mohtashim"),
      age:50
   };
   let emp2 = Employee {
      company:String::from("TutorialsPoint"),
      name:String::from("Kannan"),
      age:32
   };
   let elder = who_is_elder(emp1,emp2);
   println!("elder is:");

   //prints details of the elder employee
   display(elder);
}
//accepts instances of employee structure and compares their age
fn who_is_elder (emp1:Employee,emp2:Employee)->Employee {
   if emp1.age>emp2.age {
      return emp1;
   } else {
      return emp2;
   }
}
//display name, comapny and age of the employee
fn display( emp:Employee) {
   println!("Name is :{} company is {} age is {}",emp.name,emp.company,emp.age);
}
//declare a structure
struct Employee {
   name:String,
   company:String,
   age:u32
}

Production

elder is:
Name is :Mohtashim company is TutorialsPoint age is 50

Méthode dans la structure

Les méthodes sont comme des fonctions. Il s'agit d'un groupe logique d'instructions de programmation. Les méthodes sont déclarées avec lefnmot-clé. La portée d'une méthode se trouve dans le bloc de structure.

Les méthodes sont déclarées en dehors du bloc de structure. leimplLe mot-clé est utilisé pour définir une méthode dans le contexte d'une structure. Le premier paramètre d'une méthode sera toujoursself, qui représente l'instance appelante de la structure. Les méthodes opèrent sur les données membres d'une structure.

Pour invoquer une méthode, nous devons d'abord instancier la structure. La méthode peut être appelée à l'aide de l'instance de la structure.

Syntaxe

struct My_struct {}
impl My_struct { 
   //set the method's context
   fn method_name() { 
      //define a method
   }
}

Illustration

L'exemple suivant définit une structure Rectangle avec des champs - largeur et hauteur . Une zone de méthode est définie dans le contexte de la structure. La méthode area accède aux champs de la structure via le mot-clé self et calcule l'aire d'un rectangle.

//define dimensions of a rectangle
struct Rectangle {
   width:u32, height:u32
}

//logic to calculate area of a rectangle
impl Rectangle {
   fn area(&self)->u32 {
      //use the . operator to fetch the value of a field via the self keyword
      self.width * self.height
   }
}

fn main() {
   // instanatiate the structure
   let small = Rectangle {
      width:10,
      height:20
   };
   //print the rectangle's area
   println!("width is {} height is {} area of Rectangle 
   is {}",small.width,small.height,small.area());
}

Production

width is 10 height is 20 area of Rectangle is 200

Méthode statique dans la structure

Les méthodes statiques peuvent être utilisées comme méthodes utilitaires. Ces méthodes existent avant même que la structure ne soit instanciée. Les méthodes statiques sont appelées à l'aide du nom de la structure et sont accessibles sans instance. Contrairement aux méthodes normales, une méthode statique ne prendra pas le paramètre & self .

Syntaxe - Déclaration d'une méthode statique

Une méthode statique telle que des fonctions et d'autres méthodes peut éventuellement contenir des paramètres.

impl Structure_Name {
   //static method that creates objects of the Point structure
   fn method_name(param1: datatype, param2: datatype) -> return_type {
      // logic goes here
   }
}

Syntaxe - Invocation d'une méthode statique

La syntaxe structure_name :: est utilisée pour accéder à une méthode statique.

structure_name::method_name(v1,v2)

Illustration

L'exemple suivant utilise la méthode getInstance comme classe de fabrique qui crée et retourne des instances de la structure Point .

//declare a structure
struct Point {
   x: i32,
   y: i32,
}
impl Point {
   //static method that creates objects of the Point structure
   fn getInstance(x: i32, y: i32) -> Point {
      Point { x: x, y: y }
   }
   //display values of the structure's field
   fn display(&self){
      println!("x ={} y={}",self.x,self.y );
   }
}
fn main(){
   // Invoke the static method
   let p1 = Point::getInstance(10,20);
   p1.display();
}

Production

x =10 y=20