Kotlin Evergreen Tips: Destructuring Declarations

แชร์
ฝัง
  • เผยแพร่เมื่อ 21 ม.ค. 2025

ความคิดเห็น • 35

  • @dansadventures5514
    @dansadventures5514 2 ปีที่แล้ว +45

    Position-based destructuring is such a footgun that we updated our style guide to only allow using it with classes from the standard library (eg. Pair) since those are the only places where future safety is guaranteed.
    Name-based destructuring would be awesome.

  • @FxAndrej
    @FxAndrej ปีที่แล้ว

    Great explanation, great to mention the caveats, good pace. Thank you!

  • @pawewodarczyk1546
    @pawewodarczyk1546 2 ปีที่แล้ว +19

    Lack of name-based destructuring and nested destructuring are the main issues to solve in my opinion to make destructuring trully useful in Kotlin. Especially the lack of nested destructuing is more often the problem.

    • @Fletcher91
      @Fletcher91 2 ปีที่แล้ว +2

      No name based destructuring is a big hole in ux.
      Would also be great for more advanced pattern matching in `when`.

    • @BigCarso
      @BigCarso 2 ปีที่แล้ว

      But overall I think destructuring isn't high priority. I've been aware it's there but never use it because it doesn't add much to readability

    • @MaxCoplan
      @MaxCoplan 2 ปีที่แล้ว

      I was with you until nested destructuring. Nested destructuring always looks way more spaghetti 🍝 than just writing separate declarations

  • @daviddpg481
    @daviddpg481 2 ปีที่แล้ว +5

    You've really come to be way more at ease on camera Sebastian, i've been following these on and off since a year ago and you've improved a lot :)

  • @PaulNewport
    @PaulNewport 2 ปีที่แล้ว +4

    Very useful. I love how data classes implement component1 and component2.
    Thanks again for making these videos.

    • @Kotlin
      @Kotlin  2 ปีที่แล้ว +2

      Glad you like them!

  • @Omnieboer
    @Omnieboer 2 ปีที่แล้ว +4

    Every Kotlin video with Sebastians face in the thumbnail is an Insta-click

  • @x-lab
    @x-lab 2 ปีที่แล้ว +6

    Would be nice to have name-based destructuring syntax.

  • @DmitryKanunnikoff
    @DmitryKanunnikoff 2 ปีที่แล้ว +1

    Thank you very much!

  • @GabrielSouza-of7kt
    @GabrielSouza-of7kt 2 ปีที่แล้ว +1

    Nice video Seb 😍😍😍

  • @ethiomusic3158
    @ethiomusic3158 2 ปีที่แล้ว

    How do I make "Rate Us" and "Send App" in Kotlin language?... I did it in many ways but it doesn't go directly to Google Play Store.... I need help guys!... Right code in fragment... I hope many of you did it if you are app developers by Kotlin

  • @glubothemad
    @glubothemad 2 ปีที่แล้ว +2

    Position based structures (as anonymous pairs, or lists) are root of many hard to find bugs. I think that this has very limited valid usecases that would not become a maintenance hell. It was one of main plagues that used to drive me crazy about php codebases ~8 years ago.

  • @kvadr0n
    @kvadr0n 2 ปีที่แล้ว

    The intro made me remember the philosophy 101 paper about Mario where "I believe" in "I believe it was Kant that said..." was crossed out.
    Quote on Quote "Horrible opening"

  • @_deathcry
    @_deathcry 2 ปีที่แล้ว +1

    Would be really nice if you could use destructuring declarations with already existing variables, like if you already had var x,y and want to simply reassign them by some Pair

  • @saurabhbhorkar2607
    @saurabhbhorkar2607 2 ปีที่แล้ว

    Thanks for making video really helpful

  • @yoyo26-34
    @yoyo26-34 2 ปีที่แล้ว

    what about partial destructuring in your road map (that is closely linked to named destructuring) ? Based on your data class Person example, something like val (name, *restofproperties) = person? Is it something Kotlin is looking at ? This is so much helpful in languages like Typescript for example ( spread operator )

  • @RexTorres
    @RexTorres 2 ปีที่แล้ว

    I often use destructuring declarations, but I didn't know you can also use them on lists/arrays.

  • @abada-s
    @abada-s 2 ปีที่แล้ว

    If we declare components for data class we will not face refactoring problem when we add a new member to our data class

    • @henninghoefer
      @henninghoefer 2 ปีที่แล้ว +1

      Yes, see 4:10 in the video

  • @LostMekka
    @LostMekka 2 ปีที่แล้ว

    The real fun begins with extension operator functions :D

  • @adambickford8720
    @adambickford8720 2 ปีที่แล้ว

    i use the `with` operator as it essentially gives you named destructuring in its scope and allows function calls:
    val anon = object {
    val lol = "lolVal"
    val wut = "wutVal"
    fun beCool() = "$lol, $wut!!"
    }
    //works w/pair, data class, etc
    with(anon) {
    println("lol -> $lol")
    println("wut -> $wut")
    println("funCall -> ${beCool()}")
    }

  • @prateekkocher8540
    @prateekkocher8540 2 ปีที่แล้ว

    I was using pair based destructing, but from this video, Kotlin for Data science is even more attractive option compared to the most popular and easy to use python.

  • @ananthababu8272
    @ananthababu8272 2 ปีที่แล้ว +1

    Super 👌

  • @park2348190
    @park2348190 2 ปีที่แล้ว

    componentX functions are used for destructuring! didn't know that.

  • @Mikey-vd6op
    @Mikey-vd6op 2 ปีที่แล้ว

    Often use with(data class){…} as a work around but as everyone else has said. They really need to implement name based. Positional destructuring is problematic.

  • @ghccristia
    @ghccristia 2 ปีที่แล้ว +1

    💪💪👌

  • @jawadfadel2725
    @jawadfadel2725 2 ปีที่แล้ว

    kotlin has new features that's i keep loving kotlin
    but no company use it for server side using spring boot that's why not highly recommend

  • @dariusfathi5520
    @dariusfathi5520 2 ปีที่แล้ว +1

    Nice (t-)shirt 🙈🙈

  • @narsireddynallamilli3755
    @narsireddynallamilli3755 2 ปีที่แล้ว +1

    position based destructors are obsolete feature, I would never use them for their dangers.

  • @jesselima_dev
    @jesselima_dev 2 ปีที่แล้ว

    o/

  • @dislike__button
    @dislike__button 2 ปีที่แล้ว

    I don't know about that one chief.