Back to Basics: C++ Smart Pointers - David Olsen - CppCon 2022

แชร์
ฝัง
  • เผยแพร่เมื่อ 9 พ.ย. 2024

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

  • @coolwinder
    @coolwinder ปีที่แล้ว +17

    This talk is too good, incredible information presented. I have used this talk to sprawl my research and understanding of mentioned topics. Thanks David, this is much appreciated!

  • @violetashopova3586
    @violetashopova3586 5 หลายเดือนก่อน +1

    THIS GUY! ... every talk he did i watched so far is worth its time in gold

  • @vtx_lq
    @vtx_lq ปีที่แล้ว +13

    Excellent talk, thank you! Appreciate always revisiting some fundamentals.

  • @Bolpat
    @Bolpat ปีที่แล้ว +8

    I’m currently in the process of updating a pre-C++11 codebase and some rules I imposed to myself is:
    * Never assert(ptr_parameter); If you find yourself doing this to a parameter, it should be a reference. If necessary, the caller must assert.
    * never new and delete (“// transfers ownership” doesn’t cut it)
    * For arrays, use container types (e.g. std::vector, std::array) and (custom type) ranges and iterators
    Then, any T* is a nullable non-owner pointer to a single object. Exceptions apply when calling library functions I have no control over, but if _my_ function takes/returns a int* it expects/returns a nullable non-owner pointer to a single object.

    • @NoSpeechForTheDumb
      @NoSpeechForTheDumb 2 หลายเดือนก่อน

      @@Bolpat use static_assert instead of assert if possible. Unnecessary runtime hit by RTTI.

  • @Roibarkan
    @Roibarkan ปีที่แล้ว +8

    48:20 the type-erased nature of shared_ptr deleters can sometimes relieve issues related to multiple heap situations, ensuring an object gets deleted from the heap it was allocated from

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

      What is type-erased, also mentioned in 42:30, where it was mentioned as a resone for unique_ptr having deleter as template parameter and share_ptr a constructor argument for an instance of deleter? Thanks in advance :)

  • @aprasath1
    @aprasath1 5 หลายเดือนก่อน

    Wonderful video!!! Very well explained covering lots of issues with usage as well.

  • @acur665
    @acur665 9 หลายเดือนก่อน

    Great talk - thank you for the fundamentals here!

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

    6:32 I’d add that a raw pointer should be nullable. If it’s non-owning and points to a single object, if it’s also not supposed to be null, what’s the difference to a reference?

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

    Excellent talk ! Learnt a lot.

  • @Roibarkan
    @Roibarkan ปีที่แล้ว +3

    14:02, 29:17 (slightly advanced) note that self-move (e.g. “a=std::move(a);”) is not considered something that move-assignment should guard against. Copy-assignment should typically guard against self-assignment, and this is guaranteed for shared_ptr.

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

      Is this some guideline? Thanks

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

      @@coolwinder yeah since when you move an object, you set the pointer of the other object to nullptr. when you self move you set your object's pointer to nullptr. memory leak.

  • @nhanNguyen-wo8fy
    @nhanNguyen-wo8fy 5 หลายเดือนก่อน

    9:29 unique pointer as member of class

  • @oraz.
    @oraz. ปีที่แล้ว

    The variable length arrays in the examples are ok?

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

    at 33:38 on line 2. "a" gets passed into the thread function's parameter "b". Wouldn't that increment count. There's no red arrow showing increment count on line 2. A bit hazy on this, if anyone would answer, that would be great!

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

      I got the same question haha

    • @bva0
      @bva0 10 หลายเดือนก่อน

      I think the compiler optimizes that away (assuming you don't compile with -O0) in this case.

    • @David_Olsen
      @David_Olsen 8 หลายเดือนก่อน +2

      You are right. I missed the increment when the child thread's 'b' is initialized from the main thread's 'a'. I should have noticed that the number of increments and decrements didn't match. The main point of that slide, that the increments and decrements don't introduce data races, is still valid.

  • @eeshvardasikcm
    @eeshvardasikcm 6 หลายเดือนก่อน

    Thanks!

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

    Awesome, thank u so much.

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

    this was great!

  • @shivakumark.o846
    @shivakumark.o846 10 หลายเดือนก่อน

    Thankyou

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

    45:42 another good talk about some nice variations of smart pointers: th-cam.com/video/sjLRX4WMvlU/w-d-xo.html

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

    35:38
    some member of the committee should be ashamed of their inefficiency. they always use “pursuing perfection” as an excuse, but in fact they spent one three-year after another, and got one half-finished product after another

  • @cunningham.s_law
    @cunningham.s_law 5 หลายเดือนก่อน

    if a unique pointer is the same in memory as a raw pointer, does that mean that I can reinterpretcast a raw pointer as a unique pointer and have it call the destructor?

    • @David_Olsen
      @David_Olsen 4 หลายเดือนก่อน

      No. Don't try to do that. It won't work. A unique_ptr probably has the same memory layout as a raw pointer, but that is not guaranteed. Doing a reinterpret_cast does not create an object, so the destructor of the unique_ptr will not be run. If you have a raw pointer and you want its memory to be freed automatically, define a unique_ptr variable with the right lifetime and pass the raw pointer to the constructor.

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

    nice

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

    I'd argue that the first two examples don't need smart pointers.. what's wrong with std::vector??

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

      Sometimes better performance (for creation and destruction*, not access which is the same) and less memory. Plus they signal to everyone that they shouldn't change in size.
      *there are exceptions where std::vector outperforms such as when the size is very large or you want to use std::move.

    • @David_Olsen
      @David_Olsen 4 หลายเดือนก่อน +2

      std::vector could have been used in those examples, but I don't see it as the best solution. std::vector can fix some of the memory management problems as smart pointers. But std::vector also has all the semantics of a resizable array. Sometime you don't want that or need all that extra stuff. In the first two examples, all that was needed was to automatically free the memory. std::unique_ptr does exactly that, and nothing more, so it is the best fit for those situations.

  • @agentstona
    @agentstona 4 หลายเดือนก่อน

    THIS IS ALL A WASTE OF TIME JUST SWITCH TO RUST OR PYTHON where memory is automanaged for you .... WHY YOU wasting your time attempting to manage stuff that can be automated ....

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

    As already pointed out (yes I know) this same topic was given by Arthur O'Dwyer three years ago. I check these out just in case there's something neat or new discussed.
    The audio in this video is terrible I couldn't finish watching it.

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

      Audio seems fine to me.

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

    DId he fr just do an entire presentation reaeding a script

    • @VictorYarema
      @VictorYarema ปีที่แล้ว +24

      Reading a damn good well prepared script.

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

    CppCon 2019 - Back to basics: Smart pointers. By Arthur O'Dwyer. What's the point of repeating the same topic three years later?

    • @treyquattro
      @treyquattro ปีที่แล้ว +30

      so that we eventually get it

    • @johnhsu5459
      @johnhsu5459 ปีที่แล้ว +20

      Why does your university offers same classes every year while a recording is available?

    • @David_Olsen
      @David_Olsen 8 หลายเดือนก่อน +4

      Topics on the Back to Basics track are often repeated, but the presenter is always different with the expectation that the talks will be different enough that each of them is useful. Arthur O'Dwyer's and my Smart Pointer talks are more similar than I would have preferred. But Mike Shah's and my Concurrency talks are nothing alike and there are benefits to watching both of them.

  • @treyquattro
    @treyquattro ปีที่แล้ว +12

    pretty perfunctory talk. All the huffing and blowing made it seem that Mr. Olsen was doing it under duress. Maybe let someone with a bit more enthusiasm for the subject do it next time?

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

      Did it? It could be a health issue, or nerves, or something else.

    • @debajyotimajumder472
      @debajyotimajumder472 10 หลายเดือนก่อน +1

      I liked the content. Learnt something useful.

    • @debajyotimajumder472
      @debajyotimajumder472 10 หลายเดือนก่อน +2

      I liked the content. Learnt something useful.

    • @mrphobos44
      @mrphobos44 9 หลายเดือนก่อน

      Perhaps he just really wanted to eat those three little pigs.
      Great talk IMO.

    • @utilka5415
      @utilka5415 9 หลายเดือนก่อน +3

      its smart pointers. It is perfectly understandable to lack enthusiasm on such a basic topic, but someone has to do such entry talks, just so we have an alternative entry point to those zoomer tutorials