About this Course
최근 조회 34,328

다음 전문 분야의 5개 강좌 중 2번째 강좌:

100% 온라인

지금 바로 시작해 나만의 일정에 따라 학습을 진행하세요.

유동적 마감일

일정에 따라 마감일을 재설정합니다.

중급 단계

영어

자막: 영어

귀하가 습득할 기술

StreamsFunctional DesignReactive ProgrammingFunctional Programming

다음 전문 분야의 5개 강좌 중 2번째 강좌:

100% 온라인

지금 바로 시작해 나만의 일정에 따라 학습을 진행하세요.

유동적 마감일

일정에 따라 마감일을 재설정합니다.

중급 단계

영어

자막: 영어

강의 계획 - 이 강좌에서 배울 내용

1
완료하는 데 8시간 필요

For Expressions and Monads

We'll start by revisiting some concepts that we have learned from Principles of Functional Programming in Scala; collections, pattern matching, and functions. We'll then touch on for-comprehensions, a powerful way in Scala to traverse a list, process it, and return a new list. We'll see how to do queries with for-comprehensions as well as how the for-comprehension is "desugared" into calls to higher-order functions by the Scala compiler. Finally, we'll discuss what monads are, and how to verify that the monad laws are satisfied for a number of examples.

...
10 videos (Total 164 min), 11 readings, 1 quiz
10개의 동영상
Tools Setup for Mac OS X21m
Tools for Setup for Windows18m
Tutorial: Working on the Programming Assignments8m
Recap: Functions and Pattern Matching19m
Recap: Collections12m
Lecture 1.1 - Queries with For7m
Lecture 1.2 - Translation of For11m
Lecture 1.3 - Functional Random Generators19m
Lecture 1.4 - Monads20m
11개의 읽기 자료
Troubleshooting10m
Grading Policy10m
Tools Setup10m
Sbt Tutorial10m
Eclipse Tutorial10m
Intellij IDEA Tutorial10m
Scala Tutorial10m
Cheat Sheet10m
Reactive Cheat Sheet10m
Scala Style Guide10m
Learning Resources10m
2
완료하는 데 7시간 필요

Lazy Evaluation

This week we'll revisit performance issues caused by combinatorial search, and we'll discover an important concept in functional programming that can these issues: laziness. We'll also learn a little bit about proofs on trees; in particular, we'll see how to extend structural induction to trees.

...
5 videos (Total 80 min), 2 quizzes
5개의 동영상
Lecture 2.2 - Streams12m
Lecture 2.3 - Lazy Evaluation11m
Lecture 2.4 - Computing with Infinite Sequences9m
Lecture 2.5 - Case Study: the Water Pouring Problem31m
3
완료하는 데 7시간 필요

Functions and State

This week, we'll learn about state and side-effects. Through a rich example, we'll learn programming patterns for managing state in larger programs. We'll also learn about for-loops and while-loops in Scala.

...
6 videos (Total 72 min), 2 quizzes
6개의 동영상
Lecture 3.2 - Identity and Change8m
Lecture 3.3 - Loops8m
Lecture 3.4 - Extended Example: Discrete Event Simulation10m
Lecture 3.5 - Discrete Event Simulation: API and Usage10m
Lecture 3.6 - Discrete Event Simulation: Implementation and Test18m
4
완료하는 데 8시간 필요

Timely Effects

This week we'll learn a number of important programming patterns via examples, starting with the observer pattern, and then going on to functional reactive programming. We'll learn how latency can be modeled as an effect, and how latency can be handled with Scala's monadic futures. We'll learn the important combinators on futures as well as how they can be composed to build up rich and responsive services.

...
11 videos (Total 109 min), 2 quizzes
11개의 동영상
Lecture 4.2 - Functional Reactive Programming20m
Lecture 4.3 - A Simple FRP Implementation19m
Lecture 4.4 - Latency as an Effect 17m
Lecture 4.5 - Latency as an Effect 212m
Lecture 4.6 - Combinators on Futures 19m
Lecture 4.7 - Combinators on Futures 27m
Lecture 4.8 - Composing Futures 14m
Lecture 4.9 - Implementation of flatMap on Future3m
Lecture 4.10 - Composing Futures 28m
Conclusion4m
4.5
442개의 리뷰Chevron Right

42%

이 강좌를 수료한 후 새로운 경력 시작하기

34%

이 강좌를 통해 확실한 경력상 이점 얻기

Functional Program Design in Scala의 최상위 리뷰

대학: RPSep 15th 2016

This is a university degree course which takes enormous effort to complete. But still its beond the programming course range giving you whats not possible to google or learn practical way. Thanks!

대학: ESMar 18th 2018

Thank you for this exciting course! I did the FP in Scala course a few years ago and decided to do the full certification now. I am looking forward to the next courses in the specialisation.

강사

Avatar

Martin Odersky

Professor
Computer Science

로잔연방공과대학교 정보

Functional Programming in Scala 전문 분야 정보

Discover how to write elegant code that works the first time it is run. This Specialization provides a hands-on introduction to functional programming using the widespread programming language, Scala. It begins from the basic building blocks of the functional paradigm, first showing how to use these blocks to solve small problems, before building up to combining these concepts to architect larger functional programs. You'll see how the functional paradigm facilitates parallel and distributed programming, and through a series of hands on examples and programming assignments, you'll learn how to analyze data sets small to large; from parallel programming on multicore architectures, to distributed programming on a cluster using Apache Spark. A final capstone project will allow you to apply the skills you learned by building a large data-intensive application using real-world data....
Functional Programming in Scala

자주 묻는 질문

  • 강좌에 등록하면 바로 모든 비디오, 테스트 및 프로그래밍 과제(해당하는 경우)에 접근할 수 있습니다. 상호 첨삭 과제는 이 세션이 시작된 경우에만 제출하고 검토할 수 있습니다. 강좌를 구매하지 않고 살펴보기만 하면 특정 과제에 접근하지 못할 수 있습니다.

  • 강좌를 등록하면 전문 분야의 모든 강좌에 접근할 수 있고 강좌를 완료하면 수료증을 취득할 수 있습니다. 전자 수료증이 성취도 페이지에 추가되며 해당 페이지에서 수료증을 인쇄하거나 LinkedIn 프로필에 수료증을 추가할 수 있습니다. 강좌 내용만 읽고 살펴보려면 해당 강좌를 무료로 청강할 수 있습니다.

궁금한 점이 더 있으신가요? 학습자 도움말 센터를 방문해 보세요.