what even is a "reference"?

  Рет қаралды 145,357

Low Level

Low Level

Күн бұрын

Пікірлер: 276
@LowLevelTV
@LowLevelTV 2 жыл бұрын
C++ people, I still love you ❤ BUT ONLY IF YOU FOLLOW ME ON TWITTER >:(
@user-mz8qj7bz8h
@user-mz8qj7bz8h 2 жыл бұрын
Nice video bro, could you please drop the name of the intro music :)
@SKBotNL
@SKBotNL 2 жыл бұрын
@@user-mz8qj7bz8h Sorry, that was the outro music not the intro music
@capitalists1526
@capitalists1526 2 жыл бұрын
@@sangitakumari5482 if you are a minor you shouldn't be sharing your age at random on social media
@SKBotNL
@SKBotNL 2 жыл бұрын
@@user-mz8qj7bz8h Found it! It's Strange Stuff by Matt Harris kzbin.info/www/bejne/i4GXZmqigaeNotU
@piotrkozbial8753
@piotrkozbial8753 2 жыл бұрын
You're spreading misinformation and still didn't get the flame war you wished for. C++ programmers were not "triggered", they explained your omissions politely in the comments. Instead, you seem to have triggered C programmers to hate on C++ in most stupid, irrelevant ways.
@williamdrum9899
@williamdrum9899 2 жыл бұрын
Pointers References Array Indexes "Corporate wants you to find the difference between these pictures" Assembly Programmer: "They're the same picture"
@Brad_Script
@Brad_Script 7 ай бұрын
array indexes will dereference a pointer, that's really the only difference
@joey199412
@joey199412 2 жыл бұрын
Modern compilers are really REALLY optimized. But references can in a lot of times result in more efficient compiled code because they are more limited and thus the compiler can eliminate a lot of possibilities or potential intentions . It's also easier to use for newcomers to low level languages so you usually just tell junior programmers to use references instead of pointers to save yourself from future headaches.
@matthew314engineering7
@matthew314engineering7 2 жыл бұрын
That makes sense. I was getting the safety insight but didn't see the performance one right away.
@ghosthunter0950
@ghosthunter0950 2 жыл бұрын
Really? I had a harder time with references than pointers when I first learned each.
@mastershooter64
@mastershooter64 Жыл бұрын
"more efficient compiled code because they are more limited and thus the compiler can eliminate a lot of possibilities or potential intentions" I think it's just because passing by reference doesn't make a copy of the object so you don't spend time copying a large object + you don't waste memory making another copy of the large object. So it saves time and memory! But I'm not sure what you mean by "they are more limited and thus the compiler can eliminate a lot of possibilities" That's a reason why you don't pass fundamental types by reference because that just passes in a pointer which would usually be more memory than the fundamental data type like a char or an int
@sinom
@sinom Жыл бұрын
​​@@mastershooter64 more limited than pointers. Not more limited than copies. With a pointer you could potentially do a lot of stuff, like pointer arithmetic and they can also be null. All of this needs to be allowed with pointer parameters by the compiler. References on the other hand are just that. A reference to something. No nulling, no arithmetic etc. This means the compiler can then do some theoretical optimizations where it just handles the original object directly instead of a pointer to the object. This is pretty rare though so in general references are just safer non nullable pointers
@Abcd-ti9wv
@Abcd-ti9wv 6 ай бұрын
there s no guarantee reference are not null, you can do int& Ref = *(int*)(nullptr)
@mareknetzel
@mareknetzel 2 жыл бұрын
The content of your channel is exactly what I always felt missing while studying (long time ago ~1999 ) and in general online tutorials. Thanks a lot, the form is great and the simplicity of it shows your great understanding of the subject.
@metal571
@metal571 2 жыл бұрын
As a full time professional modern C++ dev, I love this channel - no triggering here. I think the best way to think about references is as a *const* pointer underneath, which is not the same thing as a pointer to const (however machine code gen may be identical). That's an interesting C syntax quirk that you could also cover if you haven't already. Keep up the great work on these videos
@LowLevelTV
@LowLevelTV 2 жыл бұрын
YAY 🖥
@nishanth6403
@nishanth6403 2 жыл бұрын
Yes , a const reference would then be a const pointer to a const
@sinom
@sinom Жыл бұрын
References are only very rarely used like this. Usually they are mainly uses in function signatures because it allows to pass things into a function similarly to how you could with a pointer, but without the function then having to null check the input.
@Bwallker
@Bwallker 2 жыл бұрын
Some nitpicks/extra info: 1. Refrences don't have to be implemented using pointers by the compiler. Most of the time they are, because that is a sensible way to implement them, but if you wanted to be edgy you could write your own compiler that implements them differenty. 2. Even though references and pointers are the same thing at runtime (in most compilers), they are considered to be two very different things by the type system, and using references can result in better codegen because the compiler can give stronger guarantees about references than it can about pointers.
@clehaxze
@clehaxze 2 жыл бұрын
And that's why some senior C++ developers use pointer and reference interchangeably. It's confused me in the beginning. But then it makes sense afterwards.
@TheFakeVIP
@TheFakeVIP 2 жыл бұрын
Thanks, I was going to ask about that, makes sense. For example, if passing a const reference to an object that can fit in a register, I imagine the compiler could choose to pass the object directly instead of passing a pointer to it.
@gustawbobowski1333
@gustawbobowski1333 2 жыл бұрын
How exactly can you implement references other than pointers?
@9SMTM6
@9SMTM6 2 жыл бұрын
@@TheFakeVIP doesn't have to be a const& I think, because of the rules for references or should be easy to check for the compiler if copying suffices. const& is more for the user to enforce that, as well as a promise for the API I'd say.
@9SMTM6
@9SMTM6 2 жыл бұрын
@@gustawbobowski1333 also seems a bit tricky to me... Like swift inout parameters are modeled in its model? Seems wasteful, but perhaps that suffices.
@teranyan
@teranyan 2 жыл бұрын
I once "failed" a job interview because the interviewer knew less about references than I did and didn't believe me that the reference is much more powerful as optimization tool than "it's always a pointer under the hood". Which is exactly what your disassembly example is wrongly showing. The reference is NOT a pointer. If you compile that program with O3, it will probably resolve to pushing "3" into a register and returning it, because the compiler understands at compile time what your code does already. Because you were correctly using references (and an easy to to optimize pointer dereference).
@minikindaniil99
@minikindaniil99 2 жыл бұрын
If somebody thought that this is too sensible for c++, I've got your back: c++ also has - const reference and rvalue reference that cause lifetime extension of a temporary - universal/forwarding reference that change between rvalue and lvalue reference automatically together with CTAD - std::reference_wrapper because you can't create containers of references - ref qualified methods that enable overload resolution based on if object is temporary or not - still has many of pointer's problems, as it is easy to create dangling reference by accident
@free_mind
@free_mind 2 жыл бұрын
To be fair, the things you mentioned have their uses when used at that right place and time. Universal references for example are very useful in generic code. It can be overwhelming to a beginner to learn about the OCEAN of C++ features all at once though.
@usr-bin-gcc
@usr-bin-gcc 2 жыл бұрын
I think it is a bit misleading to say that a reference is a pointer. A pointer is a variable that stores the address of another variable, i.e. there is some memory allocated to store that address. A reference is establishing another syntactic label in our program for a variable that already exists, so no additional memory is required to store the address. Try taking the address of the pointer and the address of the reference. The address of the reference will be the same as the address of the variable that is being referenced, but the address of the pointer will not be the address of the variable that is being pointed to. It is up to the compiler to decide how to implement this, but they are semantically different, and it is worth understanding the semantics as well as the implementation. In your example, the compiler would be free to substitute x everywhere it sees rx and the program would be semantically the same as rx is just a new label for the same variable, in which case there would be no need for a pointer to implement it.
@filipcimo998
@filipcimo998 2 жыл бұрын
Reference to reference actually exists (in the point of view of syntax, not functionality), it is called rvalue reference, so it can refer to a temporary object and it is a operator used for move semantics in C++. This is a lvalue reference so as you said, it has to refer to some valid and already existing object.
@Coppertiel
@Coppertiel 2 жыл бұрын
The syntax for an rvalue reference is "foo&&", but calling it a "reference to reference" is just for fun.
@gustawbobowski1333
@gustawbobowski1333 2 жыл бұрын
What's the actual use?
@ronaldweasly561
@ronaldweasly561 2 жыл бұрын
@@gustawbobowski1333 string text = "foo"; string text2 = text; Copying "foo" to text2 (which is expensive), instead of copying just move it text2 = std::move(text) std::move using &&
@Spiderboydk
@Spiderboydk 2 жыл бұрын
Rvalue references are not references to references, despite coincidentally using the && symbol.
@claywynn9837
@claywynn9837 2 жыл бұрын
@@gustawbobowski1333 move semantics. By having an r-value reference passed to a move constructor you are signifying that it's "ok to scavenge" from this reference. An easy to understand example is moving a std::vector. Std::vector points to a heap allocated array. If you want to copy to a new vector, you must allocate a new array and copy each element of the first vector. With a move constructor you can just steal the pointer from the other vector, and tell that other vector "I have your array now, don't try to use it anymore"
@CanoTheVolcano
@CanoTheVolcano 2 жыл бұрын
thank you so much for this vid, I'm a mostly self taught C++ dev, and I'm working on my first big project, and I was very confused by the &object semantics being used in function arguments in this library I'm using. All my uni professors switched to Java/JS for all instruction over a decade ago, but I've always been really fond of C++'s high performance and modular syntax
@VTdarkangel
@VTdarkangel 2 жыл бұрын
This is probably heresy for most C++ programmers, but I always preferred using pointers instead of references. The * operator was a key that reminded me that I was accessing a different bit a of memory that was potentially out of scope and to tread carefully about what I did with it. I understand some of the safety concerns that references address, but I never had those problems. Pointers were just easy for me.
@JurekOK
@JurekOK 2 жыл бұрын
this is not so much a heresy; it's more like, some people are religious about c++. This is why Linus Torvalds wrote git in C, and not C++. To avoid religious wars.
@v01d_r34l1ty
@v01d_r34l1ty 2 жыл бұрын
​@@JurekOK i mean it's not heresy, it's just not standard practice anymore. raw pointer access in abundance is arguably why C++98 was terrible (in retrospect; i never used it). smart pointers / RAII and references make c++ not only easier to work with, but a lot easier to make memory safe in comparison to C. you still can use raw pointers, and at some times it makes sense to (i.e. same situation with goto), but it shouldn't be a standard practice.
@ericbwertz
@ericbwertz Жыл бұрын
@@JurekOK Not sure how that avoids a religious war -- it's a pretty potent thumb in the eye of C++.
@JurekOK
@JurekOK Жыл бұрын
@@ericbwertz :-) Good one!
@jaimeguzman4655
@jaimeguzman4655 Жыл бұрын
Strictly talking about pointers vs references. Since the actual functionality of it is near identical besides syntax, it is more of a guideline thing The one thing that references offer is that they can't be null, so if need to pass null I stick to pointers
@thebestwizz
@thebestwizz 2 жыл бұрын
With a reference you are less likely to mess up with memory. The golden rule nowadays is to avoid pointers if a reference can be used. It's especially useful when you want to pass on a HUMONGOUS array onto a function, using a reference is clean and simple.
@ashenone5774
@ashenone5774 2 жыл бұрын
Thank you my good sir! I was actually afraid to ask this question, and here you are already taught me something new.
@LowLevelTV
@LowLevelTV 2 жыл бұрын
Gotchu man!
@rohanjoshi8785
@rohanjoshi8785 2 жыл бұрын
Great video..!! I wasn't aware that ASM for both implementation would be the same.. good to know. This reminds me one of line of Linus Torvals - "When I read C code, I know what Assembly language will look like and that's something that I care about ".
@RobertGuilman
@RobertGuilman 2 жыл бұрын
Thanks, low level programming always fascinate me, it's like opening a forbidden scroll for a high level programmer
@LowLevelTV
@LowLevelTV 2 жыл бұрын
Glad you enjoy it!
@m1rrU_1
@m1rrU_1 Ай бұрын
it's crazy that you actually uses assembly code to break down the whole process and make everything so clear, really nice video
@mikegofton1
@mikegofton1 2 жыл бұрын
Thanks , really relevant. I’m teaching myself C++ and this confirmed what I thought - spicy pointers 🙂
@LowLevelTV
@LowLevelTV 2 жыл бұрын
Glad it was helpful!
@gustawbobowski1333
@gustawbobowski1333 2 жыл бұрын
They actually are watered down, seeing as they are limited pointers... Or maybe spiecier for the programmers because more focused on their purpose and utility? Idk
@nishanth6403
@nishanth6403 2 жыл бұрын
@@gustawbobowski1333 They are watered down intentionally, to enforce stricter code and help better compiler optimization.
@jaysistar2711
@jaysistar2711 2 жыл бұрын
You seemed to forget the biggest difference: References can be optimized away, while pointers cannot (always) be. Anytime there are constraints that must be obeyed at compile time, then the optimizer has more flexibility because it doesn't have to maintain some potentially optimizable semantics at runtime.
@tusharagarwal5306
@tusharagarwal5306 Жыл бұрын
Lol, I refreshed the video multiple times because I thought the first 2 secs clip was an ad.
@FalcoGer
@FalcoGer 2 жыл бұрын
a reference is a pointer, except it's treated as the non pointer type by the compiler. the compiler will compile a reference to exactly the same bytecode as a pointer. personally I don't like them because they abstract the fact that a function may alter the reference. references are okay if they are declared const, and they are used in this manner to avoid costly copying of data with copy constructors, and instead just a 4 byte pointer is passed instead. of course passing a const pointer is also an option, but that just involves cluttering the code up with pointless dereferencing, making it less readable. const is also just a compiler check, by the way. there is no assembly instructions indicating that a value is not to be altered.
@m4rt_
@m4rt_ 2 жыл бұрын
add -ggdb as a compiler flag to gcc/g++ to get more info in the assembly when using gdb
@Mnogojazyk
@Mnogojazyk 2 жыл бұрын
Thank you! I took C and C++ thirty five years ago. From what the instructors said and did not say, I figured out then that references had to pointers, but I could not get confirmation or refutation. This is this time I have gotten it - and an explanation how so and how references differ from pointers. Thank you!
@GameDevCoffeeBreak
@GameDevCoffeeBreak Жыл бұрын
My kid is learning how to code and I tried hard to explain to him the difference but your video is priceless, I'm showing it to him right now! thank you for that, have a long life and success! great video!
@bilalshaikh6603
@bilalshaikh6603 9 ай бұрын
How old is your kid?
@GameDevCoffeeBreak
@GameDevCoffeeBreak 9 ай бұрын
@@bilalshaikh6603 12y
@zamf
@zamf Жыл бұрын
The difference between pointers and references is mostly conceptual. A pointer is an object which holds an address to another location in memory. A pointer points to a value. A reference on the other hand should be though of as just another name for the same variable. An alias. It doesn't "point" to the variable. It *is* the variable. References should be considered a high-level construct, which only exists in code and not in the actual binary, while pointers exist as symbols in the binary. This is after turning on optimizations. Without optimizations references are just converted to pointers in the binary as we saw in the video. Of course, if a reference can outlive its scope (i.e. it is a member of a class or a lambda, etc.) then the compiler automatically converts it to a pointer and then it starts appearing as a pointer in the binary. But this is an exception. Most of the time references live inside of a specific scope and they act as just a different name for the variable they're referencing.
@ABaumstumpf
@ABaumstumpf 2 жыл бұрын
References are NOT pointers. They can be implemented as pointers but they are not the same (and have some very distinct behaviours and limitations). For one - a reference is not an object. There is no welldefined memory address the reference resides in. It depends on what those references are referencing - for example refrences to non-static member likely will increase the size. other things would be lifetime-extension. It is kinda like saying that "int" is a 32bit 2's comeplement integer type. Yeah - compilers MOSTLY do that, but that is not required.
@mogenshansen7210
@mogenshansen7210 11 ай бұрын
Good, low level explanation. Reference was originally added to C++ to support operator overloading. Otherwise what type should operator=, operator== and operator+ take to have a natural syntax ? From the C++ Core Guidelines for function argument type (appr): use (const) reference when there has to exist an object (no null), use pointer when there can be zero or one object (not array - multiple object).
@ca2121
@ca2121 Жыл бұрын
Wow after all this time I finally got the idea around references in C++. The assembly lines helped a lot. Thank you so much!
@bazoo513
@bazoo513 Жыл бұрын
Unlike some other videos on this topic I watched recently, this one is clear and to the point.
@joiscode3832
@joiscode3832 2 жыл бұрын
I love these vids. They have helped me understand some confusing things. Also i finaly got my x86 bootloader to call c.
@ws9691
@ws9691 6 ай бұрын
Awesome explanation - Thank You!!
@brawnie3969
@brawnie3969 Жыл бұрын
I'm so grateful for this kind of videos, you have helped me a lot.
@LowLevelTV
@LowLevelTV Жыл бұрын
Happy to help!
@itsawonderfullife4802
@itsawonderfullife4802 Жыл бұрын
References used to confuse me when I first learnt C++ and boy they are confusing! Because references are really (=syntactic sugar for) pointers but which are used like the data variables to which they point! They are supposed to make working with pointers, safer and more intuitive, but do they?
@gustavopeixoto8682
@gustavopeixoto8682 2 жыл бұрын
I can not tell you how glad I am to find out your channel. All the subjects that I like has always been here. Subscribed++ :D
@cno9984
@cno9984 2 жыл бұрын
It's all easy and fun until you get into rvalue references and move semantics.
@jordanlapointe4690
@jordanlapointe4690 Жыл бұрын
subbed, thank you for this explanation. I'm always gonna remember "references are just spicy pointers".
@Eggman890
@Eggman890 Жыл бұрын
The biggest benefit to references is they offer a kind of contract that tells the external code that the "ptr" cannot be null. This means that anything which is passed a reference (by return or function parameter) can safely use it without the need for any null checks.
@EnterOne100
@EnterOne100 3 ай бұрын
The way I like to sum up references is that they are pointers that are “automatically” dereferenced each time. Provided they are initialized. A lot od things become clear that way. I don’t like to call them “aliases” as they can be fields in classes.
@ArtykomHry
@ArtykomHry Жыл бұрын
note that one of the differences would be that the address of "rX" in your example would be the same as the address of "x", while the address of the "pX" would differ (as it points to the location of the pointer)
@ohwow2074
@ohwow2074 2 жыл бұрын
References are limited pointers. They are far less flexible than pointers but this also means that they're safer. But of course things can easily go wrong with references too (like dangling references).
@mastershooter64
@mastershooter64 Жыл бұрын
Writing int &var instead of int& var is heresy.
@TECHN01200
@TECHN01200 Жыл бұрын
As much as I prefer c++ over c just for some of the quality of life attributes it brings (some of the new stuff in c++ is backwards, but whatever), I prefer pointers over references. I feel as though they are better signposted that "hey, something else might just change with this pointer". I say this because when you touch a pointer, you either are using an asterisk to access the value or you are using arrow notation to access a field.
@ericbwertz
@ericbwertz Жыл бұрын
The problem with unconstrained pointers is that they can take away a number of optimizations that the compiler may be able to do that would otherwise be safe to do if it only knew it was OK to do so. References are more like a sharpshooter than Yosemite Sam, so it's safer to be in the presence of the former than the latter.
@wojtekdudek2374
@wojtekdudek2374 8 ай бұрын
One significant advantage of using C++ references is the ability to reassign the pointers themselves through a function, rather than merely modifying the memory to which the pointers point. Consider the following example: template void set_null(const T*& ptr) { ptr = nullptr; } In this example, the function set_null directly sets the pointer itself to nullptr (or NULL in C, 0). This syntax is much cleaner and more straightforward compared to the rather complicated macros you would need to define in C to achieve similar functionality. Additionally, using functions like this scales better with complexity; as the function grows larger, macros become less manageable and maintainable, whereas the function approach remains clear and concise, at least in some part.
@anon_y_mousse
@anon_y_mousse 2 жыл бұрын
I think it was when I first learned about r-value references that I really started to hate C++. I was rather indifferent to it before that, but that, that is what made me hate it.
@MrAbrazildo
@MrAbrazildo Жыл бұрын
Pros: better syntax and tied to the same address, so it avoids a bug by change its destination. So it's recommended to use it whenever possible. Cons: don't take it as an alternative name, because you will depend on the compiler to optimize that away. It's better to use a macro for that matter. 0:11, it's quite the opposite: since it's more robust, you navigate through safer waters. And if you spend some time improving it, it'll become ever safer. It's only when you are making a mess is when it can become even unsafer than C.
@johnsports_iii
@johnsports_iii Жыл бұрын
References are one of the few C++ features I really do appreciate.
@ebebebeb7283
@ebebebeb7283 2 жыл бұрын
thanks for this video, i'd been wondering what those were :)
@Supakills101
@Supakills101 2 жыл бұрын
I once read "A reference is essentially a const pointer that is immediately de-referenced".
@Mnogojazyk
@Mnogojazyk Жыл бұрын
Thanks for the nice, succinct explanation.
@laenprogrammation
@laenprogrammation 2 жыл бұрын
References, when not parameters of functions (or when the functions get inlined), can be implemented without having pointers under the hood, because in many cases it's just an alias. Wheather the compiler understand the difference or not is up to it's programmer. G++ isn't the only c++ compiler out there, and i suspect it treats references as pointers in all cases for the sake of implementation simplicity. Just showing one example with no optimization and telling "they are the same" is not really proof of anything. I had a code to optimize with functions already inlined and when i started using references in stead of pointers, i had a real increase in speed (around 4%, because i had a lot of calls to as small function).
@martingeorgiev999
@martingeorgiev999 Жыл бұрын
Special reference properties like prohibiting NULL values makes references good for library code. In order to achieve the same optimizations in C you have to use compiler attributes like "nonnull" which is inconvenient because most attributes are compiler specific. That is, they are not in the standard.
@NoodleBerry
@NoodleBerry Жыл бұрын
My compiler helpfully tells me if I try to return a local reference so that's nice
@unrealdevop
@unrealdevop 10 ай бұрын
3:14 You said that you can't assign a reference to a reference. But when you pass in a reference to a function that takes in a reference...how is that not the same as assigning a reference to a reference? That part is really confusing me because I'm used to thinking about pass-by-value in terms of a = b which copies the value from one to another. So naturally I'm thinking of passing in a value as '&b = a' where a is a reference.
@williamdrum9899
@williamdrum9899 2 жыл бұрын
The thing I don't like about pointers is when you have to have a pointer to a specific memory address, the syntax is confusing. I can't remember it off the top of my head but I think it's like (*(int*)) 0xDEADBEEF or something like that. In assembly you would just use "dword ptr" which makes so much more sense
@aaaaanh
@aaaaanh 2 жыл бұрын
The mad thing for me was I only started to understand reference and pointer in C after I finished learning assembly 😭
@timwong91198
@timwong91198 2 жыл бұрын
My man, you have taught me more than my whole degree
@zhangzhang8751
@zhangzhang8751 6 ай бұрын
This video is the best video that I have seen.
@morekozhambu
@morekozhambu 9 ай бұрын
Reference and Pointer exist as constructs only within C++. Assembly is agnostic to this and everything is Register value. So cannot compare 1 to 1 though both may be implemented similarly.
@deivid-01
@deivid-01 4 ай бұрын
Amazing man! Thanks a lot
@zemlidrakona2915
@zemlidrakona2915 Жыл бұрын
Personally I use pointers more often than references. I like the fact that with a pointer you can look at the code and know it's not a normal variable, without looking around for the declaration. I do often use references for passing stuff in a out out of functions however. I especially like references to pointers in that regard. They also come in handy for operator overloading, which if memory severs me, is why they were added to the language to begin with.
@simonemicucci9222
@simonemicucci9222 2 жыл бұрын
In short is a protected pointer? I can understand but appear not so much interesting if you know exactly what you want to do no?
@LowLevelTV
@LowLevelTV 2 жыл бұрын
I'm going to make a follow up video on design choices between pointers and references but in short, yeah a reference is just a pointer with controls on how you can access it. There are good use cases for pointers and references, but pointers can do both.
@dinobotpwnz
@dinobotpwnz 2 жыл бұрын
Since protections that make you have to think less are the only advantage, I'm really surprised references exist. The C++ FQA alludes to some different reason for why they were introduced but I'm still waiting for a video to explain that to me.
@simonemicucci9222
@simonemicucci9222 2 жыл бұрын
To be fair handle with reference and not a pointer is safer in 99% of code, have access to pointer too as alternative is a really good compromise for security and manipulation
@minirop
@minirop 2 жыл бұрын
@@dinobotpwnz it adds preconditions therefore the compiler can optimize the code better. If you fail to meet them (by having a reference to NULL for instance), it's your problem.
@XeroKimorimon
@XeroKimorimon 2 жыл бұрын
@@dinobotpwnz The reason why references exists in C++ is due to special member functions. Things like copy assignment, post increment etc. If we wanted to say do a copy assignment, it might end up being expensive to copy the whole object into the operator=() function, and we can't take a pointer to an object in operator=() because what would it even mean to do something like Foo f1; Foo f2; f2 = &f1; Are we trying to make a Foo* and assign it to f1? but that can't be, because f2 is clearly a Foo, did you mean to make it a Foo*, or is it really just a Foo that has opeartor=(Foo*) defined? It's really hard to tell, so they created references so it's much simpler to tell you intended to do f2 = f1 and not f2 = &f1 where f2 is a Foo*
@goblinsflying
@goblinsflying 2 жыл бұрын
The intro music is so good man, name?
@LowLevelTV
@LowLevelTV 2 жыл бұрын
Video description
@adamkrawczyk9261
@adamkrawczyk9261 2 жыл бұрын
what about in functions? would there be literally no difference if you used a refrence or a pointer unless you wanted to change the pointer/refrence mid function
@chri-k
@chri-k 2 жыл бұрын
yes
@XxDTownxX91
@XxDTownxX91 2 жыл бұрын
If your function takes a reference as a parameter, it's guaranteed to not be null
@chri-k
@chri-k 2 жыл бұрын
@@XxDTownxX91 i did not consider that. built-in compile-time null prevention. So not yes
@minirop
@minirop 2 жыл бұрын
No differences, but someone could be pedantic by saying you can reassign the pointer parameter (i.e. pX = &another_int) but since a pointer is a variable in itself, you are not modifying the original pointer passed to the function therefore it's unnecessary/useless.
@catostre
@catostre 2 жыл бұрын
You can't index or increment a reference, so if I wanted to implement strlen() I would use a pointer
@SkyyySi
@SkyyySi 2 жыл бұрын
Why do you assemble your code to then immediately disassemble it again? Just use "gcc -S", it will output the assembly code.
@milo20060
@milo20060 2 жыл бұрын
So basically both are referencing the x but the reference is a bit more restrictive by only having able to reference one while pointer can point to a pointer.. But then reference might be a bit more efficient. Yea probably got it now.
@maksymiliank5135
@maksymiliank5135 2 жыл бұрын
You only scratched the surface. const references are so much more powerful in a sense that you can assign temporary objects to them. You cannot do this with pointers
@Adam_Lyskawa
@Adam_Lyskawa 2 жыл бұрын
I don't quite get it how it is "easier" to use. I think they are unnecessarily confusing. First we put some restrictions on a pointer IDK, to prevent an oblivious user from shooting themselves in the foot, but at the same time the variable pretends a local variable so the user can shoot themselves in the foot anyway forgetting it's a pointer, because it's being a pointer (or a reference) is hidden (because like definition can be off the screen at the moment)... Weird. But useful anyway. Maybe the syntax is a little confusing, but it makes sense to have a kind of read-only pointers that serve a particular purpose that are distinct from regular general-purpose pointers.
@iwakeupsad
@iwakeupsad Жыл бұрын
That was ... just great. So great.
@bob-ny6kn
@bob-ny6kn 2 жыл бұрын
"Give me C or give me death!" Wayne Gretzky Michael Scott
@turner7777
@turner7777 2 жыл бұрын
I can summarize it in one sentance: - Reference is literally another name for the original variable, they ARE the same thing, just with different names
@volbla
@volbla 2 жыл бұрын
So it's a pointer with all the pointer syntax abstracted away. That's pretty cool.
@n00blamer
@n00blamer 2 жыл бұрын
It's even cooler! Binding a reference to non-existing object is UB, so once you see a reference parameter you don't need go be worrying if it is pointing to a null, or non-existing object. A reference is always valid. The reasoning behind adding references was more about syntactic convenience which allowed new parameter passing tricks making the language more convenient. Those in the Functional camp of programming of course hate pointers and references because anything within scope is mutable from another thread but this is another discussion.
@valizeth4073
@valizeth4073 2 жыл бұрын
No, a pointer and a reference are conceptually and semantically different things. It's irrelevant if references are realized as pointers since it's an implementation detail. A pointer points to something, a reference aliases something.
@volbla
@volbla 2 жыл бұрын
@@valizeth4073 Implementation is what i'm interested in. I want to understand what's going on under the hood, because that helps me understand its use and usage.
@Iuigi_t
@Iuigi_t Жыл бұрын
Mutable refs are illegal. I just need to know when a func is changing the args
@briandawley7808
@briandawley7808 Жыл бұрын
Is there a point to using references outside of passing arguments to functions? When I was learning C++, I learned it as, basically, when you're passing an argument, you can either pass a copy of the object (which can only be modified locally, doesn't impact "the object" that was passed outside of the function to which it was passed), or you can pass the object itself. If all you want is the ability to use the *value* of the object, but not manipulate the object itself, use "foo(obj X)." If you want the object itself (i.e., direct access to the object, so you can change it and it will stay changed outside of the current function), pass a reference, i.e., "foo (obj &X)." That said, this was over 20 years ago, so I may not be remembering correctly, haha.
@raghavantncv5380
@raghavantncv5380 Жыл бұрын
Bro awsome content❤❤❤❤
@jan-lukas
@jan-lukas 2 жыл бұрын
In my experience you should use references any time you don't deal with dynamically allocated memory. That should either be done using unique_ptr, or if you're a madlad, raw pointers
@gideonjonkers2683
@gideonjonkers2683 7 ай бұрын
I have found that when you make a pointer that points to a reference, it has the same memory address as the original variable. How come? If the reference is loaded on to stack like a pointer then the pointer to the reference should give the address of the reference and not the original variable, right? Or does the complier just overwrite the pointer of a reference to be to the original variable?
@dartusmin8924
@dartusmin8924 2 жыл бұрын
A *reference* can actually be a null reference, but it is considered an undefined behavior by The Standard. Consider the following code: _auto& f = *((std::fstream*)nullptr);_ _f
@Baile_an_Locha
@Baile_an_Locha 2 жыл бұрын
Yep, my standard demo program whenever anyone says that a reference can’t be null is: int main() { auto& result = *(int*)nullptr; return result; }
@n00blamer
@n00blamer 2 жыл бұрын
@@Baile_an_Locha It can be null, but as mentioned that is UB, so you don't have a _correct_ C++ program.
@Baile_an_Locha
@Baile_an_Locha 2 жыл бұрын
@@n00blamer Agreed, and in a simple example like I gave, correctness is something that is easy to make a judgment on. But in a complex system that’s not so easy. Consider a utility library (.dll or .so) that is dynamically loaded at runtime and has a function in its exported interface that accepts an int&. That function is correct to assume that the reference is non-null and yet it can fault at runtime due to a defect in the caller. Sometimes in these circumstances, I have wrapped the access to the reference in SEH (MSVC only).
@Tibor0991
@Tibor0991 2 жыл бұрын
@@Baile_an_Locha and this is why you must ONLY write C++ code with -Werror always on.
@UnrealOG137
@UnrealOG137 Жыл бұрын
You should do a video on compilers
@akaikangaroo
@akaikangaroo 2 жыл бұрын
So, can we have a reference to pointer?🤔
@euler4513
@euler4513 2 жыл бұрын
A reference is basically a const TYPE * that can’t be null yeah?
@jawwad4020
@jawwad4020 10 ай бұрын
Would the reference have a memory different address from the original variable ? I thought references are aliases, unlike pointers.
@sreejishnair5922
@sreejishnair5922 2 жыл бұрын
What does that mean that you have less overhead to use them? I didn't understand that part
@ignacioariellopez8491
@ignacioariellopez8491 Жыл бұрын
Question for anyone that might happen to be here after a year. I get now this is C++, but the whole int &ri = i; is still valid C code? And if so, how does it work? Never came across it when i was studying and i just blew my mind trying to figure out differences to int *ri = i; therefore my question if its still valid C or C++ exclusive.
@JanxZ
@JanxZ 2 жыл бұрын
"And the compiler knows what i mean!" Yeah...
@charlesmayberry2825
@charlesmayberry2825 11 ай бұрын
I wouldn't say a reference is a "spicy pointer" it's a special type of pointer for sure, I always thought of them as "pointers with some protections" Which is great, there are several situations where I have made a mistake that would be allowed using a pointer but would have crashed at runtime, using a reference it goes "you can't do that" at compile time, look at the code and go "oh that's dumb what was I thinking" fix it and move on. Basically... what is a reference? a pointer that shortens my debugging time lol
@huntabadday2663
@huntabadday2663 2 жыл бұрын
I work with assembly for fun, I don't think pointers are an issue for me.
@Baile_an_Locha
@Baile_an_Locha 2 жыл бұрын
Nit-picking C++ guy says: if it is C++ you should be including instead of :)
@abuk95
@abuk95 2 жыл бұрын
Double reference `&&variable` is still a mystery, though.
@anon_y_mousse
@anon_y_mousse 2 жыл бұрын
It's an r-value reference.
@abuk95
@abuk95 2 жыл бұрын
@@anon_y_mousse Now both &&variable and r-value references are mystery, lol.
@anon_y_mousse
@anon_y_mousse 2 жыл бұрын
@@abuk95 The &&var is an r-value reference. It's used for std::move() semantics so that it doesn't cause an unnecessary construction or allocation.
@n00blamer
@n00blamer 2 жыл бұрын
It's already said it's r-value reference, but why!? The reasoning is that when "they" wanted move construction in C++ they needed a syntax, and decided that && will be move. The std::move turns object into r-value (&&) which matches before &, very ugly hack, LOL, but it works. Now C++ has move construction. The End.
@arunkrishna1854
@arunkrishna1854 2 жыл бұрын
Any projects you'd suggest to get better at rust (I'm a pentester,red teamer and looking to get into more of the rust's system stuff)
@michaeledwardharris
@michaeledwardharris 2 жыл бұрын
Very nice!
@LowLevelTV
@LowLevelTV 2 жыл бұрын
Thank you! Cheers!
@97CelticPredator
@97CelticPredator 2 жыл бұрын
can you do a video on classes?
@YounessChaaibi
@YounessChaaibi 2 жыл бұрын
does reference take an additional memory as pointers ?
@harshithgowda6227
@harshithgowda6227 Жыл бұрын
which software do you use for coding C++ on mac?
@Uerdue
@Uerdue 2 жыл бұрын
So, a reference is just a pointer that takes longer to compile?
@PieroUlloa
@PieroUlloa Жыл бұрын
Hmm, even though this video is a year old, I would like to point that in the last bit (at 5:27), where you said that references are spicy pointers, I think you should have said the opposite, ie. that pointers are spicy references.
@tuliodebarros734
@tuliodebarros734 Жыл бұрын
Are you the guy from "BroCode" ?
@sandipdas7206
@sandipdas7206 7 ай бұрын
Thanks for the treat now references aren't complicated either
@user-bi1vi6nm2o
@user-bi1vi6nm2o 2 жыл бұрын
Can you make a video to play with DAC on raspberry pi (pure C).. i saw someone make a fm radio transmitter using raspberry pi 😁
@bazoo513
@bazoo513 Жыл бұрын
So, references are just syntactic sugar for immutable pointers making it, frankly, less clear what is actually happening... (And, as some people point out, because their behaviour is far more limited, they give a compiler chance to produce better code and the programmer slightly less chance to shoot themselves in the foot.) (Obviously, I don't know C++.)
are "smart pointers" actually smart?
9:44
Low Level
Рет қаралды 82 М.
why do header files even exist?
10:53
Low Level
Рет қаралды 453 М.
Как Ходили родители в ШКОЛУ!
0:49
Family Box
Рет қаралды 2,3 МЛН
#behindthescenes @CrissaJackson
0:11
Happy Kelli
Рет қаралды 27 МЛН
Почему Катар богатый? #shorts
0:45
Послезавтра
Рет қаралды 2 МЛН
some of the worst API security i've EVER seen
27:53
Low Level
Рет қаралды 149 М.
31 nooby C++ habits you need to ditch
16:18
mCoding
Рет қаралды 858 М.
why are switch statements so HECKIN fast?
11:03
Low Level
Рет қаралды 440 М.
What is the Difference Between a Pointer and a Reference C++
7:58
Paul Programming
Рет қаралды 445 М.
you will never ask about pointers again after watching this video
8:03
why do hackers love strings?
5:42
Low Level
Рет қаралды 433 М.
Naming Things in Code
7:25
CodeAesthetic
Рет қаралды 2,3 МЛН
lvalues and rvalues in C++
14:13
The Cherno
Рет қаралды 332 М.
C++ Super Optimization: 1000X Faster
15:33
Dave's Garage
Рет қаралды 334 М.
Should I pass by const reference or by value?
10:45
The Cherno
Рет қаралды 113 М.
КАК ЖИВЕТ КВАНТУМ? РУМ ТУР КВАНТУМА!!!
13:51
КАК ЖИВЕТ КВАНТУМ? РУМ ТУР КВАНТУМА!!!
13:51
Мы Сняли Радужных Друзей на новый iPhone 14 PRO !
24:18
СИЖУ БЕЗ ЕДЫ, ПЬЮ ОДНУ ВОДИЧКУ.
21:37
Быть Добру
Рет қаралды 79 М.
Satisfying Vend 😦 Ep.5 #shorts #satisfying #vendingmachine
0:23
TYE Arcade
Рет қаралды 17 МЛН
Черная Magic Mouse
0:53
Romancev768
Рет қаралды 807 М.