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
@Orangubara4 ай бұрын
I'm positively mind blown after this tutorial, 10/10
@Dr_Dude3 жыл бұрын
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)
@rockthejvm3 жыл бұрын
Glad you liked it!
@jimaaman3 жыл бұрын
As always, a high quality tutorial and explanation 👍 particularly excited to see more examples of Scala 3 in action.
@rockthejvm3 жыл бұрын
Glad you liked it!
@MrOliwander3 жыл бұрын
I have grasped it finally. Thank you, Daniel! I can't wait to watch another similar one for monads.
@rockthejvm3 жыл бұрын
Glad it helped!
@massimodaros391 Жыл бұрын
Wow Daniel !! This video is very inspiring Scala rocks !!
@TJ-hs1qm10 ай бұрын
11:37 line 32 could you further abstract over the concrete type C[Int]... similar to C[?] perhaps
@Rockyzach883 ай бұрын
_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
@alanlewis16253 жыл бұрын
Hi Daniel Thanks!! Yet another awesome video :-) . Great content, and perfect length.
@rockthejvm3 жыл бұрын
Glad you liked it!
@mahesh_kndpl Жыл бұрын
Top notch quality. Loved it.
@ZoYaBoBo2 жыл бұрын
You are awesome, still looking your videos one by one
@Nebulorum3 жыл бұрын
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.
@rockthejvm3 жыл бұрын
Nice nuanced wish. Will think of something
@pr0master3 жыл бұрын
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.
@rockthejvm3 жыл бұрын
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.
@Nebulorum3 жыл бұрын
Quick comment this works with Scala 3.0.0M3 but there have been some syntax changes. Fundamentally the as token was dropped.
@rockthejvm3 жыл бұрын
Thanks for the tip - take the ideas and stick the new syntax.
@MartinZachrison3 жыл бұрын
Very good! Takes the ghost out of the Functor
@rockthejvm3 жыл бұрын
That's the goal
@MrCesarification Жыл бұрын
beautiful
@amol_ Жыл бұрын
Great Explanation, now please consider to make video on Applicative.
@rockthejvm Жыл бұрын
The Cats course has all of them in great detail!
@Jankoekepannekoek3 жыл бұрын
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).
@rockthejvm3 жыл бұрын
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.
@ლუკა-ჩ4ე3 жыл бұрын
quite the beginner here so sorry if its a dumb question -how does a functor differ from a generic ?
@ლუკა-ჩ4ე3 жыл бұрын
btw thank you for all your vids, they are invaluable !
@luismiguelmejiasuarez20203 жыл бұрын
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 :)
@rockthejvm3 жыл бұрын
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