Rost - Funktionen
Funktionen sind die Bausteine für lesbaren, wartbaren und wiederverwendbaren Code. Eine Funktion ist eine Reihe von Anweisungen zum Ausführen einer bestimmten Aufgabe. Funktionen organisieren das Programm in logischen Codeblöcken. Einmal definiert, können Funktionen aufgerufen werden, um auf Code zuzugreifen. Dies macht den Code wiederverwendbar. Darüber hinaus erleichtern Funktionen das Lesen und Verwalten des Programmcodes.
Eine Funktionsdeklaration informiert den Compiler über den Namen, den Rückgabetyp und die Parameter einer Funktion. Eine Funktionsdefinition liefert den tatsächlichen Hauptteil der Funktion.
Sr.Nr. | Bedienungsanleitung |
---|---|
1 | Defining a function Die TA-Funktionsdefinition gibt an, was und wie eine bestimmte Aufgabe ausgeführt werden soll. |
2 | Calling or invoking a Function Eine Funktion muss aufgerufen werden, um sie auszuführen. |
3 | Returning Functions Funktionen können zusammen mit der Steuerung auch einen Wert an den Anrufer zurückgeben. |
4 | Parameterized Function Parameter sind ein Mechanismus zum Übergeben von Werten an Funktionen. |
Funktion definieren
Eine Funktionsdefinition gibt an, was und wie eine bestimmte Aufgabe ausgeführt werden soll. Vor der Verwendung einer Funktion muss diese definiert werden. Der Funktionskörper enthält Code, der von der Funktion ausgeführt werden soll. Die Regeln für die Benennung einer Funktion ähneln denen einer Variablen. Funktionen werden mit dem definiertfnStichwort. Die Syntax zum Definieren einer Standardfunktion ist unten angegeben
Syntax
fn function_name(param1,param2..paramN) {
// function body
}
Eine Funktionsdeklaration kann optional Parameter / Argumente enthalten. Parameter werden verwendet, um Werte an Funktionen zu übergeben.
Beispiel - Einfache Funktionsdefinition
//Defining a function
fn fn_hello(){
println!("hello from function fn_hello ");
}
Aufrufen einer Funktion
Eine Funktion muss aufgerufen werden, um sie auszuführen. Dieser Vorgang wird als bezeichnetfunction invocation. Werte für Parameter sollten übergeben werden, wenn eine Funktion aufgerufen wird. Die Funktion, die eine andere Funktion aufruft, heißtcaller function.
Syntax
function_name(val1,val2,valN)
Beispiel: Aufrufen einer Funktion
fn main(){
//calling a function
fn_hello();
}
Hier ist main () die Aufruferfunktion.
Illustration
Das folgende Beispiel definiert eine Funktion fn_hello(). Die Funktion druckt eine Nachricht an die Konsole. Dasmain()Funktion ruft die Funktion fn_hello () auf .
fn main(){
//calling a function
fn_hello();
}
//Defining a function
fn fn_hello(){
println!("hello from function fn_hello ");
}
Ausgabe
hello from function fn_hello
Wert von einer Funktion zurückgeben
Funktionen können auch einen Wert zusammen mit der Steuerung an den Anrufer zurückgeben. Solche Funktionen werden als Rückgabefunktionen bezeichnet.
Syntax
Jede der folgenden Syntax kann verwendet werden, um eine Funktion mit dem Rückgabetyp zu definieren.
Mit return-Anweisung
// Syntax1
fn function_name() -> return_type {
//statements
return value;
}
Kurzsyntax ohne return-Anweisung
//Syntax2
fn function_name() -> return_type {
value //no semicolon means this value is returned
}
Illustration
fn main(){
println!("pi value is {}",get_pi());
}
fn get_pi()->f64 {
22.0/7.0
}
Ausgabe
pi value is 3.142857142857143
Funktion mit Parametern
Parameter sind ein Mechanismus zum Übergeben von Werten an Funktionen. Parameter bilden einen Teil der Funktionssignatur. Die Parameterwerte werden beim Aufruf an die Funktion übergeben. Sofern nicht ausdrücklich angegeben, muss die Anzahl der an eine Funktion übergebenen Werte mit der Anzahl der definierten Parameter übereinstimmen.
Parameter können mit einer der folgenden Techniken an eine Funktion übergeben werden:
Wert übergeben
Wenn eine Methode aufgerufen wird, wird für jeden Wertparameter ein neuer Speicherort erstellt. Die Werte der Istparameter werden in diese kopiert. Daher haben die am Parameter in der aufgerufenen Methode vorgenommenen Änderungen keine Auswirkung auf das Argument.
Im folgenden Beispiel wird eine Variable no deklariert, die anfänglich 5 ist. Die Variable wird als Parameter (nach Wert) an die übergeben mutate_no_to_zero()Funktion, die den Wert auf Null ändert. Nach dem Funktionsaufruf, wenn die Steuerung zur Hauptmethode zurückkehrt, ist der Wert derselbe.
fn main(){
let no:i32 = 5;
mutate_no_to_zero(no);
println!("The value of no is:{}",no);
}
fn mutate_no_to_zero(mut param_no: i32) {
param_no = param_no*0;
println!("param_no value is :{}",param_no);
}
Ausgabe
param_no value is :0
The value of no is:5
Referenz übergeben
Wenn Sie Parameter im Gegensatz zu Wertparametern als Referenz übergeben, wird für diese Parameter kein neuer Speicherort erstellt. Die Referenzparameter stellen denselben Speicherort dar wie die tatsächlichen Parameter, die der Methode zur Verfügung gestellt werden. Parameterwerte können als Referenz übergeben werden, indem dem Variablennamen ein vorangestellt wird& .
Im folgenden Beispiel haben wir eine Variable no , die anfänglich 5 ist. Ein Verweis auf die Variable no wird an die übergebenmutate_no_to_zero()Funktion. Die Funktion arbeitet mit der ursprünglichen Variablen. Wenn die Steuerung nach dem Funktionsaufruf zur Hauptmethode zurückkehrt, ist der Wert der ursprünglichen Variablen Null.
fn main() {
let mut no:i32 = 5;
mutate_no_to_zero(&mut no);
println!("The value of no is:{}",no);
}
fn mutate_no_to_zero(param_no:&mut i32){
*param_no = 0; //de reference
}
Der Operator * wird verwendet, um auf den Wert zuzugreifen, der an dem Speicherort der Variablen gespeichert ist param_noverweist auf. Dies wird auch als Dereferenzierung bezeichnet.
Die Ausgabe wird -
The value of no is 0.
String an eine Funktion übergeben
Die Funktion main () übergibt ein Zeichenfolgenobjekt an die Funktion display () .
fn main(){
let name:String = String::from("TutorialsPoint");
display(name);
//cannot access name after display
}
fn display(param_name:String){
println!("param_name value is :{}",param_name);
}
Ausgabe
param_name value is :TutorialsPoint