Scala for JVM
Реализация языка программирования Scala- Scala-программы во многом похожи на Java-программы, и могут свободно взаимодействовать с Java-кодом.
- Scala включает единообразную объектную модель — в том смысле, что любое значение является объектом, а любая операция — вызовом метода.
- Scala — это также функциональный язык в том смысле, что функции — это полноправные значения.
- В Scala включены мощные и единообразные концепции абстракций как для типов, так и для значений.
- Она содержит гибкие симметричные конструкции примесей для композиции классов и trait-ов.
- Она позволяет производить декомпозицию объектов путем сравнения с образцом.
- Образцы и выражения были обобщены для поддержки естественной обработки XML-документов.
- В целом, эти конструкции позволяют легко выражать самостоятельные компоненты, использующие библиотеки Scala, не пользуясь специальными языковыми конструкциями.
- Scala допускает внешние расширения компонентов с использованием видов (views)
Примеры:
Hello, World!:
Пример для версий Scala 2.5.1-final, Scala 2.7.7-finalobject HelloWorld {
def main(args: Array[String]) {
println("Hello, World!")
}
}
Факториал:
Пример для версий Scala 2.5.1-final, Scala 2.7.7-finalИспользуется рекурсивное определение факториала.
object Factorial {
def factorial(n: Int): Long =
if (n == 0) 1
else n * factorial(n - 1)
def main(args: Array[String]) {
for {i <- List.range(0, 17)}
yield { println(i + "! = " + factorial(i)) }
}
}
Числа Фибоначчи:
Пример для версий Scala 2.7.7-finalИспользуется рекурсивное определение чисел Фибоначчи.
object Fibonacci {
def fibonacci(n: Int): Int =
if (n < 3) 1
else fibonacci(n - 1) + fibonacci(n - 2)
def main(args: Array[String]) {
for {i <- List.range(1, 17)}
yield { print(fibonacci(i) + ", ") }
println("...")
}
}
Факториал:
Пример для версий Scala 2.7.7-finalИспользуется итеративное определение факториала.
object Factorial {
def main(args: Array[String]) {
var f = BigInt(1)
format("0! = %s\n", f)
for {i <- 1 to 16} {
f *= i;
format("%s! = %s\n", i, f)
}
}
}
Числа Фибоначчи:
Пример для версий Scala 2.7.7-finalЭтот пример демонстрирует возможности использования ленивых вычислений и бесконечных списков в Scala. Бесконечный список чисел Фибоначчи fibs определяется при помощи фунций .zip и .tail по аналогии с примером на Haskell. Пример предназначен для интерактивной интерпретации.
lazy val fib: Stream[Int] = Stream.cons(1, Stream.cons(1, fib.zip(fib.tail).map(p => p._1 + p._2)))
fib.take(16).print
Комментарии
]]>blog comments powered by Disqus
]]>