104 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			104 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
---
 | 
						|
title: Switch Case
 | 
						|
---
 | 
						|
 | 
						|
# Switch Case
 | 
						|
 | 
						|
Switch is a selection statement that chooses a switch case section depending on the value matched with the expression/value being evaluated.<sup>1</sup>  If none of the case statements match the value of the switched variable, the default path is chosen. The switch statement is like a set of `if statements`. We exit from the switch by `break`.
 | 
						|
 | 
						|
## Example
 | 
						|
```
 | 
						|
public enum Colors { Red, Blue, Green, Orange }
 | 
						|
 | 
						|
Colors myColor;
 | 
						|
 | 
						|
... myColor is set to one of the enum values ...
 | 
						|
 | 
						|
switch(myColor){
 | 
						|
  case Colors.Red: 
 | 
						|
    Console.WriteLine("How you like them apples?");
 | 
						|
    break;
 | 
						|
  case Colors.Blue: 
 | 
						|
    Console.WriteLine("Ice Ice Baby...");
 | 
						|
    break;
 | 
						|
  case Colors.Green: 
 | 
						|
    Console.WriteLine("Fore!");
 | 
						|
    break;
 | 
						|
  default:
 | 
						|
    Console.WriteLine("I have a hard time when I try to rhyme.");
 | 
						|
}
 | 
						|
```
 | 
						|
 | 
						|
## Output
 | 
						|
```
 | 
						|
If myColor is Colors.Red:
 | 
						|
> How you like them apples?
 | 
						|
 | 
						|
If myColor is Colors.Blue:
 | 
						|
> Ice Ice Baby...
 | 
						|
 | 
						|
If myColor is Colors.Green:
 | 
						|
> Fore!
 | 
						|
 | 
						|
If myColor is Colors.Orange:
 | 
						|
> I have a hard time when I try to rhyme.
 | 
						|
 | 
						|
```
 | 
						|
 | 
						|
## Fallthrough
 | 
						|
 | 
						|
It is also possible to use multiple statements produce the same outcome, by letting the cases 'fallthrough', like so:
 | 
						|
 | 
						|
```
 | 
						|
switch(myColor) {
 | 
						|
  case Colors.Red:
 | 
						|
  case Colors.Blue:
 | 
						|
    //Code
 | 
						|
    break;
 | 
						|
  ...
 | 
						|
 }
 | 
						|
```
 | 
						|
This will execute the same lines of code if myColor is either Red or Blue.
 | 
						|
 | 
						|
## When clause
 | 
						|
 | 
						|
Starting with C# 7.0 you can use `when` clause to specify additional condition that must be satisfied. When clause is optional and is used right after specific case.
 | 
						|
 | 
						|
```csharp
 | 
						|
Dog dog = new Dog
 | 
						|
{
 | 
						|
    Name = "Charlie",
 | 
						|
    Breed = "Affenpinscher",
 | 
						|
    Age = 3
 | 
						|
};
 | 
						|
 | 
						|
switch (dog)
 | 
						|
{
 | 
						|
    case Dog d when d.Breed == "Affenpinscher" && d.Age >= 6:
 | 
						|
        Console.WriteLine($"{dog.Name} is considered a senior dog.");
 | 
						|
        break;
 | 
						|
    case Dog d when d.Breed == "Affenpinscher" && d.Age >= 2:
 | 
						|
        Console.WriteLine($"{dog.Name} is considered an adult dog.");
 | 
						|
        break;
 | 
						|
    case Dog d when d.Breed == "Affenpinscher":
 | 
						|
        Console.WriteLine($"{dog.Name} is considered a puppy.");
 | 
						|
        break;
 | 
						|
    case Dog d when d.Breed == "Chihuahua" && d.Age >= 4:
 | 
						|
        Console.WriteLine($"{dog.Name} is considered a senior dog.");
 | 
						|
        break;
 | 
						|
    case Dog d when d.Breed == "Chihuahua" && d.Age >= 2:
 | 
						|
        Console.WriteLine($"{dog.Name} is considered an adult dog.");
 | 
						|
        break;
 | 
						|
    case Dog d when d.Breed == "Chihuahua":
 | 
						|
        Console.WriteLine($"{dog.Name} is considered a puppy.");
 | 
						|
        break;
 | 
						|
    default:
 | 
						|
        Console.WriteLine($"We have no information according {dog.Breed} breed.");
 | 
						|
        break;
 | 
						|
}
 | 
						|
```
 | 
						|
As you see in the above example after `when` keyword you should specify logical condition (an instruction that returns bool value).
 | 
						|
 | 
						|
### Sources:
 | 
						|
- 1 https://docs.microsoft.com/en-us/dotnet/csharp/language-reference/keywords/switch
 |