App

scala.App
trait App extends DelayedInit

The App trait can be used to quickly turn objects into executable programs. Here is an example:

object Main extends App {
  Console.println("Hello World: " + (args mkString ", "))
}

No explicit main method is needed. Instead, the whole class body becomes the “main method”.

args returns the current command line arguments as an array.

==Caveats==

'''''It should be noted that this trait is implemented using the DelayedInit functionality, which means that fields of the object will not have been initialized before the main method has been executed.'''''

Future versions of this trait will no longer extend DelayedInit.

Attributes

Authors:

Martin Odersky

Since

2.1

Deprecated
[Since version 3.8.0] Support for trait App is deprecated in Scala 3. Please refer to https://docs.scala-lang.org/scala3/book/methods-main-methods.html.
Graph
Supertypes
trait DelayedInit
class Object
trait Matchable
class Any

Members list

Value members

Concrete methods

final protected def args: Array[String]

The command line arguments passed to the application's main method.

The command line arguments passed to the application's main method.

Attributes

final def main(args: Array[String]): Unit

The main method. This stores all arguments so that they can be retrieved with args and then executes all initialization code segments in the order in which they were passed to delayedInit.

The main method. This stores all arguments so that they can be retrieved with args and then executes all initialization code segments in the order in which they were passed to delayedInit.

Value parameters

args

the arguments passed to the main method

Attributes

Deprecated methods

override def delayedInit(body: => Unit): Unit

The init hook. This saves all initialization code for execution within main. This method is normally never called directly from user code. Instead it is called as compiler-generated code for those classes and objects (but not traits) that inherit from the DelayedInit trait and that do not themselves define a delayedInit method.

The init hook. This saves all initialization code for execution within main. This method is normally never called directly from user code. Instead it is called as compiler-generated code for those classes and objects (but not traits) that inherit from the DelayedInit trait and that do not themselves define a delayedInit method.

Value parameters

body

the initialization code to be stored for later execution

Attributes

Deprecated
[Since version 2.11.0] the delayedInit mechanism will disappear
Definition Classes

Concrete fields

final val executionStart: Long

The time when the execution of this program started, in milliseconds since 1 January 1970 UTC.

The time when the execution of this program started, in milliseconds since 1 January 1970 UTC.

Attributes