I studied computer science in high school, and we were learning about pointers a bit, but I never really got hang of what they represent, now I'm at faculty, again learning about pointers and this video helped me more than 5 hours of my class, really glad I stumbled across you, great video, great explanation.
Thank you very much for the kind feedback Dimitrije! I'm really glad to hear that this video helped you out, and that you enjoyed the explanation. Pointers are super tricky I think, many people tell me they find them to be the hardest part of understanding C. 🙂
I'm so glad they had us *take a basic computer science course prior to our C course. I think why most people find pointers confusing is because they don't know how computer memory works.
That's very true, it's very difficult to understand lower level programming languages like C without some idea as to how computers are working at the hardware level (at least, the big picture anyways). :-)
Hi sir, I am from India, There are many indian youtube channels teaching C programming , though I found your channel most helpful. Thanks for uploading this kind of detailed videos.
Your videos are absolutely perfect! Clear, to the point, easy to understand explanations, tons of examples, sweet voice, clean workspace, man I just wish I had found your channel sooner.
Thanks so much for these tutorials, it's rare to find someone who is so clear and so well organized, doesn't waste any time and also has such a huge output of free material. Thanks.
Dude…your videos are on point. Having just finished an intense course in C++ at my university but being actually more interested in C, this is a great way to both recap similar concepts that exist in both languages as well as getting started in C
Just wow ,.. I've just started learning c, but your tutorials are just exceptional in comparison to what i've been watching.. it just amazes me how your channel is underrated..
I think it's worth noting that the pointer-variable swap technique would come in handy if the structures being swapped are larger than long int data type
THANK YOU!! You are one of VERY FEW who understood how to use the SCREEN AREA properly for a screen presentation. Nice layout, easy to read font size. DOUBLE THANKS TO YOU ! :) Next... i dont know how many videos and articles about pointers in C i have seen and read...i still had trouble grasping it, since i could not align "a data type" with a plain "memory address", since these things do have nothing to do with each other to my understanding. BUT now i can see why/when the "type" starts to become useful in conjunction with a plain memory-address pointed to.
The best video ever! It has put an end to all my curiosities and given clarifications to all confusions! Thank you thank you thank you thank you sir! The examples you gave really shed enough light! God bless you hugely sir❤❤❤🙏🙏🙏🙏
You're welcome Ido! :-) And thank you very much for sharing that positive feedback with me. A big part of the reason why I love making these videos is that they might be able to help students like you, so that means a lot to me that the videos are helping you out!
This certainly helps in my understanding of pointers. I think one of the reasons that pointers have flummoxed me over the years is the notation: Using an asterisk to signal both a pointer and the mathematical operation for multiplication is confusing.
I agree the notation for pointers is confusing. 🙂 I also don't like how the * operator is used to both declare a pointer and as the dereference operator. I'm not even sure I like the name "pointers", I've found people seem to understand them better when they're called "memory addresses".
Your video's are so amazing. I am studying for a test and some of the examples from my class are in here and you explained them to me just like my professor did, or better. Thank you for making such amazing help when you need it at a moments notice.
Thank you so much for watching the videos and subscribing Kyoshi! :-) Another thing you could do to help the channel if you like is sharing the channel with others (classmates, friends, social media, etc).
Thank you. I like the use of pointers for dynamically allocating memory. I still don’t get why one would have a function change the value of a variable that is not brought into scope for that function.
Sometimes we have things like data structures that persist across a series of function calls, and what the functions work with is a pointer to that data structure in order to access it. So for an example: th-cam.com/video/YjxKYxpf51E/w-d-xo.html. It would typically be something that's pretty important to the program, to have that same state be accessed by multiple functions.
You're welcome Sidney! :-) And -> is called the arrow operator, it's for working with pointers to structs, and in some sense it is a bit like the * operator yes, it's covered in this video here: th-cam.com/video/w5XM1N7hLgc/w-d-xo.html
I would highly recommend to start off with why you need a pointer in the first place. The way it’s presented sounds like it’s just a bunch of busywork.
Thanks for the feedback Kris, I hear you. I get into this about 9:30 into the video. Normally I like to start with "why" too but in the case of pointers, 1) most people that find this video are students that are confused from trying to learn pointers from their teachers and that are looking to understand the "nuts and bolts" of what is happening, 2) it's hard to explain the use cases without explaining memory addresses and at that point I might as well explain pointers anyways. 🙂
About that issue of freeing memory after assigning it with 'Malloc (and also calloc, correct?)'- Is that memory space freed by the system after the program is closed? And it definitely would be removed after a reboot or crash of the system? Thank you
Thanks for great explanation! I know generally its not good practice but in this swap example if we save adress of x and y in "int a" and "int b" instead of "int *a" and "int *b" does this make any change?
You're welcome Tornike! :-) The parameters of the swap function do need to be int *a and int *b (i.e. pointers) for the swap to work, it won't work if they are just int a and int b, as those would int parameters and not pointers.
I think the only reason pointers are confusing is because the syntax makes little sense. There's nothing about the syntax that gives clues as to what the code does, unless you already know about pointers and their syntax.
I think the usage of * to both declare a pointer and de-reference can be confusing. I also think the syntax: int *p; is confusing because the type 'int' isn't really the type that p stores. Really, p stores a memory address, and int is the type of data that p is pointing TO, i.e. the type of data at the memory address that p is itself storing. But for regular variables, 'int' would be the type. That different can be confusing too I think. Imagine if instead we had: address p{int}; Or something like that to indicate p stores a memory address of type int. To me that, or something like it, could help. Oh well, it is what it is now! :-)
for the example at time 14:18, how does *a and *b know to reference the memory address of x and y? I thought we would first have to define that *a points to x and that *b points to y.
I have no problem understanding the concept of things, i found it really hard to develop any creative solution for problems tho, how can i improve that?
Great question Victor! :-) What you're talking about is a very common problem for computer programmers. I've created this playlist to try to start speaking to this problem: th-cam.com/play/PLA1FTfKBAEX6e_cFeqZCuUcexEJZS4OOQ.html. But the playlist is still new and I have to make more videos on that one. Essentially though, it takes time and lots and lots of practice to get better at "creating solutions". Every time we solve a problem or figure out a new program our brain adds another "solution" to a library inside our heads. When we face new problems, we look back at this "library" for help. The new problem might not be identical to old problems, but it shares common characteristics to old problems. The more problems we see and learn about the more common characteristics there will be to 'new' problems, and the easier they get to solve. There is more to it then this... we get better at debugging with experience too, for example. But this is a big part of it, just lots of experience and practice. :-)
So this is a deep copy, if not a pointer and shallow copy if a pointer within a struct? What about string literals? I guess that doesn't matter because they are immutable? Is that right?
If you have a pointer in a struct, then when you do an assignment, yes a "shallow copy" will occur as it's really only the pointer that will be copied from one struct to the next. And string literals are immutable, yes. :-)
@@edward3105 So if we had: int *a = &b; this would be equivalent to this: int *a; a = &b; I think this part of C is kind of confusing, but if we're declaring a pointer and initializing it to a memory address on the same line, then we have the * in front of the pointer variable name. And that's just because we need it there to declare it the variable as a pointer. But after we've declared a pointer, whenever we use the * with our pointer variable it works as the de-reference operator that "gets what the pointer is pointing to".
@@PortfolioCourses I kinda thought about that but in this situation like you showed in other video char *s2 =" abcdef" why I don't declare the pointer like this char *s2= &a and let's say char a[ ]= {"abcdef"}
@@edward3105 Oh so in if we have: char a[] = "abcdef"; Then a is char array that has been initialized to the string "abcdef". So.. a[0] = 'a' a[1] = 'b' .. a[5] = 'f' a[6] = '\0' And then if we want to make s2 a pointer to a in this case we would say: char *s2 = a; The reason is that arrays are different than variables. If we had: char x = 'm'; THEN we would have: char *s2 = &x; and s2 would be a pointer to the x, it would store the memory address of x. But in the case of: char a[] = "abdef"; 'a' is a char array, and when we just use the name of a char array like 'a' what we actually get is a memory address, there is no need to use the & operator. So if we have: char *s2 = a; then we would actually get s2 storing the memory address of the array 'a' (the memory address of the first char in that array) We say that the array 'decays to a pointer' in this situation. If you try this: char a[] = "abcdef"; printf("%p", a); you'll see what I mean, in that 'a' is just a memory address. So we don't need to apply the & operator to *get* the memory address like we do a variable.
Which time of the video is this? Arrays decay to pointers when used in certain ways, and pointers can be used with "array notation". This video about passing arrays to functions addresses some of this: th-cam.com/video/oe2bZKjiWrg/w-d-xo.html. As does this video on pointer notation: th-cam.com/video/hWGYBMO553A/w-d-xo.html. :-)
That's a good question Rezuwan, but it would depend on a lot of things. Like if it's the first language that someone is ever learning it will take longer than if they know other languages already. Or if they are learning it full-time vs part-time, etc. I would say C can be learned "well enough" to work in it by taking a 4 month course at a university or college, or by self-studying full-time for a month. And I would say it would take a year of really working with it on some projects to get really "good" at it, though with programming, learning never stops. :-)
malloc returns a void pointer, and in C++ it is necessary to "cast the type" (change the type) to (char *) or whatever other type of pointer your variable is... in C this isn't necessary. This answer has more details: stackoverflow.com/a/605856. And this answers explains some reasons why I don't do it: stackoverflow.com/a/605858. Maybe next class you can tell your teacher they don't need to do that. ;-)
I studied computer science in high school, and we were learning about pointers a bit, but I never really got hang of what they represent, now I'm at faculty, again learning about pointers and this video helped me more than 5 hours of my class, really glad I stumbled across you, great video, great explanation.
Thank you very much for the kind feedback Dimitrije! I'm really glad to hear that this video helped you out, and that you enjoyed the explanation. Pointers are super tricky I think, many people tell me they find them to be the hardest part of understanding C. 🙂
I'm so glad they had us *take a basic computer science course prior to our C course. I think why most people find pointers confusing is because they don't know how computer memory works.
That's very true, it's very difficult to understand lower level programming languages like C without some idea as to how computers are working at the hardware level (at least, the big picture anyways). :-)
simplest and best explanation on pointers I've found thus far....You're a life saver
I'm really glad you enjoyed it! :-)
Hi sir, I am from India, There are many indian youtube channels teaching C programming , though I found your channel most helpful. Thanks for uploading this kind of detailed videos.
Your videos are absolutely perfect! Clear, to the point, easy to understand explanations, tons of examples, sweet voice, clean workspace, man I just wish I had found your channel sooner.
I’m glad you’re enjoying the videos, thank you for the kind feedback! :-)
Thanks so much for these tutorials, it's rare to find someone who is so clear and so well organized, doesn't waste any time and also has such a huge output of free material. Thanks.
You're very welcome, thank you for sharing this positive feedback, I'm really glad that you enjoy the material! :-)
Very useful tutorial about pointers specially the `malloc` example for creating array size in the runtime
Dude…your videos are on point. Having just finished an intense course in C++ at my university but being actually more interested in C, this is a great way to both recap similar concepts that exist in both languages as well as getting started in C
That’s awesome, thank you for the positive feedback, I’m really glad to hear the videos are helping you recap concepts and get started with C! :-)
Just wow ,.. I've just started learning c, but your tutorials are just exceptional in comparison to what i've been watching.. it just amazes me how your channel is underrated..
I'm really glad that you're enjoying the content!!! :-) And thank you very much for the kind feedback, that is really motivating for me to hear that.
Possibly the best set of videos on C. Please consider doing an episode on assert() .
I think it's worth noting that the pointer-variable swap technique would come in handy if the structures being swapped are larger than long int data type
I am taking C programming class, and your videos are so helpful. thank you for sharing such great content.
You’re very welcome! :-) Thanks for sharing this feedback, I’m really glad to hear the videos are helping you out!
This video is very great. Can't believe I understood pointers and some memory related lessons. Thank you so much.
this explanation is a real life saving , thank you for your effort 😊😊
You're welcome! :-)
THANK YOU!! You are one of VERY FEW who understood how to use the SCREEN AREA properly for a screen presentation. Nice layout, easy to read font size. DOUBLE THANKS TO YOU ! :) Next... i dont know how many videos and articles about pointers in C i have seen and read...i still had trouble grasping it, since i could not align "a data type" with a plain "memory address", since these things do have nothing to do with each other to my understanding. BUT now i can see why/when the "type" starts to become useful in conjunction with a plain memory-address pointed to.
You’re very welcome Axel, I’m glad you enjoyed the presentation style and that the video was able to help you learn about pointers! :-)
This really helped me understand pointers when other resources didn’t thank you so much
You’re very welcome, I’m so glad to hear this video helped you to understand pointers! :-)
Incredibly helpful, I was having trouble wrapping my head about how these work but this video cleared it all up.
Awesome, I'm happy the video was able to help you out! :-)
Better than paid Udemy course. As clear as day!
I'm glad you enjoyed it Eldin! :-)
The best video ever! It has put an end to all my curiosities and given clarifications to all confusions! Thank you thank you thank you thank you sir! The examples you gave really shed enough light! God bless you hugely sir❤❤❤🙏🙏🙏🙏
Man I bought c course, your course 20x better
Came back to brush up, love this video!
I am passing the first semester in my school thanks to u...thanks for the free content, its very helpfull, keep i up :)
You're welcome Ido! :-) And thank you very much for sharing that positive feedback with me. A big part of the reason why I love making these videos is that they might be able to help students like you, so that means a lot to me that the videos are helping you out!
This video is what i was looking for ! , Thank you sir i really learnt a lot watching this , much love from egypt
You’re very welcome! :-) I’m so glad to hear you learned a lot watching it, much love back at you from Canada!
This certainly helps in my understanding of pointers. I think one of the reasons that pointers have flummoxed me over the years is the notation: Using an asterisk to signal both a pointer and the mathematical operation for multiplication is confusing.
I agree the notation for pointers is confusing. 🙂 I also don't like how the * operator is used to both declare a pointer and as the dereference operator. I'm not even sure I like the name "pointers", I've found people seem to understand them better when they're called "memory addresses".
@@PortfolioCourses, I guess I’ll call them memory addresses and regard pointer as a nickname. :-)
@@Mnogojazyk Hahaha 🙂
Your video was my "AHA moment" for pointers and malloc lol.
Awesome I'm glad to hear that Sami, congratulations on the 'aha moment'! :-)
I'm glad youtube existed
Your video's are so amazing. I am studying for a test and some of the examples from my class are in here and you explained them to me just like my professor did, or better. Thank you for making such amazing help when you need it at a moments notice.
You're welcome Sean, I'm very glad to hear these videos are helping you out! :-)
Thanks for the explanation really helped me understanding the concept
Thanks
Great explanation, helped me a lot. I'll be watching more of your videos for sure. Cheers!
That's awesome, I'm glad it helped you Lovro! :-)
You sir earned my respect. I watched alot of your content already. Can`t offer more than a sub , but all my thanks !
Thank you so much for watching the videos and subscribing Kyoshi! :-) Another thing you could do to help the channel if you like is sharing the channel with others (classmates, friends, social media, etc).
this video changed my life
That's excellent! :-)
man, your are the best, these video rescue me.
I’m really glad you’re enjoying the videos Abdelmuniem, thank you for sharing this kind feedback! :-)
You’re the best for sure!
Haha thank you! :-D
thank you for the class!
You're welcome Raquel! :-D
Thank you. This is very helpful.
You’re very welcome, I’m glad it was helpful for you! :-)
Very nicely explained
Thank you very much for the kind feedback. :-)
Subscribed!
🏆
Awesome, welcome aboard Ivan! :-)
Thank you. I like the use of pointers for dynamically allocating memory. I still don’t get why one would have a function change the value of a variable that is not brought into scope for that function.
Sometimes we have things like data structures that persist across a series of function calls, and what the functions work with is a pointer to that data structure in order to access it. So for an example: th-cam.com/video/YjxKYxpf51E/w-d-xo.html. It would typically be something that's pretty important to the program, to have that same state be accessed by multiple functions.
I've just noticed, you're the guy from 3Blue1Brown !!!
I've never heard of that channel before Victor, but I looked it up just now and it looks cool! :-)
Magnificent
you make amazing videos
I'm really glad to hear you enjoy them, thank you for the positive feedback! :-)
THANK YOUUUUU
Thank you so much!
You’re very welcome Tim! :-)
Thank you so much for this video! Could you explain what -> has to do with pointers? Is it a different way to express the star * operator?
You're welcome Sidney! :-) And -> is called the arrow operator, it's for working with pointers to structs, and in some sense it is a bit like the * operator yes, it's covered in this video here: th-cam.com/video/w5XM1N7hLgc/w-d-xo.html
@@PortfolioCourses This helps thank you!
I would highly recommend to start off with why you need a pointer in the first place. The way it’s presented sounds like it’s just a bunch of busywork.
Thanks for the feedback Kris, I hear you. I get into this about 9:30 into the video. Normally I like to start with "why" too but in the case of pointers, 1) most people that find this video are students that are confused from trying to learn pointers from their teachers and that are looking to understand the "nuts and bolts" of what is happening, 2) it's hard to explain the use cases without explaining memory addresses and at that point I might as well explain pointers anyways. 🙂
Top !!!
thank u portfolio u are so cool
You're welcome! :-)
good video, i like it
I'm glad you like it! :-)
About that issue of freeing memory after assigning it with 'Malloc (and also calloc, correct?)'-
Is that memory space freed by the system after the program is closed? And it definitely would be removed after a reboot or crash of the system?
Thank you
Thanks for great explanation! I know generally its not good practice but in this swap example if we save adress of x and y in "int a" and "int b" instead of "int *a" and "int *b" does this make any change?
You're welcome Tornike! :-) The parameters of the swap function do need to be int *a and int *b (i.e. pointers) for the swap to work, it won't work if they are just int a and int b, as those would int parameters and not pointers.
thanks!
You’re welcome! :-)
god bless ur heart
Thank you Marilyn! 😊
thanks helpful vid
You're welcome Krishna! :-)
I think the only reason pointers are confusing is because the syntax makes little sense. There's nothing about the syntax that gives clues as to what the code does, unless you already know about pointers and their syntax.
I think the usage of * to both declare a pointer and de-reference can be confusing. I also think the syntax:
int *p;
is confusing because the type 'int' isn't really the type that p stores. Really, p stores a memory address, and int is the type of data that p is pointing TO, i.e. the type of data at the memory address that p is itself storing. But for regular variables, 'int' would be the type. That different can be confusing too I think. Imagine if instead we had:
address p{int};
Or something like that to indicate p stores a memory address of type int. To me that, or something like it, could help. Oh well, it is what it is now! :-)
Man u r littttttttt !!!!!!!!!!!
hahaha I've never been called lit before, so thank you! :-)
for the example at time 14:18, how does *a and *b know to reference the memory address of x and y? I thought we would first have to define that *a points to x and that *b points to y.
It's because when we call swap we have: swap(&x, &y);
That will set a to point to x and b point to y. :-)
I have no problem understanding the concept of things, i found it really hard to develop any creative solution for problems tho, how can i improve that?
Great question Victor! :-) What you're talking about is a very common problem for computer programmers. I've created this playlist to try to start speaking to this problem: th-cam.com/play/PLA1FTfKBAEX6e_cFeqZCuUcexEJZS4OOQ.html. But the playlist is still new and I have to make more videos on that one. Essentially though, it takes time and lots and lots of practice to get better at "creating solutions". Every time we solve a problem or figure out a new program our brain adds another "solution" to a library inside our heads. When we face new problems, we look back at this "library" for help. The new problem might not be identical to old problems, but it shares common characteristics to old problems. The more problems we see and learn about the more common characteristics there will be to 'new' problems, and the easier they get to solve. There is more to it then this... we get better at debugging with experience too, for example. But this is a big part of it, just lots of experience and practice. :-)
So this is a deep copy, if not a pointer and shallow copy if a pointer within a struct? What about string literals? I guess that doesn't matter because they are immutable? Is that right?
If you have a pointer in a struct, then when you do an assignment, yes a "shallow copy" will occur as it's really only the pointer that will be copied from one struct to the next. And string literals are immutable, yes. :-)
I love you!
Thank you Nahuel! :-D
on this line int *a=&b; it stores the value that's on b address and not the b address right?
That will store memory address of the variable b into the pointer variable a.
@@PortfolioCourses but you placed * before a you didn't say a=&b;
@@edward3105 So if we had:
int *a = &b;
this would be equivalent to this:
int *a;
a = &b;
I think this part of C is kind of confusing, but if we're declaring a pointer and initializing it to a memory address on the same line, then we have the * in front of the pointer variable name. And that's just because we need it there to declare it the variable as a pointer.
But after we've declared a pointer, whenever we use the * with our pointer variable it works as the de-reference operator that "gets what the pointer is pointing to".
@@PortfolioCourses I kinda thought about that but in this situation like you showed in other video char *s2 =" abcdef" why I don't declare the pointer like this char *s2= &a and let's say char a[ ]= {"abcdef"}
@@edward3105 Oh so in if we have:
char a[] = "abcdef";
Then a is char array that has been initialized to the string "abcdef". So..
a[0] = 'a'
a[1] = 'b'
..
a[5] = 'f'
a[6] = '\0'
And then if we want to make s2 a pointer to a in this case we would say:
char *s2 = a;
The reason is that arrays are different than variables.
If we had:
char x = 'm';
THEN we would have:
char *s2 = &x;
and s2 would be a pointer to the x, it would store the memory address of x. But in the case of:
char a[] = "abdef";
'a' is a char array, and when we just use the name of a char array like 'a' what we actually get is a memory address, there is no need to use the & operator.
So if we have:
char *s2 = a;
then we would actually get s2 storing the memory address of the array 'a' (the memory address of the first char in that array) We say that the array 'decays to a pointer' in this situation. If you try this:
char a[] = "abcdef";
printf("%p", a);
you'll see what I mean, in that 'a' is just a memory address. So we don't need to apply the & operator to *get* the memory address like we do a variable.
so all values in that array is stored in that one memory address?
They *begin* at that one memory address, the memory address is the memory address of the first element in the array. :-)
@@PortfolioCourses oh I see, I understand now. thanks fam ^^
which compiler do you use for c
I use gcc. :-)
i'm a bit confused, towards the ending, a is a pointer, then a is also an array?
Which time of the video is this? Arrays decay to pointers when used in certain ways, and pointers can be used with "array notation". This video about passing arrays to functions addresses some of this: th-cam.com/video/oe2bZKjiWrg/w-d-xo.html. As does this video on pointer notation: th-cam.com/video/hWGYBMO553A/w-d-xo.html. :-)
For once, the software is actually really useful
I'm glad you found this useful Karan! :-)
js curious so wanted to ask you how long do u think c language takes to learn (like completely and ur good at it)
That's a good question Rezuwan, but it would depend on a lot of things. Like if it's the first language that someone is ever learning it will take longer than if they know other languages already. Or if they are learning it full-time vs part-time, etc. I would say C can be learned "well enough" to work in it by taking a 4 month course at a university or college, or by self-studying full-time for a month. And I would say it would take a year of really working with it on some projects to get really "good" at it, though with programming, learning never stops. :-)
AAAaaaaawesome ! =)
Thhhhhaaaaankk you!!! 😀
I have a question. My teacher usually writes for example word = (char *) (malloc(10*sizeof(char))
what is the (char *) for ?
malloc returns a void pointer, and in C++ it is necessary to "cast the type" (change the type) to (char *) or whatever other type of pointer your variable is... in C this isn't necessary. This answer has more details: stackoverflow.com/a/605856. And this answers explains some reasons why I don't do it: stackoverflow.com/a/605858. Maybe next class you can tell your teacher they don't need to do that. ;-)
@@PortfolioCourses thank you!
@@raquelbraunschweig2938 you're welcome! :-D
haha the meme is too accurate
I'm glad you think so too! :-)
Why i can't understand this!!! Is it because i played rdr2 for three hous before looking at this 🤠🤯
I want an Apple but I point to Banana tree...
Ah the joys of manual memory management! :-)
Sorry.
I made it half way through before I became 'bamboozled!'
😕😕
O indiano KAKAKAKAKAKAKA
A bit pointless…
Thank you very much
You’re welcome Nhật! :-)
thank you so much!
You’re very welcome! :-)