Each function or method can only ever return a zunächstmal information. This is expressed by the return value or return parameters. What do you do but if you want to return in a way more information that maybe will even be optional? One possibility is of course a complex data type to define and designate these as the return type of the method. For convenience, but rather not make the man. 
 
 a most pragmatic approach is to provide the additional return values each   out to define parameters. The  out  parameters are generally primitive data types such as string   or  int . 
 
 In. NET Framework, there are some methods which have a  out  parameters. A class is often used as the  Dictionary . 
 
 Here's an example: 
 
    var dict = new   
   Dictionary \u0026lt;string  ,   int> (); 
  
  dict.Add ( "A" , 1); 
  
  dict.Add ( "B"  , 2); 
  
 
 
 We are now trying to pull values from the dictionary. Since it can not be guaranteed that the value sought is in the dictionary, we use the method  TryGetValue . Since this is now a  out  parameters defined, we need before we can call this method a variable with the corresponding parameter type   out and define the method with the return value of variable aufrufen.Der  TryGetValue  is a  bool  so that can be seen, whether the value in the Dictionary is available. Only if the value exists, also has the variable value. But be careful! Since  int  is a value type, he always has a default value, which is 0 For safety, one should therefore  out  variables to assign a value other than the default value at  int  example: -1 instead o.  
  
 
 
    int value = -1; 
  
    var success = dict.TryGetValue ( "A" , value); 
  
    if (success) {
  
  
  
  
   Console WriteLine (value). ; 
  
 }   
  
 extent is likely to be clear and certainly have been made many times. For me, the above method, as  TryParse  a legitimate reason to use   out parameters. All other reasons are of secondary importance since convenience is a priority. They want to halt any complex data types to create only one return parameter. 
 
 But there is another way: # F! 
 
 F # to the rescue 
 
  Because F # is a normal. NET is language, of course you can also call the classes of the framework. For example, the methods  out  define parameters such as as the Dictionary. How does F # with it? 
 
 In F # we can normally produce a dictionary. 
 
   open System.Collections.Generic  
  
    let dict = new Dictionary \u0026lt;string,int> () 
  
 Now, we add values to the Dictionary 
 
  dict.Add (  "A" , 1) 
  
   dict.Add ( "B" , 2)   
   
 Finally, we want to read the values again. 
 
   let  result = dict.TryGetValue ( "A" ) 
  
 Now what type of result is now? And why do you not pass a   out parameters? 
 
 F # Interactive is the answer. 
 
  val result: bool * int = (true, 1)   
  
 Result is of type bool * int    
  what is means in F # that this is a tuple. . NET 4.0 can describe this as   Tuple \u0026lt;bool,int>  
 . 
 
 Now we can use this tuple to the functions fst   and disassemble  snd . 
 
    let success = fst result 
  
  val success: bool = true 
  
 
 
   let  value = snd result 
  
  val value: int = 1 
  
 F # F # would not be if it could not even express simple. One can namely the tuple directly into its component parts.  
  
    let (success, value) = dict.TryGetValue ( "A" )   
  
  val value: int = 1 
  
  val success: bool = true 
  
     let (success, value) = dict.TryGetValue ( "C" )   
   
  val value: int = 0 
  
  val success: bool = false 
  
 Conclusion 
 
  to me that this is a good example of how expressive is F #. In the Vergangeneheit many errors in the programming language design have been made. Above all, C + +, but unfortunately, even with C #. Tuples are a Brilliant means to avoid  out  parameters. Since tuple. NET 4.0 is a "first class" data type, there is no reason to do so in C # to a hollowing out as an alternative to   parameters. Ultimately, it makes more fun but with F #! 
 
Over and out !
 
0 comments:
Post a Comment