Conditional (computer 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)
Theif–then
construct is common across many programming languages. Although the syntax varies from language to language, the basic structure looks like this:If Then
Else
End If
For example:
If stock=0 Then
message= order new stock
Else
message= there is stock
End If
In the example code above, the part represented by ' constitutes a conditional expression, having intrinsic value but having no intrinsic meaning. In contrast, the combination of this expression, the
If
and Then
surrounding it, and the consequent that follows afterward constitute a conditional statement, having intrinsic meaning but no intrinsic value.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, 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 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 else s2
or
if a then'''
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 usingelse 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.if condition then
--statements
elseif condition then
-- more statements
elseif condition then
-- more statements;
...
else
-- other statements;
end if;
For example, for a shop offering as much a 30% discount for an item:
if discount<11% then
elseif discount<21% then
elseif discount<31% then
end if;
The statements of
elseif
, 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 elseif
instead of else
followed by if
. PHP uses the elseif
keyword both for its curly brackets or colon syntaxes. Perl provides the keyword elsif
to avoid the large number of braces that would be required by multiple if
and else
statements. 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. Some implementations of BASIC, such as Visual Basic, use ElseIf
too. Similarly, the earlier UNIX shells use elif too, but giving the choice of delimiting with spaces, line breaks, or both.However, in many languages more directly descended from Algol, such as Algol68, Simula, Pascal, BCPL and C, this special syntax for the
else if
construct is not present, nor is it present in the many syntactical derivatives of C, such as Java, ECMAScript, and so on. This works because in these languages, any single statement can follow a conditional without being enclosed in a block.This design choice has a slight "cost" in that code
else if
branch is, effectively, adding an extra nesting level, complicating the job for some compilers, which has to analyse and implement arbitrarily long else if
chains recursively.If all terms in the sequence of conditionals are testing the value of a single expression, then an alternative is the switch statement, also called case-statement or select-statement. Conversely, in languages that do not have a switch statement, these can be produced by a sequence of
else if
statements.If–then–else expressions
Many languages support if expressions, which are similar to if statements, but return a value as a result. Thus, they are true expressions, not statements.Algol family
and some other members of the ALGOL family allowif–then–else
as an expression:
myvariable := if x > 20 then 1 else 2
Lisp dialects
In dialects of Lisp– Scheme, Racket and Common Lisp– the first of which was inspired to a great extent by ALGOL:;; Scheme
; Assigns 'myvariable' to 1 or 2, depending on the value of 'x'
;; Common Lisp
)
) ; Assigns 'myvariable' to 2
Haskell
In Haskell 98, there is only an if expression, no if statement, and theelse
part is compulsory, as every expression must have some value. 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. It can be written like this:
if' :: Bool -> a -> a -> a
if' True x _ = x
if' False _ y = y
C-like languages
and C-like languages have a special ternary operator for conditional expressions with a function that may be described by a template like this:condition ? evaluated-when-true : evaluated-when-false
This means that it can be inlined into expressions, unlike if-statements, in C-like languages:
my_variable = x > 10 ? "foo" : "bar"; // In C-like languages
which can be compared to the Algol-family if–then–else expressions .
To accomplish the same using an if-statement, this would take more than one line of code, and require mentioning "my_variable" twice:
if
my_variable = "foo";
else
my_variable = "bar";
Some argue that the explicit if/then statement is easier to read and that it may compile to more efficient code than the ternary operator, while others argue that concise expressions are easier to read than statements spread over several lines containing repetition.
In [Small Basic]
x = TextWindow.ReadNumber
If Then
TextWindow.WriteLine
Else
TextWindow.WriteLine
EndIf
First, when the user runs the program, a cursor appears waiting for the reader to type a number. If that number is greater than 10, the text "My variable is named 'foo'." is displayed on the screen. If the number is smaller than 10, then the message "My variable is named 'bar'." is printed on the screen.
In Visual Basic
In Visual Basic and some other languages, a function calledIIf
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.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 This was the earliest conditional statement in Fortran:IF label1, label2, label3
Where e is any numeric expression ; this is equivalent to
IF GOTO label1
IF GOTO label2
GOTO label3
Because this arithmetic IF is equivalent to multiple
GOTO
statements that could jump to anywhere, 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 the test-and-branch op-code had three addresses for those three states. Other computers would have "flag" registers such as positive, zero, negative, even, overflow, carry, associated with the last arithmetic operations and would use instructions such as 'Branch if accumulator negative' then 'Branch if accumulator zero' or similar. Note that the expression is evaluated once only, and in cases such as integer arithmetic where overflow may occur, the overflow or carry flags would be considered also.
Object-oriented implementation in Smalltalk
In contrast to other languages, in Smalltalk the conditional statement is not a language construct but defined in the classBoolean
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.var = condition
ifTrue:
ifFalse:
JavaScript
Two examples in JavaScript:if else
var x = Math.random;
if else if else
Lambda Calculus
In Lambda Calculus, the concept of an if-then-else conditional can be expressed using the expressions:true = λx. λy. x
false = λx. λy. y
ifThenElse =
- true takes up to two arguments and once both are provided, it returns the first argument given.
- false takes up to two arguments and once both are provided, it returns the second argument given.
- ifThenElse takes up to three arguments and once all are provided, it passes both second and third argument to the first argument. We expect ifThenElse to only take true or false as an argument, both of which project the given two arguments to their preferred single argument, which is then returned.
In a system where numbers can be used without definition, the above can be expressed as a single closure below:
)
Here, true, false, and ifThenElse are bound to their respective definitions which are passed to their scope at the end of their block.
A working JavaScript analogy to this is:
var computationResult =
)));
The code above with multivariable functions looks like this:
var computationResult = =>
_ifThenElse
) => x, => y, => c);
another version of the earlier example without a system where numbers are assumed is below.
First example shows the first branch being taken, while second example shows the second branch being taken.
)
))
)
))
Smalltalk uses a similar idea for its true and false representations, with True and False being singleton objects that respond to messages ifTrue/ifFalse differently.
Haskell used to use this exact model for its Boolean type, but at the time of writing, most Haskell programs use syntactic sugar "if a then b else c" construct which unlike ifThenElse does not compose unless
either wrapped in another function or re-implemented as shown in The Haskell section of this page.
Case and switch statements
s 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 ' 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 | case $someChar in a) actionOnA; ;; x) actionOnX; ;; ) actionOnYandZ; ;; *) actionOnNoMatch ;; esac |
Pattern matching
may be seen as an 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
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 = f h : map f t
This code defines a function map, which applies the first argument to each of the elements of the second argument, 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 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.
Hash-based conditionals
In programming languages that have associative arrays or comparable data structures, such as Python, Perl, PHP or Objective-C, it is idiomatic to use them to implement conditional assignment.pet = raw_input
known_pets =
my_name = known_pets
In languages that have anonymous functions or that allow a programmer to assign a named function to a variable reference, conditional flow can be implemented by using a hash as a dispatch table.
Predication
An alternative to conditional branch instructions is predication. Predication is an architectural feature that enables instructions to be conditionally executed instead of modifying the control flow.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.- 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.
- 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. - In Haskell and F#, a separate constant choice construct is unneeded, because the same task can be done with pattern matching.
- In a Ruby
case
construct, regular expression matching is among the conditional flow-control alternatives available. For an example, see Stack Overflow question. - SQL has two similar constructs that fulfill both roles, both introduced in SQL-92. A "searched
CASE
" expressionCASE WHEN cond1 THEN expr1 WHEN cond2 THEN expr2 ELSE exprDflt END
works likeif... else if... else
, whereas a "simpleCASE
" expression:CASE expr WHEN val1 THEN expr1 ELSE exprDflt END
works like a switch statement. For details and examples see Case. - Arithmetic
if
is obsolescent in Fortran 90.