## Buckys C++ Programming Tutorials - 17 - if / else Statement

Channel: thenewboston   |   2011/04/07
1
Buckys C++ Programming Tutorials - 17 - if / else Statement
::2011/04/07::
2
Java Programming Tutorial - 19 - else if Statement
::2009/05/10::
3
Java Programming Tutorial - 10 - If Statement
::2009/05/03::
4
Part 10 - C# Tutorial - If statement in C#
::2012/06/04::
5
Tutorial Java - 3. Sentencia IF - ELSE
::2011/10/29::
6
Tutorial PHP - 7. Condicional If - Else
::2011/11/03::
7
C Programming Tutorial - 5 - If, Else If, Else Statements
::2009/03/01::
8
Python Programming Tutorial - 20 - If Statement
::2009/04/25::
9
C Programming Tutorial - 4 - If Statement Decision
::2009/02/28::
10
Buckys C++ Programming Tutorials - 8 - if Statement
::2011/04/07::
11
Beginner JavaScript Tutorial - 15 - if/else Statement
::2011/03/18::
12
Buckys C++ Programming Tutorials - 16 - if Statement.....again?
::2011/04/07::
13
How To... Use Basic Conditional Formatting with an IF Statement in Excel 2012
::2013/05/16::
14
Branching structures in MATLAB- IF-ELSE
::2011/03/03::
15
Programar em C - Como Utilizar " if else" - Aula 14
::2012/10/24::
16
PHP Tutorial - 4 - If Else Statements
::2008/02/28::
17
Visual Basic Tutorial - 13 - If Statement
::2011/06/04::
18
IF Statement and Nested IF Statement in Excel
::2008/08/19::
19
Microsoft Excel Nested IF Statement Tutorial and Guide - Excel 2003, 2007, 2010
::2012/08/07::
20
C++ Tutorial - 18 - The if else Statement
::2008/12/21::
21
Programar em Java - IF ELSE em Java - Aula 18
::2013/05/26::
22
Beginner JavaScript Tutorial - 14 - if Statement
::2011/03/18::
23
C++ Tutorial - 17 - The if Statement
::2008/12/21::
24
10 The if-else statement
::2012/03/14::
25
C++ Tutorial - 19 - The if else if else Statement
::2008/12/21::
26
Excel If Statement
::2007/04/21::
27
Universidade XTI - JAVA - 023 - if else
::2011/10/15::
28
Unity C# Beginner Tutorial - If, Else, and Else If Statements (Part 04)
::2014/01/09::
29
4- Programming with C++ , IF , IF - Else , IF - Else If statements برمجة
::2013/02/04::
30
Alice Programming Intermediate: Lesson 5 If / Else
::2011/06/13::
31
Using the IF Statement in Excel 2007
::2008/09/20::
32
Java Tutorial 5 - Conditional Statements (If, else if, else)
::2011/01/12::
33
Batch Programming: Lesson 7 (If, If Else and Else Statements)
::2013/10/13::
34
Beginner PHP Tutorial - 19 - if / else if Statement
::2011/04/20::
35
Excel VBA (Macro) If Statement with Multiple Criteria
::2012/05/09::
36
MATLAB Branch (IF/ELSE) Tutorial
::2013/10/13::
37
Java Tutorial 5 - If Else oder auch... Was ist wenn?
::2011/10/02::
38
Excel For Beginners | IF Statement (spreadsheets) HD
::2011/09/14::
39
C Programming Tutorial - 20: Nested if-else Statement
::2013/01/29::
40
C Programming Tutorial 6, If Statement pt.1
::2011/12/09::
41
C Programlama | Ders 6 | Koşul İfadeleri (if,else,else if) (2/2)
::2013/07/03::
42
Javascript Tutorial - 8 - If Statement
::2008/03/13::
43
Microsoft Excel IF Statement Tutorial and Guide - Excel 2003, 2007, 2010
::2012/08/07::
44
Tutorial Javascript 2 - Condicionales: If, Else if y Switch
::2012/03/13::
45
Python 3 Tutorial: 10 - If statement
::2010/05/05::
46
Javascript beginner tutorial 16 - if else statements
::2013/09/29::
47
Programação C - Aula 05 - if else (se senão) - Operadores Lógicos e Relacionais
::2012/04/03::
48
// PASCAL - Estrutura condicional - IF ELSE
::2012/04/09::
49
Javascript Control Flow - If / Else / If Else : Codecademy
::2013/03/27::
50
Tutorial Programación en C++ 1.4 (Uso de condiciones If else)
::2013/02/21::
NEXT >>
RESULTS [51 .. 101]
(Redirected from Conditional (programming))

In computer science, conditional statements, conditional expressions and conditional constructs are features of a programming language which perform different computations or actions depending on whether a programmer-specified boolean condition evaluates to true or false. Apart from the case of branch predication, this is always achieved by selectively altering the control flow based on some condition.

In imperative programming languages, the term "conditional statement" is usually used, whereas in functional programming, the terms "conditional expression" or "conditional construct" are preferred, because these terms all have distinct meanings.

Although dynamic dispatch is not usually classified as a conditional construct, it is another way to select between alternatives at runtime.

## If–then(–else)

The `if–then` construct (sometimes called `if–then–else`) is common across many programming languages. Although the syntax varies quite a bit from language to language, the basic structure (in pseudocode form) looks like this:

``` IF (boolean condition) THEN
(consequent)
ELSE
(alternative)
END IF
```

When an interpreter finds an `If`, it expects a boolean condition – for example, `x > 0`, which means "the variable x contains a number that is greater than zero" – and evaluates that condition. If the condition is `true`, the statements following the `then` are executed. Otherwise, the execution continues in the following branch – either in the `else` block (which is usually optional), or if there is no `else` branch, then after the `end If`.

After either branch has been executed, control returns to the point after the `end If`.

In early programming languages, especially some dialects of BASIC in the 1980s home computers, an `if–then` statement could only contain `GOTO` statements. This led to a hard-to-read style of programming known as spaghetti programming, with programs in this style called spaghetti code. As a result, structured programming, which allows (virtually) arbitrary statements to be put in statement blocks inside an `if` statement, gained in popularity, until it became the norm even in most BASIC programming circles. Such mechanisms and principles were based on the older but more advanced ALGOL family of languages, and ALGOL-like languages such as Pascal and Modula-2 influenced modern BASIC variants for many years. While it is possible while using only `GOTO` statements in `if-then` statements to write programs that are not spaghetti code and are just as well structured and readable as programs written in a structured programming language, structured programming makes this easier and enforces it. Structured `if-then-else` statements like the example above are one of the key elements of structured programming, and they are present in most popular high-level programming languages such as C, Java, JavaScript and Visual Basic .

A subtlety is that the optional else clause found in many languages means that the context-free grammar is ambiguous, since nested conditionals can be parsed in multiple ways. Specifically,

```if a then if b then s else s2
```

can be parsed as

```if a then (if b then s) else s2
```

or

```if a then (if b then s else s2)
```

depending on whether the `else` is associated with the first `if` or second `if`. This is known as the dangling else problem, and is resolved in various ways, depending on the language.

### Else if

By using `else if`, it is possible to combine several conditions. Only the statements following the first condition that is found to be true will be executed. All other statements will be skipped. The statements of

```if condition then
--statements
elseif condition then
-- more statements
elseif condition then
-- more statements;
...
else
-- other statements;
end if;
```

`elsif`, in Ada, is simply syntactic sugar for `else` followed by `if`. In Ada, the difference is that only one `end if` is needed, if one uses `elsif` instead of `else` followed by `if`.

In some other languages, such as C and Java, `else if` literally just means `else` followed by `if`, and syntactic sugar is neither needed nor provided. This works because in these languages, an `else` followed by one statement (in this case the `if`) does not need braces. This is not true in Perl, which provides the keyword `elsif` to avoid the large number of braces that would be required by multiple `if` and `else` statements. Similarly, Python uses the special keyword `elif` because structure is denoted by indentation rather than braces, so a repeated use of `else` and `if` would require increased indentation after every condition.

C and Java implementations, however, do have a disadvantage that each `else if` branch is, effectively, adding an extra nesting level, which will complicate compiler's writer job if arbitrarily long `else if` chains are to be supported.

If all terms in the sequence of conditionals are testing the value of a single expression (e.g., `if x == 0 ... else if x == 1 ... else if x == 2`), then an alternative is the switch statement. Conversely, in languages that do not have a switch statement, such as Python, these can be produced by a sequence of `if ... else if` statements.

### If expressions

Many languages support if expressions, which are similar to if statements, but return a value as a result. Thus, they are true expressions (which evaluate to a value), not statements (which just perform an action).

#### As a ternary operator

In C and C-like languages conditional expressions take the form of a ternary operator called the conditional expression operator, ?:, which follows this template:

```(condition)?(evaluate if condition was true):(evaluate if condition was false)
```

This means that conditions can be inlined into expressions, unlike with if statements, as shown here using C syntax:

```//Invalid in most programming languages. Two of the exceptions are Ruby and Scala
my_variable = if(x > 10) { "foo" } else { "bar" };
//Valid
my_variable = (x > 10)?"foo":"bar";
```

To accomplish the same as the second (correct) line above, using a standard if/else statement, this would take more than one line of code (under standard layout conventions):

```if (x > 10)
my_variable = 'foo';
else
my_variable = 'bar';
```

The explicit if/then statement is easier to read and usually compiles more efficiently than the ternary operator.[1]

ALGOL 60 and some other members of the ALGOL family have the `if` expression which performs the same function.

In ALGOL:

```  myvariable := if x > 10 then 1 else 2
```

In dialects of Lisp -- Scheme, Racket and Common Lisp -- the first of which was inspired to a great extent by ALGOL:

``` ;; Scheme
(define myvariable (if (> x 10) 1 2))   ; Assigns ‘myvariable’ to 1 or 2, depending on the value of ‘x’

;; Common Lisp
(let ((x 5))
(setq myvariable (if (> x 10) 1 2)))  ; Assigns ‘myvariable’ to 2
```

#### As a function

In Visual Basic and some other languages, a function called `IIf` is provided, which can be used as a conditional expression. However, it does not behave like a true conditional expression, because both the true and false branches are always evaluated; it is just that the result of one of them is thrown away, while the result of the other is returned by the IIf function.

In Haskell 98, there is only an if expression, no if statement, and the `else` part is compulsory, as every expression must have some value.[2] Logic that would be expressed with conditionals in other languages is usually expressed with pattern matching in recursive functions.

Because Haskell is lazy, it is possible to write control structures, such as if, as ordinary expressions; the lazy evaluation means that an if function can evaluate only the condition and proper branch (where a strict language would evaluate all three). It can be written like this:[3]

```if' :: Bool -> a -> a -> a
if' True x _ = x
if' False _ y = y
```

### Arithmetic if

Up to Fortran 77, the language Fortran has an "arithmetic if" statement which is halfway between a computed IF and a case statement, based on the trichotomy $x < 0$, $x = 0$, $x > 0$. This was the earliest conditional statement in Fortran:[4]

```IF (e) label1, label2, label3
```

Where e is any numeric expression (not necessarily an integer); this is equivalent to

```IF (e .LT. 0) GOTO label1
IF (e .EQ. 0) GOTO label2
GOTO label3
```

Because this arithmetic IF is equivalent to multiple `GOTO` statements, it is considered to be an unstructured control statement, and should not be used if more structured statements can be used. In practice it has been observed that most arithmetic `IF` statements referenced the following statement with one or two of the labels.

This was the only conditional control statement in the original implementation of Fortran on the IBM 704 computer. On that computer it could be implemented quite efficiently using instructions such as 'Branch if accumulator negative'.

### Object-oriented implementation in Smalltalk

In contrast to other languages, in Smalltalk the conditional statement is not a language construct but defined in the class `Boolean` as an abstract method that takes two parameters, both closures. `Boolean` has two subclasses, `True` and `False`, which both define the method, `True` executing the first closure only, `False` executing the second closure only.[5]

```var = condition
ifTrue: [ 'foo' ]
ifFalse: [ 'bar' ]
```

## Case and switch statements

Switch statements (in some languages, case statements or multiway branches) compare a given value with specified constants and take action according to the first constant to match. There is usually a provision for a default action ('else','otherwise') to be taken if no match succeeds. Switch statements can allow compiler optimizations, such as lookup tables. In dynamic languages, the cases may not be limited to constant expressions, and might extend to pattern matching, as in the shell script example on the right, where the '*)' implements the default case as a regular expression matching any string.

Pascal: C: Shell script:
```case someChar of
'a': actionOnA;
'x': actionOnX;
'y','z':actionOnYandZ;
else actionOnNoMatch;
end;
```
```switch (someChar) {
case 'a': actionOnA; break;
case 'x': actionOnX; break;
case 'y':
case 'z': actionOnYandZ; break;
default: actionOnNoMatch;
}
```
```case \$someChar in
a)    actionOnA; ;;
x)    actionOnX; ;;
[yz]) actionOnYandZ; ;;
*)     actionOnNoMatch  ;;
esac
```

## Pattern matching

Pattern matching may be seen as a more sophisticated alternative to both if-then-else, and case statements. It is available in many programming languages with functional programming features, such as Wolfram Language, ML and many others. Here is a simple example written in the OCaml language:

``` match fruit with
| "apple" -> cook pie
| "coconut" -> cook dango_mochi
| "banana" -> mix;;
```

The power of pattern matching is the ability to concisely match not only actions but also values to patterns of data. Here is an example written in Haskell which illustrates both of these features:

``` map _ []      = []
map f (h : t) = f h : map f t
```

This code defines a function map, which applies the first argument (a function) to each of the elements of the second argument (a list), and returns the resulting list. The two lines are the two definitions of the function for the two kinds of arguments possible in this case – one where the list is empty (just return an empty list) and the other case where the list is not empty.

Pattern matching is not strictly speaking always a choice construct, because it is possible in Haskell to write only one alternative, which is guaranteed to always be matched – in this situation, it is not being used as a choice construct, but simply as a way to bind names to values. However, it is frequently used as a choice construct in the languages in which it is available.

## Branch predication

In assembly language, branch predication is a feature of certain central processing unit (CPU) instruction sets which permits conditional execution of instructions, without having to perform costly conditional jumps.

## Choice system cross reference

This table refers to the most recent language specification of each language. For languages that do not have a specification, the latest officially released implementation is referred to.

Programming language Structured if switch/select/case Arithmetic if Pattern matching[A]
then else else-if
Ada Yes Yes Yes Yes No No
C/C++ Yes Yes Unneeded[B] Fall-through No No
C# Yes Yes Unneeded[B] Yes No No
COBOL Yes Yes Unneeded[B] Yes No No
Eiffel Yes Yes Yes Yes No No
F# Yes Yes Yes Unneeded[C] No Yes
Fortran 90 Yes Yes Yes Yes Yes No
Haskell Yes Needed Unneeded[B] Unneeded[C] No Yes
Java Yes Yes Unneeded[B] Fall-through[6] No No
ECMAScript (JavaScript) Yes Yes Unneeded[B] Fall-through[7] No No
Mathematica Yes Yes Yes Yes No Yes
Oberon Yes Yes Yes Yes No No
Perl Yes Yes Yes Yes No No
PHP Yes Yes Yes Fall-through No No
Pascal, Delphi Yes Yes Unneeded Yes No No
Python Yes Yes Yes No No No
QuickBASIC Yes Yes Yes Yes No No
Ruby Yes Yes Yes Yes No No
Scala Yes Yes Unneeded[B] Fall-through No Yes
SQL Yes[S] Yes Yes Yes[S] No No
Visual Basic, classic Yes Yes Yes Yes No No
Visual Basic .NET Yes Yes Yes Yes No No
Windows PowerShell Yes Yes Yes Fall-through No No
1. ^ This refers to pattern matching as a distinct conditional construct in the programming language – as opposed to mere string pattern matching support, such as regular expression support.
2. 1 2 3 4 5 The often-encountered `else if` in the C family of languages, and in COBOL and Haskell, is not a language feature but a set of nested and independent if then else statements combined with a particular source code layout. However, this also means that a distinct else-if construct is not really needed in these languages.
3. 1 2 In Haskell and F#, a separate constant choice construct is unneeded, because the same task can be done with pattern matching.
4. 1 2 SQL has two similar constructs that fulfill both roles, both introduced in SQL-92. A "searched `CASE`" expression `CASE WHEN cond1 THEN expr1 WHEN cond2 THEN expr2 [...] ELSE exprDflt END` works like `if ... else if ... else`, whereas a "simple `CASE`" expression: `CASE expr WHEN val1 THEN expr1 [...] ELSE exprDflt END` works like a switch statement. For details and examples see Case (SQL).

## References

1. ^ "Efficient C Tips #6 – Don’t use the ternary operator « Stack Overflow". Embeddedgurus.com. 2009-02-18. Retrieved 2012-09-07.
2. ^ Haskell 98 Language and Libraries: The Revised Report
3. ^
4. ^ "American National Standard Programming Language FORTRAN". 1978-04-03. Retrieved 2007-09-09.
5. ^ "VisualWorks: Conditional Processing". 2006-12-16. Retrieved 2007-09-09.
6. ^ Java.sun.com, Java Language Specification, 3rd Edition.
7. ^ Ecma-international.org ECMAScript Language Specification, 5th Edition.

Mashpedia enables any individual or company to promote their own Youtube-hosted videos or Youtube Channels, offering a simple and effective plan to get them in front of our engaged audience.

MASHPEDIA
SOCIAL MEDIA
LANGUAGES
LEGAL