Sir. Thanks for this video. I am a Computer Science student from USA, and the only thing I can say is that my professor should be watching this video also. You saved me to complete my assingment, but the most important thing is that I finally learned the topic which is more important to me. Greetings from Miami. Best Regards
Thank you very much for all your videos. I really feel like my teacher should learn from you, it's amazing how you can, in 17 minutes, explain something she's trying to explain in 3 hours. And she fails every time. Too bad I haven't found your videos earlier! :)
SO FAR, ONE OF THE BEST EXPLANATIONS OF DYNAMIC MEMORY. MY CONCEPTS ARE TOTALLY CLEAR, ALL THANKS TO YOU :) WE USUALLY SHY AWAY OR RATHER FEAR DYNAMIC MEMORY ALLOCATION, BUT AFTER WATCHING THIS VIDEO, MY PERCEPTION HAS SURELY CHANGED.
I have learned much more from cramming to your videos in 4 hours than my university prof's teachings that stretch over months. sir mycodeschool, you is the realest
I have watched a fair amount of tutorials in a wide range of topics over the years. This series has to be, hands down, the best one there is. Amazing job dude, I sincerely hope you are a teacher because you are the natural talent.
I just wanted to say thank you! I'm relearning some stuff I'm rusty on for my new job and I appreciate greatly the fact that you share all of this knowledge for free for us.
after so many failed attempts to learn basic programmng from different platforms now i can certainly say this is one of the best platforms to learn basics thanks to entire team for making such an amazing series .
You are by far the MOST amazing teacher in TH-cam! Thank you so much. I wish you could get back here soon. We, cs students, really really need your knowledge!
I love your videos!!! My teacher from palm beach state college doesn't explain nearly as well as you and I'm so lucky to have found your vids. You're a life saver. I'm gonna spread the word so that more people can know about your vids when they are confused in C. Greetings from Boca Raton, Florida.
Thanks so much. I am a new grad to CS major and I just learn "coding" in python, matlab before in kinda math major. What we learnt about C in math major is so similar to learning python, just in another syntax, but actually they are so different! This series saved my life and really let me know deeper in C. Thanks again!
This channel is the best that I have found on these topics, thanks for sharing this. Again it proves the subject is not complex it is the way it is explained that makes it complex.
Man I am actually really impressed with this explanation usually I find TH-cam tutorials for coding super convoluted, but this one was very clear and precise. Good job
Great video ! C was my first programming language, and when I was first learning it I had no idea how to use malloc, calloc, and realloc, and just ended up never learning it lol. Thankfully when I decided to try and learn exactly what these functions do, your video was able to provide an easy to understand explanation.
I think i could have paid my college fee to you for this teaching ...u are awesome ..My college professor's should see these video to learn actual c/c++...and companies are hoping from us to be a good programmer without such a good depth knowledge..
Yes, indeed sir, I was thinking the same thing. Like I've written codes that uses a variable to declare the size of an array, and it works fine. So, I am guessing this is more of a compiler thing? rather than the C language itself? Like in some compiler you cant do that, and in other, we can.
@@gamoholic7653 I program in c++, I don't think it's legal, everytime I use an integer to initialize size of array, it flashes illegal initialization error, size cannot be vector value
it wasnt orignally a part of c, its called variable length array (VLA), VLA has been there since C99 and has been optional since C11, however big compilers like clang or gcc will never remove it probably
this is a great video- i was hesitant at first because the videos on this topic were long but it's very concise and explains everything with specific examples
I've been searching all throughout for a good video on malloc, and I have to say. This is the BEST tutorial that I have found. Excellent tutorial. Thank you very much
sir thank you so much for this video.before i watch this video i had fear of pointer now i am feel good in pointer .your teaching technique is too good .
I am about 5 years late to the party but this video was amazing at explaining these dynamic memory allocation functions, much much better than my prof ever could. Thank you!!
@@vishwaja1523 #include int main() { int n; scanf("%d", &n); char arr[n]; scanf("%c", &arr[n - 2]); // it was fine uptill this one. scanf("%c", &arr[n - 1]); // here the size gets too big for run time operation printf("%c ", arr[n - 2]); printf("%c", arr[n - 1]); return 0; } /* Deciding an array size at runtime is possible in modern C (>= C99) and code like the below is fine. One obvious drawback of VLAs is that if s is quite big and the allocation of a could fail. Worse, there's no way to check if the allocation has failed and you'll run into runtime errors (e.g., segfault). It's essentially undefined behaviour */ /* #include int main() {
int n; scanf("%d",&n); int arr[n];
scanf("%d", &arr[n-2]); scanf("%d", &arr[n-1]); //both of these works being smaller in size.
Fantastic video. I would add one thing to the explanation of why malloc(sizeof(int)) should be used instead of malloc(4); it makes the code a lot more readable. Somebody else reading the code will see the number 4 and potentially have no idea why it is there, but when they see sizeof(int) they know exactly what it represents. No magic numbers!
@@shakiulanam6569You can go through this link to know what happened actually. www.google.com/url?sa=t&source=web&rct=j&url=www.freecodecamp.org/news/mycodeschool-youtube-channel-history/amp/&ved=2ahUKEwi169TOwrXwAhWbIbcAHTa3A2oQFjACegQIFxAC&usg=AOvVaw1qjV_46-q46sfTrJpe96jt&cf=1
🎯 Key Takeaways for quick navigation: 00:24 🛠️ malloc, calloc, realloc, and free are key functions for dynamic memory allocation in C. 01:23 📏 malloc allocates memory based on the specified size, returning a void pointer. 02:43 📝 Sizeof and typecasting ensure proper allocation for specific data types. 05:00 🚀 Use typecasting to convert void pointers to specific data types for manipulation. 06:43 ➡️ Dynamic memory manipulation is done through pointers, incrementing for array traversal. 07:09 📊 Calloc initializes allocated memory with zero values, unlike malloc. 08:32 🔄 Realloc modifies memory block size, potentially copying and extending existing data. 09:27 📦 Dynamically allocate memory for arrays, prompt user input, and store data. 10:52 📋 Typecast and initialize memory when using calloc for dynamic arrays. 12:14 ❗️ Use free to deallocate dynamically allocated memory when it's no longer needed. 14:34 ↔️ Realloc resizes memory blocks, possibly extending or reducing existing blocks. 17:13 🔀 Realloc can serve as a substitute for malloc and free, offering flexibility. Made with HARPA AI
I had that "not so obvious question" for a long time. Even my teacher had no clue how that happened when I asked her. Well, now I know it. Thanks a lot. :)
we can allocate stack data in compile time now ! It used to give errors in the older versions of C (or C++). meaning, int n; scanf("%d",&n); int A[n]; doesn't give any error (up-to some limits on n. For my PC the range is 100,000 approx. It may be the stack size available in the Memory,I am not sure.)
First of all, thank you so much for making this video, you have no idea how much it helped. But I do want to say that when I write code as: int A[n] it stills compiles with no errors, and when I run the program it prints the same result; I am using GNU Make 4.2. The only thing is now I can not free the memory so I like allocating it because it gives a pointer so I can free it later.
sir i have a question. when we use free(A), A is only a pointer to the base address of the memory allocated. How does free know exactly how many bytes of memory to be freed? that is when to stop the deallocation?
Ayindrila Bhattacharyya Most implementations of C memory allocation functions will store accounting information for each block, either inline or separately.One typical way (inline) is to actually allocate both a header and the memory you asked for, padded out to some minimum size. So for example, if you asked for 20 bytes, the system may allocate a 48-byte block:16-byte header containing size, special marker, checksum, pointers to next/previous block and so on.32 bytes data area (your 20 bytes padded out to a multiple of 16).The address then given to you is the address of the data area. Then, when you free the block, freewill simply take the address you give it and, assuming you haven't stuffed up that address or the memory around it, check the accounting information immediately before it.Keep in mind the size of the header and the padding are totally implementation defined (actually, the entire thing is implementation-defined (a) but the inline-accounting-info option is a common one).The checksums and special markers that exist in the accounting information are often the cause of errors like "Memory arena corrupted" if you overwrite them. The padding (to make allocation more efficient) is why you can sometimes write a little bit beyond the end of your requested space without causing problems (still, don't do that, it's undefined behaviour and, just because it works sometimes, doesn't mean it's okay to do it).(a) I've written implementations of malloc in embedded systems where you got 128 bytes no matter what you asked for (that was the size of the largest structure in the system) and a simple non-inline bit-mask was used to decide whether a 128-byte chunk was allocated or not.Others I've developed had different pools for 16-byte chunks, 64-bytes chunks, 256-byte chunks and 1K chunks, again using a bitmask to reduce the overhead of the accounting information and to increase the speed of malloc and free (no need to coalesce adjacent free blocks), particularly important in the environment we were working in.
At ~16:30, while in the old days we thought it was okay to do a realloc( ptr, 0 ) as a free(), this is very much deprecated now. It is flat-out undefined behavior in C23 now. Other than that small detail, a great video.
If you're doing something like: unsigned char*list=(unsigned char*)calloc(size,sizeof(unsigned char)); You can shorten it to (without type casting, not all compilers allow this): unsigned char*list=calloc(size,1); Because sizeof(char) is always 1.
I am really thankful to you for this wonderful lecture series. I wanted to understand connection between heap and hugepages on linux. How to find out what's the heap size of our system on Linux and how to increase the heap size. Thanks
Almost 10 years and still this is the only video that made me understand dynamic memory allocation in c
he dead
Sir. Thanks for this video. I am a Computer Science student from USA, and the only thing I can say is that my professor should be watching this video also. You saved me to complete my assingment, but the most important thing is that I finally learned the topic which is more important to me.
Greetings from Miami.
Best Regards
aburridohp You are most welcome :)
+mycodeschool really awesome for beginners also
+aburridohp me too, this video help me a lot. i'am also a computer science student, regards from indonesia.
This so much!
mycodeschool ....awesome video... This video is much much better than other local books.. And college teachers/ professors .....thank you mycodeschool
You are actually explaining the most complex things in the simplest way. I think every book on C should contain a reference to your videos.
I sit in class for 75 minutes twice a week and this man explains it better in 17 minutes
Thank you very much for all your videos. I really feel like my teacher should learn from you, it's amazing how you can, in 17 minutes, explain something she's trying to explain in 3 hours. And she fails every time. Too bad I haven't found your videos earlier! :)
Thanks a lot Natália Karelová
sir same compliments from me too. it's a shame i didn't find your videos earlier.
Wow I wish I found these at least a few months ago... then my assignments would have been a piece of cake. :'(
feel absolutely the same thing. I could have passed my mid-sem examinations had I had access to these videos earlier :3 thanks a lot :D
Natália Karelová
SO FAR, ONE OF THE BEST EXPLANATIONS OF DYNAMIC MEMORY. MY CONCEPTS ARE TOTALLY CLEAR, ALL THANKS TO YOU :) WE USUALLY SHY AWAY OR RATHER FEAR DYNAMIC MEMORY ALLOCATION, BUT AFTER WATCHING THIS VIDEO, MY PERCEPTION HAS SURELY CHANGED.
Your whole series on pointers in C is an absolute goldmine!
learning is so fun when you learn it from the right people
thanks a lot ! after 3 yrs in engineering now i am understanding the basic concepts being in final year !
+Sneha Vernekar Your comment makes me feel a lot luckier as I am still in my second year and sir has saved me the effort
Triple H nice :) make the best use of these videos ! get the concepts cleared right from the beginning :)
+Sneha Vernekar Sure. Your words mean a lot coming from an experience senior :)
I am a 3rd semester student and i think i have come to right place
And your comment makes me feel bad coz I'm a s/w engineer and still unclear about the subject.
I have learned much more from cramming to your videos in 4 hours than my university prof's teachings that stretch over months.
sir mycodeschool, you is the realest
I have watched a fair amount of tutorials in a wide range of topics over the years. This series has to be, hands down, the best one there is. Amazing job dude, I sincerely hope you are a teacher because you are the natural talent.
I just wanted to say thank you! I'm relearning some stuff I'm rusty on for my new job and I appreciate greatly the fact that you share all of this knowledge for free for us.
after so many failed attempts to learn basic programmng from different platforms now i can certainly say this is one of the best platforms to learn basics thanks to entire team for making such an amazing series .
You are by far the MOST
amazing teacher in TH-cam! Thank you so much. I wish you could get back here soon. We, cs students, really really need your knowledge!
I love your videos!!! My teacher from palm beach state college doesn't explain nearly as well as you and I'm so lucky to have found your vids. You're a life saver. I'm gonna spread the word so that more people can know about your vids when they are confused in C.
Greetings from Boca Raton, Florida.
The information inside those 17 videos is the minimum requirement for any programmer.
Good job.
The best explanation i have ever seen.. Greeting from Azerbaijan 🇦🇿
Watching your videos is an excellent accompaniment to reading my textbook, which is sometimes so unclear, I could cry lol. Thank you so much!
9 year later, and it the most helpful channel on this topic, great work
One of the best teacher ever. Thanks for sharing your knowledge!
Thanks so much. I am a new grad to CS major and I just learn "coding" in python, matlab before in kinda math major. What we learnt about C in math major is so similar to learning python, just in another syntax, but actually they are so different! This series saved my life and really let me know deeper in C. Thanks again!
This channel is the best that I have found on these topics, thanks for sharing this. Again it proves the subject is not complex it is the way it is explained that makes it complex.
Man I am actually really impressed with this explanation usually I find TH-cam tutorials for coding super convoluted, but this one was very clear and precise. Good job
You've made the topics of pointers and dynamic memory allocation crystal clear for me. You're a rockstar. Thank you.
Why some people dislike this kind of educational content. Thanks bro it helps me a lot.
I am in a German University and I must admit that you are an excellent teacher,,,keep it up
Thanks a lot Faisal :)
malloc -> Memory ALLOCation
calloc -> Continuous ALLOCation
realloc -> REALLOCation
Calloc actually stands for contiguous allocation.
Great video ! C was my first programming language, and when I was first learning it I had no idea how to use malloc, calloc, and realloc, and just ended up never learning it lol. Thankfully when I decided to try and learn exactly what these functions do, your video was able to provide an easy to understand explanation.
Great video, this is by far the best tutorial i have found on line after hours of reading articles and watching videos
I think i could have paid my college fee to you for this teaching ...u are awesome ..My college professor's should see these video to learn actual c/c++...and companies are hoping from us to be a good programmer without such a good depth knowledge..
Simple, detailed, no bullshit explanation, i wish every teacher in my university is like you. THANKS ALOT!!
at 9:55 it's perfectly fine to declare A[n] as an integer array , works perfect in my codeblocks compiler !
Really? never heard of that before. I don't even believe that smh
Yes, indeed sir, I was thinking the same thing. Like I've written codes that uses a variable to declare the size of an array, and it works fine. So, I am guessing this is more of a compiler thing? rather than the C language itself? Like in some compiler you cant do that, and in other, we can.
@@puturavindrawiguna3025 I guess it's legal in C++ but I never tried in C. Can you please try and share the observations with me...
@@gamoholic7653 I program in c++, I don't think it's legal, everytime I use an integer to initialize size of array, it flashes illegal initialization error, size cannot be vector value
it wasnt orignally a part of c, its called variable length array (VLA), VLA has been there since C99 and has been optional since C11, however big compilers like clang or gcc will never remove it probably
He malloc,
He calloc,
but most importantly...
He realloc to 0.
I read zeroc
ciroc
this is a great video- i was hesitant at first because the videos on this topic were long but it's very concise and explains everything with specific examples
I've been searching all throughout for a good video on malloc, and I have to say.
This is the BEST tutorial that I have found.
Excellent tutorial.
Thank you very much
sir thank you so much for this video.before i watch this video i had fear of pointer now i am feel good in pointer .your teaching technique is too good .
Bruhh you explained this concept like a pro...i almost cried:D
🙂👍 You sir have helped a lot of Students, including me, better Understand the Dynamic Memory Allocation. Thank You!
To be clear, realloc() is a god-tier function 😂. Awesome explanation, you're A1, brother!
Thanks man, that actually showed me what malloc is. I had so much trouble and you made it easy, thank you so much
Brilliant sir!
After watching this video I found myself comfortable with dynamic memory allocation......
I am about 5 years late to the party but this video was amazing at explaining these dynamic memory allocation functions, much much better than my prof ever could. Thank you!!
10:00 However, the value of an array can be a variable. However, I must say MCS is a must-visit source to understand pointers.
variable size of array is allowed in C after C99 onward.
@@amritasaha2793 u mean that we can do a[n] declaration in new version of c ?
@@vishwaja1523 in c++ we can definitely do
@@vishwaja1523 Yes we can. After taking 'n' as input, we can create an array of size 'n' in c !!
@@vishwaja1523 #include
int main()
{
int n;
scanf("%d", &n);
char arr[n];
scanf("%c", &arr[n - 2]); // it was fine uptill this one.
scanf("%c", &arr[n - 1]); // here the size gets too big for run time operation
printf("%c
", arr[n - 2]);
printf("%c", arr[n - 1]);
return 0;
}
/* Deciding an array size at runtime is possible in modern C (>= C99)
and code like the below is fine.
One obvious drawback of VLAs is that if s is quite big and the allocation of
a could fail. Worse, there's no way to check if the allocation has failed
and you'll run into runtime errors (e.g., segfault).
It's essentially undefined behaviour */
/*
#include
int main() {
int n;
scanf("%d",&n);
int arr[n];
scanf("%d", &arr[n-2]);
scanf("%d", &arr[n-1]); //both of these works being smaller in size.
printf("%d
",arr[n-2]);
printf("%d",arr[n-1]);
return 0;
}
*/
YES WE CAN
I was having a lot of difficulty in understanding DMA but this cleared it up. Thanks!
Sir, thank you for your kind explanation, you have some really good didactic skills, congratulations!
Fantastic video. I would add one thing to the explanation of why malloc(sizeof(int)) should be used instead of malloc(4); it makes the code a lot more readable. Somebody else reading the code will see the number 4 and potentially have no idea why it is there, but when they see sizeof(int) they know exactly what it represents. No magic numbers!
The size of int is not 4bytes for all machines
Very nicely explained, I understood everything although I am not native english speaker. You got my like.
A very helpfull video, you teach better than all my professors.
this is the only video that made me understand dynamic memory allocation in c
Thanks man! Most of ICT teachers should learn to explain as you do
Awesome video, you explained this to me like no one would ever have.. thanks
.
Sir ,thank you for providing best programming video for free !
i have lost my word to explain the quality of this video series , carry on sir best wish for you for such kind of dedication.
He is no more brother
@@yatinbahl6240 ooo my god !! how?
@@shakiulanam6569 He died in a car accident. Luckily his wife survived in that accident.
@@shakiulanam6569You can go through this link to know what happened actually.
www.google.com/url?sa=t&source=web&rct=j&url=www.freecodecamp.org/news/mycodeschool-youtube-channel-history/amp/&ved=2ahUKEwi169TOwrXwAhWbIbcAHTa3A2oQFjACegQIFxAC&usg=AOvVaw1qjV_46-q46sfTrJpe96jt&cf=1
This is great video, clear my doubt! Superb explanation and sample code.
Greetings from Malaysia
🎯 Key Takeaways for quick navigation:
00:24 🛠️ malloc, calloc, realloc, and free are key functions for dynamic memory allocation in C.
01:23 📏 malloc allocates memory based on the specified size, returning a void pointer.
02:43 📝 Sizeof and typecasting ensure proper allocation for specific data types.
05:00 🚀 Use typecasting to convert void pointers to specific data types for manipulation.
06:43 ➡️ Dynamic memory manipulation is done through pointers, incrementing for array traversal.
07:09 📊 Calloc initializes allocated memory with zero values, unlike malloc.
08:32 🔄 Realloc modifies memory block size, potentially copying and extending existing data.
09:27 📦 Dynamically allocate memory for arrays, prompt user input, and store data.
10:52 📋 Typecast and initialize memory when using calloc for dynamic arrays.
12:14 ❗️ Use free to deallocate dynamically allocated memory when it's no longer needed.
14:34 ↔️ Realloc resizes memory blocks, possibly extending or reducing existing blocks.
17:13 🔀 Realloc can serve as a substitute for malloc and free, offering flexibility.
Made with HARPA AI
even videos with my native language couldn't explain it this well thank you :D
I had that "not so obvious question" for a long time. Even my teacher had no clue how that happened when I asked her. Well, now I know it. Thanks a lot. :)
best Malloc tutorial on TH-cam
You should become a teacher if you aren't already.. great and detailed tutorial for difficult and demanding students like myself..
Hi George Pan -
I am not a professional teacher, but yes I love to teach.
Bro I appreciate you so much. Saved me for this midterm I'm about to take tomorrow.
I love this, the topic is widely explained. Thank you very much Sir.
Thank you bro! This video help me a lot! I didn't understand nothing from my C professor. :)
Respect!
I love this guy.
This guy is awesome...!! Finally i understood this n can use it well in my assignments... Thanks alot!!!
My professor is so boring!!
2:15 up to 7:00 MALLOC() for those pressed for time &
9:18 compiler input with real code
Wow I thought malloc realloc and calloc would take my whole day but 17 mins and I did
Thanks man one❤
we can allocate stack data in compile time now !
It used to give errors in the older versions of C (or C++).
meaning,
int n;
scanf("%d",&n);
int A[n];
doesn't give any error (up-to some limits on n.
For my PC the range is 100,000 approx. It may be the stack size available in the Memory,I am not sure.)
Wonderful explanations!!!Dynamic memory allocation made easy by you!! Thanks a lot!!
First of all, thank you so much for making this video, you have no idea how much it helped. But I do want to say that when I write code as: int A[n] it stills compiles with no errors, and when I run the program it prints the same result; I am using GNU Make 4.2. The only thing is now I can not free the memory so I like allocating it because it gives a pointer so I can free it later.
Great explanation!! You really make things a cakewalk. Thanks!!
excellent explanation you helped many of us. Thanks from students at IIT Mandi.
The example at minute 10 is just what I was looking for, thx
Awesome explanation sir!!!I understood very well 🙏🙏🙏🙏
I finally know how to dynamically allocate memory...And two nights before my exam! thank you so much!!
thanks for sharing such quality videos sir....your teaching skills are perfect...now my concepts are more clear....
Thank you for making this video! It honestly helped me so much. You're a great teacher!
Superb explanation bro. Thanks lot... Its was very clear enough to understand a newbie also.....
Finally after 2 years I can say that I know about dynamic memory allocation.
this was extremely clear and helpful, thank you!
Thank you so much!
Student from Romania
Amazing video. Outstanding explanation.
Thanks a whole bunch mate.
sir i have a question.
when we use free(A), A is only a pointer to the base address of the memory allocated. How does free know exactly how many bytes of memory to be freed? that is when to stop the deallocation?
Ayindrila Bhattacharyya
Most implementations of C memory allocation functions will store accounting information for each block, either inline or separately.One typical way (inline) is to actually allocate both a header and the memory you asked for, padded out to some minimum size. So for example, if you asked for 20 bytes, the system may allocate a 48-byte block:16-byte header containing size, special marker, checksum, pointers to next/previous block and so on.32 bytes data area (your 20 bytes padded out to a multiple of 16).The address then given to you is the address of the data area. Then, when you free the block, freewill simply take the address you give it and, assuming you haven't stuffed up that address or the memory around it, check the accounting information immediately before it.Keep in mind the size of the header and the padding are totally implementation defined (actually, the entire thing is implementation-defined (a) but the inline-accounting-info option is a common one).The checksums and special markers that exist in the accounting information are often the cause of errors like "Memory arena corrupted" if you overwrite them. The padding (to make allocation more efficient) is why you can sometimes write a little bit beyond the end of your requested space without causing problems (still, don't do that, it's undefined behaviour and, just because it works sometimes, doesn't mean it's okay to do it).(a) I've written implementations of malloc in embedded systems where you got 128 bytes no matter what you asked for (that was the size of the largest structure in the system) and a simple non-inline bit-mask was used to decide whether a 128-byte chunk was allocated or not.Others I've developed had different pools for 16-byte chunks, 64-bytes chunks, 256-byte chunks and 1K chunks, again using a bitmask to reduce the overhead of the accounting information and to increase the speed of malloc and free (no need to coalesce adjacent free blocks), particularly important in the environment we were working in.
OMG.. this is amazing! Why can't my professor explain like him???
You saved my life with this video
what an amazing video you made ,it really helped me a lot ! you do a great job !
Thanks Daniel !!
best tutorial on internet
Really helpful and concise! Thank you very much!
It was uploaded on my birthday :)
My code school is so awesome ❤❤
this video is great! your explanation is so clear and helped me a lot ! tnx!!
Thank you so much for the great explanation, sir. Best video on this subject that I found. You should become a teacher :)
this video is seriously very helpful.thank you very much
wow!!! man great explanation.... I wish my university professor could explain like the way u did.....
You literally saved my life!
At ~16:30, while in the old days we thought it was okay to do a realloc( ptr, 0 ) as a free(), this is very much deprecated now. It is flat-out undefined behavior in C23 now. Other than that small detail, a great video.
The man, the myth, the legend!
great video, I finally understand these concepts.
If you're doing something like:
unsigned char*list=(unsigned char*)calloc(size,sizeof(unsigned char));
You can shorten it to (without type casting, not all compilers allow this):
unsigned char*list=calloc(size,1);
Because sizeof(char) is always 1.
I am really thankful to you for this wonderful lecture series. I wanted to understand connection between heap and hugepages on linux. How to find out what's the heap size of our system on Linux and how to increase the heap size.
Thanks