9:24 - If code doesn't work for you to, in scala 3.4.2 you need to write "given listFunctor: Functor[List] with" IDK what happened with "as" keyword Im new to this too :P
@Orangubara5 ай бұрын
I'm positively mind blown after this tutorial, 10/10
@Dr_Dude4 жыл бұрын
This is one of the best videos i watched on this channel, this is a must for all those wanting to do proper functional programming, and of course the rest of the category theory programming imo (monad, monoid, type classes -- supported in scala 3 now without too much typing-- and many others)
@rockthejvm4 жыл бұрын
Glad you liked it!
@jimaaman4 жыл бұрын
As always, a high quality tutorial and explanation 👍 particularly excited to see more examples of Scala 3 in action.
@rockthejvm4 жыл бұрын
Glad you liked it!
@massimodaros391 Жыл бұрын
Wow Daniel !! This video is very inspiring Scala rocks !!
@MrOliwander4 жыл бұрын
I have grasped it finally. Thank you, Daniel! I can't wait to watch another similar one for monads.
@rockthejvm4 жыл бұрын
Glad it helped!
@mahesh_kndpl Жыл бұрын
Top notch quality. Loved it.
@alanlewis16254 жыл бұрын
Hi Daniel Thanks!! Yet another awesome video :-) . Great content, and perfect length.
@rockthejvm4 жыл бұрын
Glad you liked it!
@Rockyzach884 ай бұрын
_Looks at Scala history page_ : "Scala was designed to be a better Java" Me: Oh sweet! I'm going to learn a new language. Me after the video: :O
@ZoYaBoBo2 жыл бұрын
You are awesome, still looking your videos one by one
@TJ-hs1qm Жыл бұрын
11:37 line 32 could you further abstract over the concrete type C[Int]... similar to C[?] perhaps
@MartinZachrison4 жыл бұрын
Very good! Takes the ghost out of the Functor
@rockthejvm4 жыл бұрын
That's the goal
@MrCesarification Жыл бұрын
beautiful
@pr0master4 жыл бұрын
Hi, question: I still do not understand the exact applicability of an Functor, or better say, in combination with a typeclass. I do understand the concept of "mapping" and reusing this construct to multiple datatypes, but, you said in the video that you reduced this API to a single method with the given functor implementation. How I see it, is, what you actually did is moving the implementation to multiple typeclasses (list, option, leaf etc.). You need the implementation of the map function for different types. Why using all these abstract and complicated language constructs to reduce the method/api to a single method? So, why not just define a simple trait / interface? No typeclasses, no extention functions, no implicit stuff (dependency), no misdirection etc.
@rockthejvm4 жыл бұрын
Legit question. The idea is we're moving code so we can keep a "stable" API and then "plug" in different implementations as we see fit. The moving of code to reduce duplication happens at all levels. Think of the standard OO polymorphism: it serves a similar purpose, whereby you rely on an instance of a general type (e.g. Animal) in a stable API but then at runtime you can use Cats, Dogs, Crocodiles in your actual logic, instead of explicitly handling Cats, Dogs, Crocodiles directly in your public API.
@Jankoekepannekoek4 жыл бұрын
At 4:23 you mention that java.util.Optional has the same semantics as scala.Option, but that is not true; Java's Optional can't contain null, but Some(null) is perfectly allowed in Scala. While probably no programmer on earth would explicitly instantiate an Option with null on its initial creation, this situation can still occur when trying to map a function over an option. If the function used as the argument for map returns null, then Java's Optional#map will return the empty Optional, but Scala's Option#map will return Some(null).
@rockthejvm4 жыл бұрын
Partially true. Some(null) is allowed in Scala but it's an anti-pattern, much like Optional.of(null). The map method of optionals will return None if the resulting optional is empty. Even so, the validity of the statement does not change: the semantics are the same, as both Scala Option and Java Optional were built for the same purpose.
@Nebulorum4 жыл бұрын
Really like the video. After a mid video epiphany I would love to see a series of this small type classes building something larger for free. E.g. Functor + Applicative + Monoid of Tree allows me to do X for free, for some X that is complex.
@rockthejvm4 жыл бұрын
Nice nuanced wish. Will think of something
@Nebulorum4 жыл бұрын
Quick comment this works with Scala 3.0.0M3 but there have been some syntax changes. Fundamentally the as token was dropped.
@rockthejvm4 жыл бұрын
Thanks for the tip - take the ideas and stick the new syntax.
@amol_ Жыл бұрын
Great Explanation, now please consider to make video on Applicative.
@rockthejvm Жыл бұрын
The Cats course has all of them in great detail!
@eugenehlushin1746 Жыл бұрын
great
@ლუკა-ჩ4ე4 жыл бұрын
quite the beginner here so sorry if its a dumb question -how does a functor differ from a generic ?
@ლუკა-ჩ4ე4 жыл бұрын
btw thank you for all your vids, they are invaluable !
@luismiguelmejiasuarez20204 жыл бұрын
What is a generic for you? And why you think a Functor is something similar? - BTW, I would encourage you to ask this and future questions in the gitter channel or in the Scala sub-reddit since you would get more audience :)
@rockthejvm4 жыл бұрын
A "generic" is the language feature of using the same code for more than one type, e.g. the List logic is the same for Ints, Strings, etc. A Functor is a particular kind of concept (a "mappable" data structure) that we attach to a particular set of types (in this case, List, Option and Tree).
@ლუკა-ჩ4ე3 жыл бұрын
@@rockthejvm thank you for this just seen it !!my understanding is slowly but surely improving, thanks to you ! appreciate it