Bu makalede, farklı türde girdiler alan ve örneklerle çıktı döndüren farklı kullanıcı tanımlı işlevler hakkında bilgi edineceksiniz.
Bir önceki makalede Swift Fonksiyonları, fonksiyonları öğrendik. Şimdi, Swift'de bir işlev oluşturabileceğimiz farklı yollara ve türlere bakacağız, yani bir işlevdeki girdi ve çıktıyı ele alacağız.
Parametresi ve dönüş değeri olmayan işlev
Bu tür fonksiyonlar herhangi bir girdi ve dönüş değeri almaz.
işlevadı () (// deyimleri) VEYA işlevadı () -> () (// deyimleri) YA DA işlevadı () -> Void (// deyimleri)
Yukarıdaki tüm sözdizimi, parametre almayan ve değer döndürmeyen bir işlev oluşturmak için geçerlidir.
Yukarıdaki sözdizimi func funcname() -> ()
aynı zamanda eşdeğerdir func funcname() -> Void
çünkü Void
yalnızca bir tür takma adıdır ()
. Daha fazla bilgi edinmek için Swift Typealias'ı ziyaret edebilirsiniz.
Örnek 1: Parametre geçirilmedi ve dönüş değeri yok
func greetUser() ( print("Good Morning!") ) greetUser()
Yukarıdaki programı çalıştırdığınızda, çıktı:
Günaydın!
Parametresi olmayan ancak dönüş değeri olan işlev
Bu tür işlevler herhangi bir girdi parametresi almaz, ancak bir değer döndürür. Dönüş türünü eklemek için ok ( ->
) ve dönüş türünü eklemeniz gerekir .
func funcname () -> ReturnType (// ifadeler dönüş değeri)
Örnek 2: Parametre geçirilmedi, ancak dönüş değeri
func greetUser() -> String ( return "Good Morning!" ) let msg = greetUser() print(msg)
Yukarıdaki programı çalıştırdığınızda, çıktı:
Günaydın!
Yukarıdaki programda dönüş Tipi olarak tanımladınız String
. Şimdi, ifade işlevin içindeki ifadeden bir dize döndürmelidir, aksi takdirde bir hata alırsınız.
return
anahtar kelime, programın denetimini işlevin gövdesinden işlev çağrısına aktarır. İşlevden değer döndürmeniz gerekiyorsa, return
anahtar kelimeden sonra değer ekleyin .
return "Good Morning!"
ifade String
, işlevin türünün değerini döndürür . Dönüş türünün ve değerin eşleşmesi gerektiğini unutmayın.
Dönüş değerini bir değişkene veya sabite de atayabilirsiniz. let msg =
dönüş değerini sabit mesaja atar. Deyimin Yani print(msg)
çıkışlar Günaydın! konsolda.
Eğer değeri ihmal etmek istiyorsanız, basitçe kullanabilirsiniz _
olarak let _ =
.
Parametreli ancak dönüş değeri olmayan işlev
Fonksiyona girdi almak için parametreler kullanılır. Parametre, bir parametre adı ve türü ve ardından iki nokta üst üste ( :
) içerir. Bu tür işlevler giriş parametresi alır ancak değer döndürmez.
işlev işlevi adı (parametreAdı: Tür) (// deyimleri)
Örnek 3: Değiştirilen parametreler ancak dönüş değeri yok
func greetUser(msg:String) ( print(msg) ) greetUser(msg: "Good Morning!")
Yukarıdaki programı çalıştırdığınızda, çıktı:
Günaydın!
Yukarıdaki programda, işlev tek bir tip parametresi kabul eder String
. Parametre yalnızca işlevin içinde kullanılabilir. msg, parametrenin adıdır.
İşlevi, parametre adı olarak bir dize değeri ileterek çağırabilirsiniz greetUser(msg: "Good Morning!")
. Msg parametresi adı yalnızca işlevin içinde görülebilir greetUser()
.
Bu nedenle, deyim print(msg)
çıkışı Günaydın! konsolda.
Parametre ve dönüş değeri olan fonksiyon
Bu tür işlevler parametre alır ve ayrıca değer döndürür.
func işlevadı (parametreAdı: Tür) -> DönüşTürü (// deyimleri)
Örnek 4: Geçilen parametreler ve değer döndürür
func greetUser(name:String) -> String ( return "Good Morning! " + name ) let msg = greetUser(name: "Jack") print(msg)
Yukarıdaki programı çalıştırdığınızda, çıktı:
Günaydın! Jack
Yukarıdaki programda, işlev tek bir tür parametresini kabul eder String
ve ayrıca Günaydın! Jack tipi String
.
Birden çok parametre ve birden çok dönüş değeri olan işlev
Bu tür işlevler, virgülle ayrılmış birden çok parametre alır ve aynı zamanda birden çok değer döndürür. Tuples'ı kullanarak Swift'de birden çok değer döndürebilirsiniz. Daha fazlasını öğrenmek için Swift Tuples'a bakın.
işlev işlevadı (parametreAdı: Tür, parametreAdı2: Tür,…) -> (Dönüş Türü, DönüşTürü…) (// ifadeler)
Örnek 5: Birden çok parametre geçildi ve birden çok dönüş değeri
func greetUser(name:String, age:Int) -> (String, Int) ( let msg = "Good Morning!" + name var userage = age if age < 0 ( userage = 0 ) return (msg, userage) ) let msg = greetUser(name: "Jack", age: -2) print(msg.0) print("You have (msg.1) coins left")
Yukarıdaki programı çalıştırdığınızda, çıktı:
Günaydın Jack 0 jetonun kaldı
Yukarıdaki programda, işlev greetUser()
birden çok tür parametresini String
ve Int
. İşlev ayrıca, String
ve Int
.
Her dönüş değeri erişmek için, endeks pozisyonları 0, 1 kullanın … Burada kullandım msg.0 erişim için Good Morning! Jack ve msg.1 erişimine 0 .
Dizin konumlarını kullanmak bazen sezgisel ve okunamaz olabilir. Dönen değerlere isimler vererek bu sorunu zarif bir şekilde çözebiliriz. Yukarıdaki program aşağıdaki şekilde de yeniden yazılabilir.
Example 6: Multiple return values with name
func greetUser(name:String, coins:Int) -> (name:String, coins:Int) ( let msg = "Good Morning!" + name var userCoins = coins if coins < 0 ( userCoins = 0 ) return (msg, userCoins) ) let msg = greetUser(name: "Jack",coins: -2) print(msg.name) print("You have (msg.coins) coins left")
In this program, the return type is of tuple that contains the variable name with the type. The main advantage of this is you can access the result using the variable name as msg.name and msg.coins instead of msg.0 and msg.1.
Function with argument label
When you define a function that accepts inputs, you can define the input name with the help of parameter name. However, there is another type of name which you can give along with the parameter name, known as argument label.
The use of argument labels allow a function to be called in an expressive way, sentence-like manner, while still providing a function body that is readable and clear in intent.
Each function parameter has both an argument label and a parameter name. By default, parameters use their parameter name as their argument label. But, if you explicitly define the argument name, the argument label is used when calling the function.
The syntax of function with argument label is
func funcname(argumentLabel parameterName:Type)-> Return Type ( //statements )
Let's see this in example below.
Example 7: Function without argument label
func sum(a:Int, b:Int) -> Int ( return a + b ) let result = sum(a: 2, b: 3) print("The sum is (result)")
When you run the above program, the output will be:
The sum is 5
In the above example, we have not specified the argument label, so it takes default parameter name a and bas the argument label while calling the function.
You may notice the function call is not expressive/sentence when calling the function. You may think it can be made more expressive as English if you could make the function call as:
let result = sum(of: 2, and: 3)
Now let's change the function as:
Example 8: Function with better function call but not as parameter names
func sum(of:Int, and:Int) -> Int ( return of + and ) let result = sum(of: 2, and: 3) print("The sum is (result)")
Now the method call is expressive. However, now we have to use the parameter name of & and in return of + and
to find the sum of two numbers. Now, this makes the function body unreadable. Use of a and b instead of of&and would make more sense inside the function body.
For this purpose we have to explicitly define argument label as:
Example 9: Function with argument labels
func sum(of a :Int, and b:Int) -> Int ( return a + b ) let result = sum(of: 2, and: 3) print("The sum is (result)")
In the above program, the function accepts two parameter of type Int
. The function call uses the argument label of & and which makes sense while calling the function as sum(of: 2, and: 3)
instead of sum(a: 2, b: 3)
.
Also, the function body uses the parameter name a and b instead of of & and which also makes more sense while applying operations.
You can also omit the argument label by writing a _
before the parameter name.
func sum(_ a :Int, _ b:Int) -> Int ( return a + b ) let result = sum(2, 3) print("The sum is (result)")
Function with default parameter values
You can give default values for any parameter in a function by assigning a value to the parameter after that parameter's type. Giving a default parameter allows you to neglect the parameter while calling the function.
If you do not pass value to the parameter while calling the function, its default value is used. However, if you explicitly pass a value to the parameter while calling, the specified value is used.
func funcname(parameterName:Type = value) -> Return Type ( //statements )
Example 10: Function with default parameter values
func sum(of a :Int = 7, and b:Int = 8) -> Int ( return a + b ) let result1 = sum(of: 2, and: 3) print("The sum is (result1)") let result2 = sum(of: 2) print("The sum is (result2)") let result3 = sum(and: 2) print("The sum is (result3)") let result4 = sum() print("The sum is (result4)")
When you run the above program, the output will be:
The sum is 5 The sum is 10 The sum is 9 The sum is 15
In the above program, the function sum(of a :Int = 7 , and b:Int = 8) -> Int
accepts two parameter of type Int
but also specifies the default value of parameter a = 7
and b = 8.
If you pass value as a parameter in the function call as sum(of: 2, and: 3)
then 2 and 3 is used instead of parameter default value.
But if you don't pass the parameter value as sum()
, then default value 7 and 8 are used as the parameter value.
Function with variadic parameters
A variadic parameter can accept zero or more values of a specific type. You can specify variadic parameter by inserting three period characters (… ) after the parameter's type name.
You usually use a variadic parameter when you need to pass a varying number of input values to the parameter when the function is called. For example, a list of numbers, a list of alphabets, etc.
The syntax of function with variadic parameters is:
func funcname(parameterName:Type… ) -> Return Type ( //statements )
Example 11: Function with variadic parameters
func sum(of numbers:Int… ) ( var result = 0 for num in numbers ( result += num ) print("The sum of numbers is (result)") ) sum(of: 1, 2, 3, 4, 5, 6, 7, 8)
In the above program, the function sum(of numbers:Int… )
accepts a variadic parameter of type Int
. A variadic parameter can accept multiple values separated by comma as sum(of: 1, 2, 3, 4, 5, 6, 7, 8)
.
The values 1, 2, 3, 4, 5, 6, 7, 8 passed as a variadic parameter are made available within the function's body as an array of the Int
type. Therefore, we can apply for-in
loop in the value as for num in numbers
.
When you run the above program, the output will be:
The sum of numbers is 36
Note: Swift built in print()
function also accepts variadic parameter of type Any
.
Any
represents to any data type in Swift e.g. Int
, Float
, Double
,String
etc.
Function with in-out parameters
When you define the function parameter, the function parameters cannot be modified inside the body. So they are constants by default. Let's see this in example:
func process(name:String) ( if name == ""( name = "guest" ) )
The above program results a compile-time error because you cannot change the value of a parameter.
If you want a function to modify a parameter's value, you need to define the parameter as in-out parameter. You write an in-out parameter by placing the inout
keyword right before a parameter's type.
Behind the scenes, an in-out parameter has a value that is passed into the function, is modified by the function, and is passed back out of the function to replace the original value. Therefore the value passed in the function call cannot be a constant. You must declare it as a variable.
The syntax of function with inout parameter is:
func funcname(parameterName:inout Type) -> Return Type ( //statements )
Example 12: Function with in out parameter
func process(name:inout String) ( if name == ""( name = "guest" ) ) var userName = "" process(name: &userName) print(userName)
When you run the above program, the output will be:
guest
In the above program, we have declared a function that accepts inout
parameter name so that the parameter can be changed/altered inside the body of the function.
You must use ampersand (&)
sign directly before a variable's name when you pass argument to an in-out parameter so that it can be modified by the function.