Master Pointers in C: 10X Your C Coding!

  Переглядів 256,899

Dave's Garage

Dave's Garage

День тому

Pointer basics, indirection, void pointers, pointers to pointers, function pointers, callbacks and much more in this comprehensive introduction to pointers. For information on my book, "Secrets of the Autistic Millionaire": amzn.to/3diQILq
My other channel, join now so you're there for episode 01 of my AudioBook!
/ @davepl
Discord Chat w/ Myself and Subscribers: / discord
Primary Equipment (Amazon Affiliate Links):
* Camera: Sony FX-3 - amzn.to/3w31C0Z
* Camera Lens: 50mm F1.4 Art DG HSM - amzn.to/3kEnYk4
* Microphone: Electro Voice RE 320 - amzn.to/37gL65g
* Teleprompter: Glide Gear TMP 100 - amzn.to/3MN2nlA
* SD Cards: Sony TOUGH - amzn.to/38QZGR9
This is a revised edit (shorter and without intro) of the video from several days ago!
As always, all content and opinions are mine only, (c) 2022 Plummer's Software LLC.

КОМЕНТАРІ: 617
@esra_erimez
@esra_erimez 11 місяців тому
My dad taught me about pointers using index registers in assembler.
@johnmckown1267
@johnmckown1267 11 місяців тому
Sounds like IBM mainframe HLASM. I've been doing that for a little over 40 years. Although I vaguely remember some 8 bit computers which had an index register. I don't know x86.
@nezbrun872
@nezbrun872 11 місяців тому
I used indirect addressing in assembler for some years before I realised I was using pointers, when I did a Pascal course around 1984.
@DavesGarage
@DavesGarage 11 місяців тому
I would have struggled less in the beginning if someone would have told me that a pointer is like 6502 zero page!
@toby9999
@toby9999 11 місяців тому
​@@DavesGarageI programmed the 6502 way back in the 80s, but I didn't have an assembler. I did everything directly in hex op codes etc. But that stuff definitely helped me later with pointers in C i.e. they're just memory addresses as you said.
@vk3fbab
@vk3fbab 11 місяців тому
Dad's should teach assembly language to their children. I think of it like the Latin of computer languages. You learn about how the computer actually works and appreciate all of the things that come along for free with the HLLs that you will use. You also see pointers in things like the aptly named Stack Pointer and the Instruction Pointer. You also see function pointers in vector tables. Assembly is cumbersome but you learn so much by doing just a little bit.
@mossi5976
@mossi5976 8 місяців тому
That analogy between memory address and the address of a house is great! I used to make similar comparisons when teaching C to students and it really seemed to help make it click for them.
@hookahtagen5421
@hookahtagen5421 4 місяці тому
I'm 12 years into programming now... And i just understood the concept now, with that analoy :D
@lukas-kevynmuller6697
@lukas-kevynmuller6697 3 місяці тому
as if you never heard that analogy before. that analogy was in every tutorial I've seen.
@greg4367
@greg4367 11 місяців тому
Dave, i have been coding in C since 1980 and have, many times, tried with variable success to explain pointers to newbies. This video is clearer and more concise then my best efforts. Going forward I'm just going to refer newbies to this. Thanks.
@DavesGarage
@DavesGarage 11 місяців тому
Hope it helps others!
@johannesschneider1784
@johannesschneider1784 10 місяців тому
This is the most amazingly coherent, clear and informative explanation of pointers I have seen in 14 years since I started programming in C and C++. This is beyond fantastic omg please continue. :)
@thegame4027
@thegame4027 11 місяців тому
Its a great video if you understand pointers but it fails to do the most important part of why people don't understand pointers. People don't understand pointers because they don't understand the problem they are solving. The moment you understand how memory works, how data is stored/loaded in/from memory and what the cpu has to do differently depending on if you call by reference or by value is the moment you get pointers. The real explanation needed is not what pointers are but what problem they solve and why you need them. Back when i was learning C i had a hard time wrapping my head around pointers until one day my boss took an houre to explain the difference. He showed me the assembler output of different scenarios with and without pointers and explained what happened on each line inside the cpu and memory and it just all made sense after that. It's not about what pointers are but what problem they solve and how.
@vcv6560
@vcv6560 11 місяців тому
Assembly is a lost art, but explains so much.
@lukas-kevynmuller6697
@lukas-kevynmuller6697 3 місяці тому
this
@mahee96
@mahee96 Місяць тому
Yeah assembly could have explained it simply.. You have Registers, and direct/indirect addressing… all registers can be pointers unless they all are general purpose registers Then the addressing and instructions decide how we are representing the registers LA R1,=A(0000) Load address of location where =A(0000) has been resolved in the executable, into Register 1 XC 4(256, R1), 4(R1) XOR 256 bytes starting from values pointed by R1 offset by +4 bytes with the same… (XOR of itself is 0 ie clearing all the bits/bytes at that location) ST R1,INT32 Store value in R1 into location INT32 L R3,INT32 Load value at INT32 into R3 LA R4,INT32 Load absolute address of symbol INT32 into R4 ST R3, 0(R4) Store R3 into INT32 symbol location INT32 DS 4F Someone who knows assembly should be able to teach pointers in a better way
@yoshi4980
@yoshi4980 11 місяців тому
i was a TA for an intro to C class, and the house example was what i used to describe pointers to people really confused about them. glad to see that you are using a similar example here! i feel that the easiest way to describe technical concepts to people who are confused about them(or have no technical experience/knowledge) is to use a real world analogy, even if it oversimplifies what is actually going on. once they understand the analogy and how it relates to the technical concept, then they can get to the nitty gritty of understanding the technical details behind the concept
@tangiblewaves3581
@tangiblewaves3581 10 місяців тому
Hi Dave, I discovered your channel a few days ago and enjoyed some windows related vids; today I wanted to improve my understanding of C pointers and, voila, here you are again! I looked at some other tutorials, but yours is definitely the best! I really love your style! Keep up your great work; it's pure gold! ❤
@connecticutaggie
@connecticutaggie 10 місяців тому
Wow, 40 years ago I was still programming Fortran and had never heard of object oriented programming. At the time I was designing a production program to run various tests on pacemakers and since all the tests had some shared behavior (like limits checking, saving results to a database, printing results, etc.), I decided to create a large common block array that was indexed by something I called a "test number" then functions could do what they needed with just a test number. One huge advantage was that I could configure what tests to run and what limits to use and units to report with a big constant array at the top of the code. This meant that when a new test specification came out, usually all I had to do was to change the constant array and no code change was required. Later on in my career my SW boss told me I had created Object Oriented Fortran. Interesting - I was just a young "lazy" programmer trying to find a way to do more with less code to develop, debug, and validate. Also, being ADD, my brain worked faster than my fingers.
@tangiblewaves3581
@tangiblewaves3581 10 місяців тому
Haha, all programmers are lazy; this is what drives the development of technologies, languages and so on!
@theMaizeOfficial
@theMaizeOfficial 10 місяців тому
@@tangiblewaves3581 well i agree but i dont agree, i think we always find shorter ways to do things and yes we develop wicked tech from it, but programming its self can be very intensive / labor intensive. And takes a lat of work even to learn, so i get what your saying, but programmers are just like any trade (plumbers, electricians) and just like those trades look for better ways. I have a family full of trades, and they are full of unique (what i would call lazy) ways to fix stuff but it works and they have good solid reputations for the work they do, sometimes its those ways that make a completely new product that works 10x what the previous method is, but it takes knowledge and the skill to think it through (and sometimes the balls to apply the fix lol and hope it works.) just like them, programmers, designers and scientist need to sometimes "go back to simple" in order to step forward. All that said... i have seen lazy programmers and lazy plumbers. so i think the ratio is likely the same in terms of avoidance of physical labor. o7
@OneMilian
@OneMilian 9 місяців тому
@@theMaizeOfficial exactly, and if you want to code proffessional, you also need some good amount of discipline to code even when you have a bad day or are tired.
@atlantic_love
@atlantic_love 6 місяців тому
Cool story.
@elpatosilva
@elpatosilva 3 місяці тому
A good programmer is that who will spend 3 hour of his time to automate a one time task that requires half an hour to be made manually.
@JamesLatimer
@JamesLatimer 11 місяців тому
Wow. This made a whole lot more sense to me by the end. Thanks Dave!
@ochbad
@ochbad 11 місяців тому
Thanks for making this video! I still remember the exact ‘ahah’ moment (two decades ago in freshman cs) when I grokked c memory (pointers, arrays, structures). Learning how c handles memory really helped me understand how computers work.
@jimwinchester339
@jimwinchester339 10 місяців тому
Good video, Dave. I also have been working in C/C++ for about 40 years, including work for some notable compiler vendors such as C86, Zortech C++, and GCC (via Cygnus). This was IMO an uncommonly clear and well-organized presentation. Was impressed that you had time to include pointer-to-functions in this 14-minute overview. Perhaps you might have mentioned the precise prototype matching required to do real-world useful work involving pointer-to-functions; and in particular, how judicious use usually warrants declaring a typedef for a particular group of related pointers-to-functions.
@AusSkiller
@AusSkiller 11 місяців тому
Pointers were so logical and intuitive for me. When I was first learning C++ I was coming from having played around with languages that didn't have dynamic allocation, I didn't know what dynamic allocation was at the time but I had been frustrated in numerous projects I had made that I couldn't make new variables at runtime. So when I first read an example of malloc and using a pointer I immediately put down the book (before even reading the explanation of the example) because I had recognized it as the solution to what I had wanted for so long and wrote a linked list (not that I knew that it was a linked list at the time) to verify that it could do exactly what I had hoped it could, and it worked. I was so excited, the possibilities of pointers were limitless in my eyes and I messed around with them for most of the rest of the day. When I finally got back to reading the book that I was using to learn C++ I was a little disappointed to learn that everything I thought I had created to use pointers for was pretty much covered in the next chapter, but I was glad that at least I had understood them well enough that I could correctly extrapolate their uses without knowing much more than that they existed. It also turned out the example was only the first half of the program that only covered allocation, it wasn't until I turned the page to see the deallocation example and read the explanation for it that I realized all the horrors of memory leaks and how many I must have created that day 😉
@IBelieveInCode
@IBelieveInCode 11 місяців тому
"having played around with languages that didn't have dynamic allocation" Cobol ?
@AusSkiller
@AusSkiller 11 місяців тому
@@IBelieveInCode Logo and Visual Basic, though I was very young at the time and no internet so I might just not have been aware if they actually did have that capability.
@TehIdiotOne
@TehIdiotOne 10 місяців тому
Honestly i don't have any problems at all understanding the concept of pointers, all that makes sense to me. What i don't understand, is when you want to use them
@bkw777
@bkw777 6 місяців тому
Maybe that is the right way to tech the concept, is to pose problems that require the indirection to do the job. A lot of things are easy if the person thinks it was their own idea or something they want rather than something imposed from outside. Get them to say for themselves "what I really need is some way to ..."
@soooslaaal8204
@soooslaaal8204 5 місяців тому
@@TehIdiotOne as said on this video, the most common use is with larger or variable data types like objects, it is much more efficient to point to the adress of an object than bring the entire object into memory, this is especially noteworthy in C++ when storing lists of large objects or integers, you just use the pointer and the -> operator and it is way more memory efficient. Plus, it allows for dynamic memory allocation which allows to manage what is and what isn't in memory at any given time
@mrcrackerist
@mrcrackerist 11 місяців тому
You can also subtract a end pointer from a start pointer to get the length of data or string. As for void pointer if you use the same format for all your structs then a uin64_t in the beginning can be used to identify the data type.
@scottcooper3107
@scottcooper3107 11 місяців тому
Thanks! Very Helpful. You explained some things that C++ books that I have read have overlooked. Like ..... The reason why we even need to use pointers to begin with. I hope to see more content like this.
@alrutto
@alrutto 9 місяців тому
Thanks for this, Dave. I led the way you explained and the examples. I hope this C/C++ videos keep coming :)
@morrick
@morrick 11 місяців тому
I have always struggled with this. Dave, your explanation is the best I've ever heard and it worked for me! Like you say "it clicked"!
@Evilive15
@Evilive15 9 місяців тому
Such a good video Dave, straight to the point. much love from Argentina!
@mathiasdreke180
@mathiasdreke180 11 місяців тому
Thanks for your programming content! I have been a programmer for a while but nowadays information technology seems much too complex for me. I cannot code for real but I can follow your explanations and understand them. It's just I have problems memorizing them. So I consider your videos a source of sophisticated entertainment.
@twm4259
@twm4259 11 місяців тому
BYOB - Bring Your Own Bytes?
@possumcode
@possumcode 10 місяців тому
Let me speak from my heart =) This description was absolutely incredible! I wish I've had it about 5 years ago..
@cd860viu
@cd860viu 11 місяців тому
I've been (slowly) learning C as my starting language just for fun. Pointers has given me many headaches and I still can't completely get a picture in my head of how they work. I wish sometimes that they had a special name or different symbol, maybe that would've made it easier. But you mentioned a few things (that I had to listen to 3-4 times) that gave me some better insight, so maybe one day. Thanks!
@olafzijnbuis
@olafzijnbuis 11 місяців тому
Making a drawing of it often helps a lot.
@bob_mosavo
@bob_mosavo 11 місяців тому
Hang in there! You'll understand them 👍
@newmonengineering
@newmonengineering 11 місяців тому
C and C++ learning is like this: you learn the basics and start writing. Then you want to do more or understand someone else's code, at that point you go through 3 to 6 months of FOG where you don't quite get it, but you keep trying. The good news is once you get past that, you become a decent programmer.
@cd860viu
@cd860viu 11 місяців тому
@@newmonengineering I basically set out to make a reasonably simple game and by using reference code from others or books I've managed to piece things together bit by bit. By interpreting compiler errors I've managed to kind of get a feeling for when it's in need of a pointer or not. So I definitely know more now than half a year ago luckily :)
@morgengabe1
@morgengabe1 11 місяців тому
I think C started a bad pattern for working with pointers because you declare one with the same symbol you use to dereference one. That said the arrow operator has some, as of yet untapped, potential for conveying ownership semantics needed for automated resource management (at the cost of the control C devs freak over :p)
@jeffsmith1798
@jeffsmith1798 4 місяці тому
Thanks for the pointers, Dave!
@Horendus123
@Horendus123 10 місяців тому
Thank you so much for putting together such a great video on pointers. I’ve watched it twice and I plan to watch it three or four more times until I understand every single concept of gone over here. The function pointers are still a mystery to me how I would use those affectively
@andtpfack8243
@andtpfack8243 11 місяців тому
Great video. Straight to the point, easy to follow along.
@TheIllerX
@TheIllerX 4 місяці тому
Very clear introduction to the most important things about pointers. Remember struggling a lot with those when I started using C++.
@TheAndjelika
@TheAndjelika 11 місяців тому
Dear Dave, you said something really wonderful. When you want to learn C++ or C but your first language is Python, of course, it looks scary. That is what I can hear from a lot of students who are honestly scared to delve into low-level languages and learn how "motor" actually works. Since I am a child of the 80s, my first language was machine code and assembler for 8-bit CPUs. As such, I always try to explain things from that perspective, emphasizing memory and how the CPU "crawls" through it. Thank you for this episode. I truly believe it is important. Greetings from the Netherlands.
@nezbrun872
@nezbrun872 11 місяців тому
As a veteran assembler and C programmer of over 45 years, I can tell you that Python is scary to me. I seem to spend more time maintaining a working development environment than I do writing code in Python.
@Sauvenil
@Sauvenil 11 місяців тому
@@nezbrun872 That sounds kind of disgusting. I've never dived into Python. I started with C64 BASIC and jumped to machine code after that. A few years later when I got into college I got introduced to Pascal. After that I pretty much went into C, because I was fascinated with MUDs and wanted to learn how to run one and modify it.
@loc4725
@loc4725 11 місяців тому
I was once in a class where students first learned Visual Basic and then moved on to Java. And I can say that Dijkstra was right, learning this way actually harms students.
@TheAndjelika
@TheAndjelika 11 місяців тому
@@nezbrun872 Dear, I totally agree with you. You have less control on data flow. Young people who are using languages as Python, then just don't think about memory, about what is going on behind.They rely on some, what they call - libraries, but it is more like the whole Lego block, framework. For me library is part of the OS or what I build for myself (: I'm glad there are more people who feel the same. Thank you for sharing!
@Thatdavemarsh
@Thatdavemarsh 11 місяців тому
@@TheAndjelika ...and this is why my windows machine uses 7GB of memory after just booting....
@andreipriboi8373
@andreipriboi8373 10 місяців тому
one of the best videos on this topic in my opinion. thank you!
@onejdc
@onejdc 11 місяців тому
Two follow-up tips: The & (address-of operator) is used when you want to turn the address value of something into a pointer. Second, you will sometimes see that asterisk * in different places between the type and the pointer name: e.g. int* a; int * a; int *a; int (*a); ... all of these are exactly the same. The whitespace doesn't mean anything in these examples. That took me forever to understand. Just try to be consistent in code.
@JamieT1986
@JamieT1986 10 місяців тому
int* should be the only way to write int pointer.. everything else should be banned 😄😄 To me it makes the most sense. The type is an "int pointer" so put it with the type name... I think it's confusing for beginners because it looks similar to the dereferencing syntax.
@vaakdemandante8772
@vaakdemandante8772 10 місяців тому
@@JamieT1986 yes, but then a declaration in 4:07 would create 2 pointers, not one. int * x, y is in actuality: int *x AND int y. I agree it would be better to just have something like 'intP x, int y' and then it would be obvious what is a pointer and what isn't but we got stuck with a syntax that is efficient for writing, but hard for reading - somewhat opposite to Python's syntax.
@JamieT1986
@JamieT1986 10 місяців тому
@@vaakdemandante8772 int* x, y; is something I was a little skeptical about actually when I saw this. I never knew that's how it worked, and I forgot to test it myself. I will assume it's correct... but yeah that kinda screws it up! :)
@jeromearenas8028
@jeromearenas8028 10 місяців тому
"int \*num" is much better, the declaration in 4:07 is confusing if you use the "type\* var" version. Edit: I used "\" sign cuz youtube comments converts asterisk to bold letters. lol
@tristennollman5344
@tristennollman5344 10 місяців тому
This^^^ i would say, find a style and stick to it, but as an OS and firmware dev the most common style i come across (and use personally) is this: Type* var_name = ….whatever here…. Ex: int* pointer_to_integer = (int*)malloc(sizeof(int)); So the asterisk essentially lives right next to the type, with no whitespace between. This makes it clear that it is a POINTER of said type, in my example a pointer to an ‘int’ Using this style consistently makes reading and reasoning about pointers much less frustrating in my opinion. Of course, then there is dereferencing a pointer to get the object’s value. In those cases common style i see and use is this, continuing with my int example: int integer_variable = *pointer_to_integer; So we use the asterisk right against the VARIABLE NAME to dereference it. The combination of sticking to these two basic style guidelines makes points way less messy. Essentially, use the asterisk directly next to your type name when declaring a pointer variable, and right next to the variable name when de-referencing it. Hope this helps some of the less experienced! Also, as a follow up, i think the example at 4:07 of Int* x, y Is a kind of poor example. It just isnt code that would fly in most (well maintained) C projects like the linux kernel for example. You want things to be CLEAR above all else, and so its not really much effort to be explicit with each variable declaration. The compiler can optimize for you if it is necessary or possible. Otherwise, be more verbose in an effort for future contributors to have an easier time grasping what your code is doing. Little syntax tricks like that can be neat, but often fall flat in well maintained project environments with C.
@rahulbeniwal6321
@rahulbeniwal6321 5 місяців тому
Thanks Dave for revising my C concept. Last time when I did was solving exercise of K&R in 1 st year of graduation. Clap for your line "I am not here to sell anything".
@connorhillen
@connorhillen 9 місяців тому
I recently started teaching the introduction system's programming course at my university, and this should make for a great review resource going forward, thank you for this and the many great videos!
@fgelana
@fgelana 11 місяців тому
Thanks Dave!! I am learning C++ and pointers where the most challenging part. This was a great help.
@fastestdraw
@fastestdraw 10 місяців тому
This is really, really helpful. You have a talent for explaining things.
@buttforce4208
@buttforce4208 10 місяців тому
Love this, thanks Dave!
@TheFeralEngineer
@TheFeralEngineer 10 місяців тому
I've been waiting for you to dive into programming like this... Did not disappoint. Bravo 👏👏👏👏
@waynec369
@waynec369 11 місяців тому
Thanks, Dave! This is what I'm talking about! Coverage of more advanced C/Cpp topics. Please keep up with explaining some applications where the topic-of-the-day is used. I will say again, your knowledge should be memorized in a book. I would buy two!
@derekchristenson5711
@derekchristenson5711 10 місяців тому
That's a very nice refresher on pointers. Thank you!
@potatoplays2
@potatoplays2 10 місяців тому
Thank you for such a clear explanation I have a project coming up for implementing data types so this really helps
@robertbruce7686
@robertbruce7686 11 місяців тому
Excellent! My best saga was creating a pointer to an array of functions (oh what fun) 😆
@user-wt7pq5qc2q
@user-wt7pq5qc2q 11 місяців тому
Awesome !! I now understand pointers better than I ever had. Thanks
@Gorgutzdaboss
@Gorgutzdaboss 11 місяців тому
Starting with C and fiddling with memory made understanding how more higher level language handle memory / what is passed by reference vs value.
@suvetar
@suvetar 5 місяців тому
Man, I could have used such a good explanation 30 years ago!! Thank you Dave!
@gregledbetter5942
@gregledbetter5942 8 місяців тому
This was good for me thank you Dave
@MyCodingDiarie
@MyCodingDiarie 11 місяців тому
This video is exactly what I was looking for to help me improve my programming skills. Thank you for making it!⭐♥
@vcv6560
@vcv6560 11 місяців тому
My experience with pointers came with my first programming being PDP-11 assembly (school) and later 6502. So dealing with them in 'C was very straightforward...after the syntax of course. I say that because your comment about 'decorating the variable' rather than the type, (int* x is not int *x) was my personal stumbling block.
@pharoah327
@pharoah327 11 місяців тому
I hit "thumbs up" on the video for the thumbnail alone, lol.
@BogdanSerban
@BogdanSerban 11 місяців тому
I understood the point of pointers when I tried to access registers in a microcontroller. And to this day it makes the most sense of using them.
@juliusfucik4011
@juliusfucik4011 11 місяців тому
I started learning Turbo Pascal in the mid 90s, so for me pointers where never really hard to grasp as TP uses them too. Once you have the concept in your head a pointer to an array of pointers becomes a natural thing to work with. Great video!
@fadichamieh
@fadichamieh 11 місяців тому
We are that old, eh?
@nezbrun872
@nezbrun872 11 місяців тому
I first used pointers in Pascal on a mini computer in the mid 80s, and then Turbo Pascal in 1986, although I was also an assembler programmer before that, where you use pointers all the time but call it indirect addressing. Pascal taught me about structures. Then I went onto C, but it was K&R, and I found the nomenclature hard to follow: it took me months to get proficient, not because I didn't understand the concepts, but because K&R C can be super impenetrable for a C noob. Thankfully ANSI C came along at just the right time, I re-wrote the K&R code I was maintaining in ANSI, and I've stuck with that ever since. C remains my language of choice to this day, but mostly I'm a deeply embedded systems programmer and mixed signal hardware engineer, where C sits well, nice and close to the hardware. I dip into assembler still every now and again for those pinch points, but 99% is C.
@johanloubser8138
@johanloubser8138 10 місяців тому
​@nezbrun872 I literally use Delphi for fun nowadays, with a free Community license. It's pretty fun tbh
@freddybronson5410
@freddybronson5410 2 місяці тому
Absolutely fascinating video!
@ElliotAlderson835
@ElliotAlderson835 9 місяців тому
That was so good and so well explained 👏❤
@kisungyou6505
@kisungyou6505 10 місяців тому
Your video encouraged me to Go Pointers again! Thanks!
@cyndicorinne
@cyndicorinne 10 місяців тому
30 years ago I learned about pointers in C, and I’m grateful for this recap. Some things made more sense even now, after watching this, particularly the double indirection.
@joshismyhandle
@joshismyhandle 10 місяців тому
Thanks Dave, helpful stuff
@SimonWahlin
@SimonWahlin 8 місяців тому
There's an audio book coming? Wow! Can't wait! Have the physical book and love it so far, but finding time and mood for sitting down to read on paper is hard.
@outsideworld76
@outsideworld76 4 місяці тому
Picked up writing some code for microcontrollers, my C is a bit rusty so these video's are very welcome.
@PianoJoe822
@PianoJoe822 6 місяців тому
Very helpful video, thank you!
@kencreten7308
@kencreten7308 11 місяців тому
Master Pointers! I've been waiting for him!
@LiviuGelea
@LiviuGelea 11 місяців тому
I learnt about pointers in high school. Having programmed in a higher level language for the next decade or so I really never needed them except for knowing they’re really what's used under the hood for all the syntactic sugar I grew accustomed to. What clicked for me was when, trained to use polymorphism I tried to obtain the same result in c++ embedded only to realize you cannot send daya structes of different sizes to same function. Using pointers was the solution for passing different implementations of an interface of varying byte sizes.
@B-a_s-H
@B-a_s-H 11 місяців тому
[C]lear and straight to the point(er). 🎯
@komivalentine3067
@komivalentine3067 11 місяців тому
Thank you this really helps me get started with C++ ❤
@sjfsr
@sjfsr 8 місяців тому
Great explanation.
@Sauvenil
@Sauvenil 11 місяців тому
Once the light bulb went on in my head, it was mind-blowing. I was obsessed with it for months afterward.
@manfredrichtoften8848
@manfredrichtoften8848 15 днів тому
Holy mackrel I don't think I ever rewatched a single video consequtivelt as this. Sir, in 12 minutes, you explained pointers better than my professor in an hour and a half.
@NevosLP
@NevosLP 9 місяців тому
This is actually pretty good. Until recently I had also been learning C and while it takes quite a bit longer to become proficient in it than I have, this talk about many pitfalls in that many beginners in that language fall into. While it's not the most convenient language to learn, it's still really useful in giving you an idea about how certain parts of computers work and hopefully let you learn higher level languages as well. I tend to agree that a bottom up learning pattern is better than bottom down, so even if you're not too interested in C, it's still a useful language to know, at least generally, even if you're not proficient in it. A lot of things in Programming are still based on it and it would just be weird if a proper programmer didn't know certain basic things about programming that you learn in C, even if you don't directly need it these days. Keep ad it, I struggled at first too but once you get the hang of it, you'll wonder how you ever had troubles with it. If you're into it, programming can be a great thing, especially for people that like more practical uses of math but also many people in general. It's not nearly as rigid and a lot more creative than many like to think. So even if someone isn't that much into math, it can still be pretty nice to learn and use. Solving some of those problems you'll end up encountering, requires often a lot more than just purely logical, mathematical thinking, even if tends to be the basis of it. There's lots of creativitiy to be found in programming.
@StaticBlaster
@StaticBlaster 3 місяці тому
Thanks for the pointers.
@andrewsmilie140
@andrewsmilie140 11 місяців тому
On the first example, it is important to note the memory address needs to be casted to a byte pointer. When I was learning, this confused me a bit, especially when working with custom types. You can have an entire buffer filled with data which looks random, but if you cast it to the correct type when dereferencing, all values in the custom structure are magically decoded, and it is extremely fast!
@DavesGarage
@DavesGarage 11 місяців тому
You're right, I remember "struct IntuitionBase * pIntuitionBase = (struct IntuitionBase *) LoadLibrary(:...)" is what threw me the first time!
@Felice_Enellen
@Felice_Enellen 11 місяців тому
@@DavesGarage We really needed the modern version of the auto keyword back on the Amiga. 80 columns only go so far.
@llothar68
@llothar68 10 місяців тому
Because i guess you did not start with assembly langauge. This was my 2nd language after Basic .... like all teenagers in the early 1980s home computer time. Feeling sad for the current generation that think it's not only magic but black magic.
@andrewsmilie140
@andrewsmilie140 10 місяців тому
@@llothar68 actually, in my Electrical Engineering curriculum in 1999 I took a class in ANSI C in Unix and an Assembly class. In the Assembly class I wrote a 8088 CPU emulator, which was both frustrating and fun! I ended up using assembly programming PIC microcontrollers more than anything else. I used the term “magic” because I know what it is doing under the hood for me, and how much effort the C language saves us rather than writing in pure assembly! Cheers! Edit: it was the 8080, not the 8088-long time ago and I have lost the floppy disk where I had a backup. Oh well…. My degree is in Electrical and Computer Engineering (ECE) and I took quite a bit of digital design classes, focusing more on hardware than software.
@jordixboy
@jordixboy 10 місяців тому
@@llothar68 im self taugh software engineer, i did not went to cs, and I know this stuff, cause I love digging deep, no need to feel sorry. most of these jobs doesnt require this knowledge, yo ucan still learn it as hobby
@InterestingTed
@InterestingTed 3 місяці тому
This is very helpful. Thank you!
@theunseenandseen
@theunseenandseen 10 місяців тому
great video; keep them coming
@guilherme5094
@guilherme5094 11 місяців тому
👍👍Thanks Dave!
@FabricioRWitt
@FabricioRWitt 6 місяців тому
Legendary explanation.
@sjoervanderploeg4340
@sjoervanderploeg4340 11 місяців тому
I love these C episodes!
@frankdearr2772
@frankdearr2772 Місяць тому
Great topic, thanks 👍
@stevenlynch3456
@stevenlynch3456 8 місяців тому
One extremely important fundamental point that I am very surprised you didn't mention: The reason why pointers have types to begin with. Void pointers (void*) exist because data is inherently typeless. Is the binary number 01001001 11001111 00000000 11111111 an integer or an unsigned integer or 2 shorts or 4 chars? There's no way to know by the data alone. You have to assign meaning to it. Incrementing/decrementing pointers (like `int a = 5; int* ptr = a; a+=1;`) can be confusing at first because the compiler uses the pointer's type to figure out how many bytes to increment/decrement. Incrementing an int pointer by 1 means "move the pointer by the size of one int (4 bytes)", NOT "move the pointer 1 byte". `a += 16;` == "move the pointer by 16 units of its type" == "move the pointer by 16*sizeof(a)_inBytes" == "move the pointer by 16*4 bytes" "Dereferencing a pointer" means to use the memory location that the pointer is storing, **then actually go to that location, returning the value at that location**. Example: int b = 64; int* ptrToB = nullptr; //Declare the pointer, initializing it to a safe NULL (but with pointer type instead of value type). ptrToB = &b; //Reinitialize the pointer. `&b` means "get the memory address of where b is stored". //Compiler determines the memory address of b, so we can't tell what it is without compiling. int valOfB = *ptrToB; //Dereferencing the pointer, which only ever happens after the pointer is declared ***and*** initialized. //valOfB == 64 **Memory is classified in bytes** and not 4-byte ints or 8-byte longs or anything else is because the *hardware itself is only accessible by entire bytes* (this is sometimes untrue, depending on the computer architecture, meaning sometimes the smallest accessible data is 4-bytes (some 32-bit architectures) or even 8-bytes long (some 64-bit architectures), both of them called a *word*). No modern computer can access each individual bit because that would require too much addressing-data. So how do we not waste 7 bits of memory every time we only need a single bit? Modifying individual bits requires pulling in an entire byte, applying bitwise operation(s) to the entire byte, then storing back the entire modified byte. This way, we can store 8 bools in a single byte instead of needing 8 bytes (but you'll always need at least one byte for a single bool). int a = 5; //ints are usually 4 bytes, meaning a=4+1=2^2+2^0 = 00000000 00000000 00000000 00000101 //The OS has allocated 4 contiguous bytes SOMEWHERE in memory to copy the binary version of the # 5 into. //The OS knew it had to allocate EXACTLY 4 bytes and not only 1 or 1,000 bytes because the compiler knows that //ints are 4 bytes. int* ptr = a; //Go to get the BYTE address that the int `a` will start getting read at. Anytime the pointer `ptr` is used in the future, //the compiler and hence the OS knows to read three more bytes after the initial address of `ptr` (4 bytes total). So, **why do we assign types to pointers?** It's NOT to tell the compiler the size of the pointer itself (which is always the same size on a given system, like how an int is always 4 bytes on the same system), BUT IT IS to **let the compiler know how many bytes to read after the pointer's stored location**.
@SandorPipei
@SandorPipei 11 місяців тому
5:41 The -> pointer "dereference operator" is the shorthand variant for (*struct_name).member e.g. (*pHouse).SquareFeet 11:00 Usually when we program in C without classes ,we are using malloc. In C with classes (C++) we use new. Syntactically are both correct but new is safer. 2:58 Hardware registers or memory locations (physical memory locations on a CPU without MPU/MMU) can be accessed using a single line of code like *(byte *)53281 = 0x00;
@nezbrun872
@nezbrun872 11 місяців тому
"Usually when we program in C without classes ,we are using malloc" It depends on the platform and application: in embedded microcontroller applications, which are typically memory constrained. would fail catastrophically in the event of failure, so malloc is rarely used in production hardware. As a result, memory and objects are typically allocated statically, or on the stack (typically small objects only on the stack).
@danielrhouck
@danielrhouck 11 місяців тому
Calling C++ “C with Classes” is sort of like calling Firefox “Netscape Navigator”. Or maybe like calling Windows “MS-DOS 1.0”.
@JohnDoe-kh3hy
@JohnDoe-kh3hy 11 місяців тому
@@danielrhouck It is something common among C (ansi, K&R, 90, etc) fans.
@danielrhouck
@danielrhouck 11 місяців тому
@@JohnDoe-kh3hy Classes are one of the *many* things C++ does differently than C, and they are *not* the most important one to this discussion.
@toby9999
@toby9999 11 місяців тому
​@@danielrhouckNot really. Stroustrup referred to C++ as "C with classes". If it's good enough for him, it's good enough for me. It's a nice succinct way to describe the language conceptually.
@Upsilon-gb6ch
@Upsilon-gb6ch 4 місяці тому
very good explanation. especially the function pointer part.
@arondsouza3568
@arondsouza3568 3 місяці тому
great explanation mr. dave
@eramires
@eramires 6 місяців тому
Thanks for this, I always had pointers as something nasty but this video helped me. :D
@MrMalchore
@MrMalchore 11 місяців тому
I once had to create an array of function pointers. I remember nearly going blind with the syntactic gynastics that was required to create the thing and actually use it without leading to memory leaks. That was some 30 years ago, when I was programming embedded systems. Anyways, I strongly agree that mastering pointer syntax is important to improve your code READING skill. Oh, yah, and I heavily commented all that code. I typcially had more comments in my code then code, but I recall going way overboard commenting that code.
@patrickstival6179
@patrickstival6179 10 місяців тому
Nice one. I found this video easy to grasp
@hawks3109
@hawks3109 9 місяців тому
We use pointers for everything at work. I mean EVERYTHING. Network structs? Passed around everywhere as pointers. Passing around random data structures that you don't define until runtime? Void pointers. Needing to access a player and all their information if building video games? Pass around const refs to the player
@saberlite8809
@saberlite8809 10 місяців тому
You look exactly like a person who would teach me about pointers. Just like a Wizard NPC in games.
@Fernando-du5uj
@Fernando-du5uj 6 місяців тому
Thanks alot, sir!
@SpinStar1956
@SpinStar1956 11 місяців тому
Even though I come from TTL and then Assembly, I’ve always had inordinate amounts of trouble with symbology involving assembler-directives, figuring out other peoples UIs and pointer notation. 😢 Maybe I’ve been living on the ‘Spectrum’ all along 😂 Thanks for the video and clearing up some of the confusion with the notation! 😊
@subhranshudas8862
@subhranshudas8862 10 місяців тому
Feels like a PBS documentary. love it.
@radosmirkovic8371
@radosmirkovic8371 2 місяці тому
Excellent tutorial
@alphabasic1759
@alphabasic1759 4 місяці тому
Your history with C is almost exactly the same as mine. Love C
@malectric
@malectric 8 місяців тому
I got my first taste of this type of pointer use (outside of assembly language) when I had to learn Modula-2. Thankfully it was a realtively small leap from there to using them effectively in C but the pointer declaration and use nomenclature in C was a bit confusing. This was very helpful thanks.
@syrus3k
@syrus3k 11 місяців тому
Pointers are one of those things that isn't complicated but sounds complicated because hard to explain
@9adamlevin
@9adamlevin 10 місяців тому
6 years of college working in C++ and i had never even heard about function pointers, thanks for showing me something i didn't even think was possible!
@Hennue
@Hennue 10 місяців тому
Function pointers are kindof the origin of object oriented programming. You would create a struct with function pointers as member variables. Then a "constructor-like" function could initialize the struct with the desired functions and voilá you have a class. C++ started out as a transpiler to C and, I might be wrong on this part, that is how i think it translated c++ classes into c structs.
@PiotrPilinko
@PiotrPilinko 27 днів тому
Function pointers are currently almost not used (directly) in modern c++ (of course they exist and can be used if needed): most of the functionality was moved into lamba/function objects which is more robust and powerful solution (with some small problems). Also operators new/delete should not be directly used (as smart pointers are better option with make_shared and make_unique templates).
@generovinsky
@generovinsky 10 місяців тому
thanks for the pointers dave ;P
@MyMy-tv7fd
@MyMy-tv7fd 11 місяців тому
good stuff Dave
@AnExPor
@AnExPor Місяць тому
I love function pointers. I thought that was the coolest shit when I was studying CS in college.
@me0262
@me0262 10 місяців тому
Free the mallocs! Awesome video. Pointers are always misunderstood and often not done properly, they get especially finicky when you start using classes and C++ conventions, like the Trilogy of Evil (Copy, Assignment, Destructor operators) where data inside pointers has to be handled, not just the pointers themselves. One thing I came across was that in classes, you can allocate memory space with malloc, but it will not call the constructor for you. Another thing I've come across a lot when debugging is that people will call delete on the pointer when it's freed, but you also have to set the pointer to null in order to not leak that last bit of memory. One thing that needs to be taught is how to clean up after your allocations (free() and delete/delete[]). I never learned this from three separate classes, until I went for a Game Development degree at Full Sail.
@siadat
@siadat 3 місяці тому
The Commodore 64 screen background colour byte example was brilliant!
@bank8489
@bank8489 19 днів тому
THIS. this is the video that FINALLY made it click for me. thank you Dave
@drewwilson8756
@drewwilson8756 11 місяців тому
We who are about to design and build salute you!
@hanspeterbestandig2054
@hanspeterbestandig2054 10 місяців тому
Very well thank you very much Sir!
@mr_noodler
@mr_noodler 11 місяців тому
Beautiful video I enjoyed it a lot
@PaulHindt
@PaulHindt 11 місяців тому
The day I understood pointers was the day I first heard the address -> house analogy. It still took me a while beyond that to really become fluent with actually deploying the C pointer syntax, and longer still to become comfortable with pointer arithmetic.
@DavesGarage
@DavesGarage 11 місяців тому
Damn, I thought the house address analogy was original! :-)
@kristianwichmann9996
@kristianwichmann9996 11 місяців тому
The 53281 example made me nostalgic. I've only recently started coding in C, but so far pointers have seemed pretty logical to me, maybe because I grew up on constantly referencing specific addresses in memory on the C64.
@DavesGarage
@DavesGarage 11 місяців тому
I figured it'd be meaningful to a few folks :-)
@MatheusMPL
@MatheusMPL 8 місяців тому
I come from a C background, and when I started learning Python I thought to myself "What the hell is going on here?! This is crazy!!" 😂
E01: Stupid C++ Tricks with Dave
15:43
Dave's Garage
Переглядів 310 тис.
C++ Super Optimization: 1000X Faster
15:33
Dave's Garage
Переглядів 245 тис.
ФОКУС С ЧИПСАМИ (секрет)
00:44
Masomka
Переглядів 3,8 млн
The World's Fastest Cleaners
00:35
MrBeast
Переглядів 85 млн
Is It Possible To Code Without Variables?
8:01
ByteBlox
Переглядів 111
you will never ask about pointers again after watching this video
8:03
Low Level Learning
Переглядів 1,9 млн
Introduction to Pointers | C Programming Tutorial
24:42
Portfolio Courses
Переглядів 98 тис.
I Rewrote This Entire Main File // Code Review
16:08
The Cherno
Переглядів 73 тис.
How Creating ZIPFolders for Windows almost got me FIRED from Microsoft!
8:15
Docker vs VM:  What's the Difference, and Why You Care!
13:40
Dave's Garage
Переглядів 172 тис.
Want High Speed Fiber?  Watch this First!
18:52
Dave's Garage
Переглядів 296 тис.
why do void* pointers even exist?
8:17
Low Level Learning
Переглядів 300 тис.
everything is open source if you can reverse engineer (try it RIGHT NOW!)
13:56
Low Level Learning
Переглядів 1,2 млн
Что если бы Apple делала зубные щётки?
0:59
I wish I knew this When Istarted Programming #school #software  #codingtips
0:34
Claude Ams - Programming Guru 💻
Переглядів 7 млн
Компьютерная мышь за 50 рублей
0:28
dizzi
Переглядів 1,5 млн
Обзор Nothing ear (3) и ear (a) - ПРОРЫВ за $100
17:34