MJay
Scala 공부해보기 - Day 1 본문
Scala 공부해보기 - Day 1
왜 스칼라 인가
scalable language
간결하고 우유연하다 정적 타입의 다중 패러다임 JVM 언어이다.
작은 인터프리터 방식의 스크립트부터 대규모의 복잡한 애플리케이션에 이르기까지 폭넓은 규모 확장성을 제공하는 도구이다.
- JVM과 자바스크립트 언어
- 스칼라는 JVM의 성능과 최적화를 활욯했다.
- 정적 타입
- 스칼라는 튼튼한 애플리케이션을 만드는 도구로 정적 타입 지정을 채택했다.
- 타입 추론을 사용해서 대부분의 귀찮고 불필요한 타입표기를 생략할 수 있게 지원한다.
객체 지향 프로그래밍을 완벽히 지원한다. 스칼라는 혼합 합성을 사용해서 타입을 깔끔하게 구현하는 트레이트로 자바 객체 모델을 보완한다. 스칼라에서는 모든 것이 객체이다. 수를 표현하는 함수도 객체이다
함수형 프로그래밍을 완전히 지원한다. FP는 동시성, 빅데이터, 일반적인 코드의 정확성을 사고하는데 최선의 도구이다. 불변값, 1급함수, 부수 효과가 없는 함수, 함수 컬렉션 등은 모두 간결하고 강력하며 정확한 코드를 작성하는데 기여한다
Scalability에 좋은 언어이다. ( 트레이트를 사용한 혼합 합성 , 추상 타입 멤버와 제네릭스, 내포 클래스, 명시적인 자기 타입 )
- 스칼라의 매력
- JVM, 라이브러리, 생산성 도구를 , 빅데이터, 고가용성과 강선성을 제공하는 간결하지만 표현련 높은 문법을 제공한다.
- 시간이 걸리지만 이거 잘하면 프로그래밍 언어는 잘할 것이다.
- 람다함수라고 불리는 익명 함수가 유용하다 -> 트레이터 처럼 유용한 혼합 합성을 사용할수 있다.
스칼라 설치하기
1 자바설치 -> 6,7,8 모두 사용 http://bit.ly/TEA7iC 에서 자바 개발도구를 다운받으면 된다.
2 SBT 설치 -> Scala Build Tool (http://bit.ly/1toEO6H)
Mac에서 설치할려면
brew update –debug –verbose
brew install sbt@1 ```
3 코드 예제 내려받기 -> http://bit.ly/prog-scala-code
1.git clone https://github.com/deanwampler/prog-scala-2nd-ed-code-examples.git
4 SBT 실행 -> sbt test를 입력하면 스칼라 컴파일러나 외부 라이브러리를 포함해서 해당 프로젝트가 의존하는 모든 라이브러리를 내려받는다. sbt는 코드를 컴파일한 다음에 단위 테스트를 실행할 것이다.
5 SBT 밖에서 스칼라 실행 http://www.scala-lang.org 스칼라 내려받고 스칼라를 위한 자바독이라고 할수 있는 스칼라독도 내려받기
root package
SBT 사용하기
명령을 설명한다.
현재 사용 가능한 작업 중 가장 일반적으로 사용하는 것들을 보여준다.
모든 가용 작업을 보여준다
코드를 증분 컴파일한다.
코드를 증분 컴파일하고 테스트를 실행한다.
빌드로 산출된 결과물을 지운다.
저장된 파일이 바뀌면 증분 컴파일과 테스트를 진행한다.
(~ , 프로젝트 파일을 감시하다가, 일부 또는 전부가 변경되는 경우 작업을 실행한다는 뜻이다.)
스칼라 REPL을 시작한다.
프로젝트의 main 루틴 중 하나를 실행한다.
변수 x의 정의를 본다.
주로 ~test를 사용해서 항상 변경 사항을 컴파일하고 관련 테스를 실행한다. 매번 전체를 새로 빌드할때까지 기다릴 필요가 없다. ~test 상태에서 다른 명령을 실행하거나 sbt를 종료하고 싶다면 리턴키를 누르면 된다.
'Cloud Computing > Spark' 카테고리의 다른 글
i3.instance 의 /dev/nvme0n1에 mount하기 (0) | 2017.11.30 |
---|---|
spark-ec2 i3 instance iostat 알아보기 & NVMe 비교해보기 (0) | 2017.11.30 |
r4 Instance Scalability 조사 (0) | 2017.10.02 |
Spark-EC2 Too large frame (0) | 2017.10.02 |
Spark에서 왜 결과값이 16*16이 아니라 4*4 인지 Code를 통해 설명 (0) | 2017.10.02 |