
In
computer science
Computer science is the study of computation, information, and automation. Computer science spans Theoretical computer science, theoretical disciplines (such as algorithms, theory of computation, and information theory) to Applied science, ...
, conditionals (that is, conditional statements, conditional expressions and conditional constructs) are
programming language
A programming language is a system of notation for writing computer programs.
Programming languages are described in terms of their Syntax (programming languages), syntax (form) and semantics (computer science), semantics (meaning), usually def ...
constructs that perform different computations or actions or return different values depending on the value of a
Boolean expression, called a ''condition''.
Conditionals are typically implemented by selectively executing instructions. Although
dynamic dispatch is not usually classified as a conditional construct, it is another way to select between alternatives at
runtime.
Terminology
Conditional
statements are imperative constructs executed for side-effect, while conditional
expressions return values. Many programming languages (such as C) have distinct conditional statements and conditional expressions. Although in pure
functional programming
In computer science, functional programming is a programming paradigm where programs are constructed by Function application, applying and Function composition (computer science), composing Function (computer science), functions. It is a declarat ...
, conditional expressions do not have
side-effects, many languages with conditional expressions (such as Lisp) support conditional side-effects.
If–then(–else)
The
if–then
or
if–then–else
construction is used in many programming languages. Although the syntax varies from language to language, the basic structure (in
pseudocode form) looks like this:
If (Boolean condition) Then
(consequent)
Else
(alternative)
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 ''(Boolean condition)'' constitutes a conditional ''expression'', having intrinsic value (e.g., it may be substituted by either of the values
True
or
False
) 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 (e.g., expressing a coherent logical rule) 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 (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
.
History and development
In early programming languages, especially some dialects of
BASIC
Basic or BASIC may refer to:
Science and technology
* BASIC, a computer programming language
* Basic (chemistry), having the properties of a base
* Basic access authentication, in HTTP
Entertainment
* Basic (film), ''Basic'' (film), a 2003 film
...
in the 1980s
home computer
Home computers were a class of microcomputers that entered the market in 1977 and became common during the 1980s. They were marketed to consumers as affordable and accessible computers that, for the first time, were intended for the use of a s ...
s, an
if–then
statement could only contain
GOTO
statements (equivalent to a
branch instruction). 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
Java is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea (a part of Pacific Ocean) to the north. With a population of 156.9 million people (including Madura) in mid 2024, proje ...
,
JavaScript
JavaScript (), often abbreviated as JS, is a programming language and core technology of the World Wide Web, alongside HTML and CSS. Ninety-nine percent of websites use JavaScript on the client side for webpage behavior.
Web browsers have ...
and
Visual Basic Visual Basic is a name for a family of programming languages from Microsoft. It may refer to:
* Visual Basic (.NET), the current version of Visual Basic launched in 2002 which runs on .NET
* Visual Basic (classic), the original Visual Basic suppo ...
.
The "dangling else" problem
The
else
keyword is made to target a specific
if–then
statement preceding it, but for
nested if–then
statements, classic programming languages such as
ALGOL 60
ALGOL 60 (short for ''Algorithmic Language 1960'') is a member of the ALGOL family of computer programming languages. It followed on from ALGOL 58 which had introduced code blocks and the begin and end pairs for delimiting them, representing a ...
struggled to define which specific statement to target. Without clear boundaries for which statement is which, an
else
keyword could target any preceding
if–then
statement in the nest, as parsed.
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 (commonly via the
end if
statement or
brackets).
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.
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 as a 30% discount for an item:
if discount < 11% then
print (you have to pay $30)
elseif discount<21% then
print (you have to pay $20)
elseif discount<31% then
print (you have to pay $10)
end if;
In the example above, if the discount is 10%, then the first if statement will be evaluated as true and "you have to pay $30" will be printed out. All other statements below that first if statement will be skipped.
The
elseif
statement, in the
Ada language for example, 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
PHP elseif syntax
' both for its curly brackets or colon syntaxes.
Perl and
Ruby provide 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
Basic or BASIC may refer to:
Science and technology
* BASIC, a computer programming language
* Basic (chemistry), having the properties of a base
* Basic access authentication, in HTTP
Entertainment
* Basic (film), ''Basic'' (film), a 2003 film
...
, such as
Visual Basic Visual Basic is a name for a family of programming languages from Microsoft. It may refer to:
* Visual Basic (.NET), the current version of Visual Basic launched in 2002 which runs on .NET
* Visual Basic (classic), the original Visual Basic suppo ...
,
Visual Basic ElseIf syntax
' use
ElseIf
too. Similarly, the earlier UNIX shells (later gathered up to the POSIX shell syntax
') 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
Simula
Simula is the name of two simulation programming languages, Simula I and Simula 67, developed in the 1960s at the Norwegian Computing Center in Oslo, by Ole-Johan Dahl and Kristen Nygaard. Syntactically, it is an approximate superset of AL ...
,
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
Java is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea (a part of Pacific Ocean) to the north. With a population of 156.9 million people (including Madura) in mid 2024, proje ...
,
ECMAScript
ECMAScript (; ES) is a standard for scripting languages, including JavaScript, JScript, and ActionScript. It is best known as a JavaScript standard intended to ensure the interoperability of web pages across different web browsers. It is stan ...
, and so on. This works because in these languages, any ''single'' statement (in this case
if ''cond''
...) can follow a conditional without being enclosed in a block.
This design choice has a slight "cost". Each
else if
branch effectively adds an extra nesting level. This complicates the job for the compiler (or the people who write the compiler), because the compiler must 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 (e.g.,
if x=0
...
else if x=1
...
else if x=2
...), an alternative is the
switch statement
In computer programming languages, a switch statement is a type of selection control mechanism used to allow the value of a variable or expression to change the control flow of program execution via search and map.
Switch statements function ...
, 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 ''conditional 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 may not be permitted in the context of a value). The concept of conditional expressions was first developed by
John McCarthy during his research into symbolic processing and LISP in the late 1950s.
Algol family
ALGOL 60
ALGOL 60 (short for ''Algorithmic Language 1960'') is a member of the ALGOL family of computer programming languages. It followed on from ALGOL 58 which had introduced code blocks and the begin and end pairs for delimiting them, representing a ...
and some other members of the
ALGOL family allow
if–then–else
as an expression. The idea of including conditional expressions was suggested by John McCarthy, though the ALGOL committee decided to use English words rather than McCarthy's mathematical syntax:
myvariable := if x > 20 then 1 else 2
Lisp dialects
Conditional expressions have always been a fundamental part of
Lisp
Lisp (historically LISP, an abbreviation of "list processing") is a family of programming languages with a long history and a distinctive, fully parenthesized Polish notation#Explanation, prefix notation.
Originally specified in the late 1950s, ...
. In pure LISP, the
COND
function is used. In dialects such as
Scheme,
Racket and
Common Lisp:
;; Scheme
(define (myvariable x) (if (> x 12) 1 2)) ; Assigns 'myvariable' to 1 or 2, depending on the value of 'x'
;; Common Lisp
(let ((x 10))
(setq myvariable (if (> x 12) 2 4))) ; Assigns 'myvariable' to 2
Haskell
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.
Haskell 98 Language and Libraries: The Revised Report
' 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:
[If-then-else Proposal on HaskellWiki]
if' :: Bool -> a -> a -> a
if' True x _ = x
if' False _ y = y
C-like languages
C 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'' (in contrast to a ''statement'') (and similar in Ruby and Scala, among others).
To accomplish the same using an if-statement, this would take more than one line of code (under typical layout conventions), and require mentioning "my_variable" twice:
if (x > 10)
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.
Small Basic
x = TextWindow.ReadNumber()
If (x > 10) Then
TextWindow.WriteLine("My variable is named 'foo'.")
Else
TextWindow.WriteLine("My variable is named 'bar'.")
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.
Visual Basic
In
Visual Basic Visual Basic is a name for a family of programming languages from Microsoft. It may refer to:
* Visual Basic (.NET), the current version of Visual Basic launched in 2002 which runs on .NET
* Visual Basic (classic), the original Visual Basic suppo ...
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.
Tcl
In
Tcl if
is not a keyword but a function (in Tcl known as command or
proc
). For example
if
invokes a function named
if
passing 2 arguments: The first one being the condition and the second one being the true branch. Both arguments are passed as strings (in Tcl everything within curly brackets is a string).
In the above example the condition is not evaluated before calling the function. Instead, the implementation of the
if
function receives the condition as a string value and is responsible to evaluate this string as an expression in the callers scope.
Such a behavior is possible by using
uplevel
and
expr
commands:
:Uplevel makes it possible to implement new control constructs as Tcl procedures (for example, uplevel could be used to implement the while construct as a Tcl procedure).
Because
if
is actually a function it also returns a value:
:The return value from the command is the result of the body script that was executed, or an empty string if none of the expressions was non-zero and there was no bodyN.
Rust
In
Rust,
if
is always an expression. It evaluates to the value of whichever branch is executed, or to the unit type
()
if no branch is executed. If a branch does not provide a return value, it evaluates to
()
by default. To ensure the
if
expression's type is known at compile time, each branch must evaluate to a value of the same type. For this reason, an
else
branch is effectively compulsory unless the other branches evaluate to
()
, because an
if
without an
else
can always evaluate to
()
by default.
// Assign my_variable some value, depending on the value of x
let my_variable = if x > 20 else ;
// This variant will not compile because 1 and () have different types
let my_variable = if x > 20 ;
// Values can be omitted when not needed
if x > 20
Guarded conditionals
The
Guarded Command Language (GCL) of
Edsger Dijkstra supports conditional execution as a list of commands consisting of a Boolean-valued
guard (corresponding to a ''condition'') and its corresponding statement. In GCL, exactly one of the statements whose guards is true is evaluated, but which one is arbitrary. In this code
if G0 → S0
□ G1 → S1
...
□ Gn → Sn
fi
the G
''i'''s are the guards and the S
''i'''s are the statements. If none of the guards is true, the program's behavior is undefined.
GCL is intended primarily for reasoning about programs, but similar notations have been implemented in
Concurrent Pascal and
occam.
Arithmetic if
Up to
Fortran 77, the language Fortran has had an arithmetic ''if'' statement which jumps to one of three labels depending on whether its argument ''e'' is This was the earliest conditional statement in Fortran.
Syntax
IF (e) label1, label2, label3
Where e is a numeric expression of type
integer
,
real
, or
double precision
.
Semantics
This is equivalent to this sequence, where ''e'' is evaluated only once.
IF (e .LT. 0) GOTO label1
IF (e .EQ. 0) GOTO label2
IF (e .GT. 0) GOTO label3
Stylistics
Arithmetic ''if'' is an unstructured control statement, and is not used in
structured programming.
In practice it has been observed that most arithmetic
IF
statements reference 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
Smalltalk is a purely object oriented programming language (OOP) that was originally created in the 1970s for educational use, specifically for constructionist learning, but later found use in business. It was created at Xerox PARC by Learni ...
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.
var = condition
ifTrue: 'foo' ifFalse: 'bar'
JavaScript
JavaScript
JavaScript (), often abbreviated as JS, is a programming language and core technology of the World Wide Web, alongside HTML and CSS. Ninety-nine percent of websites use JavaScript on the client side for webpage behavior.
Web browsers have ...
uses if-else statements similar to those in
C languages. A Boolean value is accepted within parentheses between the reserved ''if'' keyword and a left curly bracket.
if (Math.random() < 0.5) else
The above example takes the conditional of
Math.random() < 0.5
which outputs
true
if a random float value between 0 and 1 is greater than 0.5. The statement uses it to randomly choose between outputting
You got Heads!
or
You got Tails!
to the console. Else and else-if statements can also be chained after the curly bracket of the statement preceding it as many times as necessary, as shown below:
var x = Math.random();
if (x < 1/3) else if (x < 2/3) else
Lambda calculus
In
Lambda calculus
In mathematical logic, the lambda calculus (also written as ''λ''-calculus) is a formal system for expressing computability, computation based on function Abstraction (computer science), abstraction and function application, application using var ...
, the concept of an if-then-else conditional can be expressed using the following expressions:
true = λx. λy. x
false = λx. λy. y
ifThenElse = (λc. λx. λy. (c x y))
# true takes up to two arguments and once both are provided (see
currying), it returns the first argument given.
# false takes up to two arguments and once both are provided(see
currying), 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(which is a function that given two arguments, and produces a result). 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.
note: if ifThenElse is passed two functions as the left and right conditionals; it is necessary to also pass an empty tuple () to the result of ifThenElse in order to actually call the chosen function, otherwise ifThenElse will just return the function object without getting called.
In a system where numbers can be used without definition (like Lisp, Traditional paper math, so on), the above can be expressed as a single closure below:
((λtrue. λfalse. λifThenElse.
(ifThenElse true 2 3)
)(λx. λy. x)(λx. λy. y)(λc. λl. λr. c l r))
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(using only functions of single variable for rigor) to this is as follows:
var computationResult = ((_true => _false => _ifThenElse =>
_ifThenElse(_true)(2)(3)
)(x => y => x)(x => y => y)(c => x => y => c(x)(y)));
The code above with multivariable functions looks like this:
var computationResult = ((_true, _false, _ifThenElse) =>
_ifThenElse(_true, 2, 3)
)((x, y) => x, (x, y) => y, (c, x, y) => c(x, y));
Another version of the earlier example without a system where numbers are assumed is below.
The first example shows the first branch being taken, while second example shows the second branch being taken.
((λtrue. λfalse. λifThenElse.
(ifThenElse true (λFirstBranch. FirstBranch) (λSecondBranch. SecondBranch))
)(λx. λy. x)(λx. λy. y)(λc. λl. λr. c l r))
((λtrue. λfalse. λifThenElse.
(ifThenElse false (λFirstBranch. FirstBranch) (λSecondBranch. SecondBranch))
)(λx. λy. x)(λx. λy. y)(λc. λl. λr. c l r))
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
Switch statement
In computer programming languages, a switch statement is a type of selection control mechanism used to allow the value of a variable or expression to change the control flow of program execution via search and map.
Switch statements function ...
s (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.
Pattern matching
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
, "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.
Hash-based conditionals
In programming languages that have
associative array
In computer science, an associative array, key-value store, map, symbol table, or dictionary is an abstract data type that stores a collection of (key, value) pairs, such that each possible key appears at most once in the collection. In math ...
s or comparable data structures, such as
Python,
Perl,
PHP or
Objective-C
Objective-C is a high-level general-purpose, object-oriented programming language that adds Smalltalk-style message passing (messaging) to the C programming language. Originally developed by Brad Cox and Tom Love in the early 1980s, it was ...
, it is idiomatic to use them to implement conditional assignment.
pet = input("Enter the type of pet you want to name: ")
known_pets =
my_name = known_pets et
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.
See also
*
Branch (computer science)
*
Conditional compilation
*
Dynamic dispatch for another way to make execution choices
*
McCarthy Formalism for history and historical references
*
Named condition
*
Relational operator
*
Test (Unix)
*
Yoda conditions
*
Conditional move
References
External links
*
IF NOT (ActionScript 3.0)video
{{DEFAULTSORT:Conditional (programming)
Articles with example pseudocode
Articles with example C code
Articles with example Pascal code
Articles with example Haskell code
Articles with example Python (programming language) code
Articles with example Tcl code