Kotlin Keywords and Identifiers

Kotlin Keywords and Identifiers

Kotlin: Keywords and Identifiers Guide

Keywords in any programming language are predefined, reserved words with specific meanings for the compiler whereas Identifiers are unique names created by programmers to represent variables, functions, classes, or other entities. In Kotlin, understanding these keywords is essential for writing clean and effective code.

1. What are Keywords in Kotlin?

Keywords are tokens that are reserved and have a special meaning in a given programming language that cannot be used as identifiers (like variable names, method names, or class names) in your code. Using a keyword as an identifier will cause compilation errors. Kotlin has a set of keywords that serve different purposes within the language.

For example, consider the following code snippet:

Here, String is a keyword that indicates the variable name is of string type. Attempting to use String as a variable name would lead to a compilation error.

2. Types of Keywords in Kotlin

There are basically four types of keywords in Kotlin:

  1. Hard keywords

  2. Soft keywords

  3. Modifier keyword

  4. Special identifiers

  5. Operators and special symbols (NOT A KEYWORD)

1. Hard Keywords

  • Hard keywords are strictly reserved and cannot be used as identifiers (such as variable names, function names, or class names) under any circumstances.

  • They have predefined meanings in the language.

Here are the 24 hard keywords in Kotlin:

KeywordDescription
asUsed for type casts.
as?Used for safe type casts.
breakTerminates the execution of a loop.
classDeclares a class.
continueProceeds to the next step of the nearest enclosing loop.
doBegins a do/while loop (a loop with a postcondition).
elseDefines the branch of an if expression that is executed when the condition is false.
falseSpecifies the ‘false’ value of the Boolean type.
forBegins a for loop.
funDeclares a function.
ifBegins an if expression.
inSpecifies the object being iterated in a for loop.
interfaceDeclares an interface.
isChecks that a value has a certain type.
nullRepresents an object reference that doesn’t point to any object.
objectDeclares a class and its instance at the same time.
packageSpecifies the package for the current file.
returnReturns from the nearest enclosing function or anonymous function.
superRefers to the superclass implementation of a method or property.
thisRefers to the current receiver.
throwThrows an exception.
trueSpecifies the ‘true’ value of the Boolean type.
tryBegins an exception-handling block.
typealiasDeclares a type alias.
valDeclares a read-only property or local variable.
varDeclares a mutable property or local variable.
whenBegins a when expression (executes one of the given branches).
whileBegins a while loop (a loop with a precondition).

2. Soft Keywords

  • Soft keywords act as keywords in specific contexts but can be used as identifiers in other situations. These tokens have dual roles.

  • These tokens act as keywords in specific contexts but can be used as identifiers in other contexts.

Here are 17 soft keywords in Kotlin:

KeywordDescription
byDelegates the implementation of an interface to another object. Also used for property delegation.
catchBegins a block that handles a specific exception type.
constructorDeclares a primary or secondary constructor.
delegateUsed as an annotation use-site target.
dynamicReferences a dynamic type in Kotlin/JS code.
fieldUsed as an annotation use-site target.
fileUsed as an annotation use-site target.
finallyBegins a block that is always executed when a try block exits.
getDeclares the getter of a property. Also used as an annotation use-site target.
importImports a declaration from another package into the current file.
initBegins an initializer block.
paramUsed as an annotation use-site target.
propertyUsed as an annotation use-site target.
receiverUsed as an annotation use-site target.
setDeclares the setter of a property. Also used as an annotation use-site target.
setparamUsed as an annotation use-site target.
valueWith the class keyword, declares an inline class.
whereSpecifies the constraints for a generic type parameter.

3. Modifier Keywords

  • Modifier keywords affect the visibility, behavior, or properties of declarations. They can be used as identifiers in other contexts.

  • Modifier keywords appear in modifier lists of declarations. While they serve as keywords in those contexts, they can also be used as regular identifiers elsewhere.

Here’s the 29 modifier keywords in Kotlin:

KeywordDescription
abstractMarks a class or member as abstract.
actualDenotes a platform-specific implementation in multiplatform projects.
annotationDeclares an annotation class.
companionDeclares a companion object.
constMarks a property as a compile-time constant.
crossinlineForbids non-local returns in a lambda passed to an inline function.
dataInstructs the compiler to generate canonical members for a class.
enumDeclares an enumeration.
expectMarks a declaration as platform-specific, expecting an implementation in platform modules.
externalMarks a declaration as implemented outside of Kotlin (accessible through JNI or in JavaScript).
finalForbids overriding a member.
infixAllows calling a function using infix notation.
inlineTells the compiler to inline a function and the lambdas passed to it at the call site.
innerAllows referring to an outer class instance from a nested class.
internalMarks a declaration as visible in the current module.
lateinitAllows initializing a non-nullable property outside of a constructor.
noinlineTurns off inlining of a lambda passed to an inline function.
openAllows subclassing a class or overriding a member.
operatorMarks a function as overloading an operator or implementing a convention.
outMarks a type parameter as covariant.
overrideMarks a member as an override of a superclass member.
privateMarks a declaration as visible in the current class or file.
protectedMarks a declaration as visible in the current class and its subclasses.
publicMarks a declaration as visible anywhere.
reifiedMarks a type parameter of an inline function as accessible at runtime.
sealedDeclares a sealed class (a class with restricted subclassing).
suspendMarks a function or lambda as suspending (usable as a coroutine).
tailrecMarks a function as tail-recursive (allowing the compiler to replace recursion with iteration).
varargAllows passing a variable number of arguments for a parameter.

4. Special Identifiers

  • Kotlin defines two special identifiers in specific contexts. These identifiers can also be used as regular identifiers elsewhere.

Here are the special identifiers:

KeywordDescription
fieldUsed inside a property accessor to refer to the backing field of the property.
itUsed inside a lambda to refer to its parameter implicitly.

5. Operators and special symbols

  • Keywords are tokens that are reserved and have a special meaning in a given programming language. Operators are keywords that can take one or more arguments. They are usually associated with the standard mathematical operations.

  • Operators like new in Java are generally considered as "Alphanumeric operator symbols" rather than keywords. Other examples are sizeof delete throw instanceof.

KeywordDescription
+, -, *, /, %Mathematical operators for addition, subtraction, multiplication, division, and modulo.
* (passing to vararg)Used to pass an array to a vararg parameter.
\=Assignment operator.
?:Elvis operator – takes the right-hand value if the left-hand value is null.
+=, -=, *=, /=, %=Augmented assignment operators.
++, –Increment and decrement operators.
&&,
\==, !=Equality operators (translated to calls of equals() for non-primitive types).
\===, !==Referential equality operators.
<, >, <=, >=Comparison operators (translated to calls of compareTo() for non-primitive types).
[, ]Indexed access operator (translated to calls of get and set).
!!Asserts that an expression is non-nullable.
?.Performs a safe call (calls a method or accesses a property if the receiver is non-nullable).
::Creates a member reference or a class reference.
…, …<Create ranges.
:Separates a name from a type in a declaration.
?Marks a type as nullable.
->Separates the parameters and body of a lambda expression.
@Introduces an annotation or references a loop label.
$References a variable or expression in a string template.
_Substitutes an unused parameter in a lambda expression or destructuring declaration.

Conclusion

Keywords are reserved words with predefined meanings that cannot be used as identifiers, while identifiers are unique names created by programmers to represent various entities in the code. There are 72 keywords in Kotlin.

  1. Keywords:

    • Keywords are reserved words with predefined meanings in a programming language.

    • They serve specific purposes and cannot be used as variable names or other identifiers.

    • Examples of keywords include if, for, and class.

    • Keywords always start with lowercase.

  2. Identifiers:

    • Identifiers are unique names created by programmers to represent variables, functions, classes, or other entities.

    • It starts with a letter or an underscore (_). It can include letters, numbers, and underscores.

    • It can’t be a reserved keyword, true, false, or null**.** Whitespace is not allowed within an identifier.

    • Symbols like @ or # cannot be part of an identifier.

    • Identifiers are case-sensitive.

The Kotlin tutorial page lists down all the important topics you can go through to get a deeper understanding of the language basics and advanced concepts.