ITERATORS in C++
The first 1000 people who click the link will get 2 free months of Skillshare Premium: skl.sh/thecherno08202
Patreon ► / thecherno
Merch ► chernothreads.com
Instagram ► / thecherno
Twitter ► / thecherno
Discord ► thecherno.com/discord
Series Playlist ► thecherno.com/cpp
This video was sponsored by Skillshare.
Пікірлер: 333
Thanks for watching! If you're after more, try and conditionally erase elements from your data structure while iterating over it, and make sure it works! Also don't forget to check out Skillshare - the first 1000 people who click the link will get 2 free months of Skillshare Premium: skl.sh/thecherno0820
@kadiyamsrikar9565
3 жыл бұрын
Hey cherno why don't you give your opinion on c++20 dropping support for iterators and adding modules
@battosaijenkins946
3 жыл бұрын
@The Cherno, Yes THANK you for these kind of vids! I don't mean to sound like a complete prik but please, less of the dev reviews/opinions and more of the educational lessons of C++ like you used to upload back. You probably heard this a gazillion times but you are one of the best C++ explainers out there hands down~ Cheers.
@oracleoftroy
3 жыл бұрын
@@kadiyamsrikar9565 Uh what? C++20 renamed the old XIterator categories (e.g. InputIterator) to LegacyXIterator (e.g. LegacyInputIterator) and introduced a bunch of concepts to more explicitly categorize iterators. Modules has nothing to do with iterators, did you mean ranges? That doesn't replace iterators, but gives you a nicer set of algorithms that work on anything that models a range. Iterators are still there and aren't going away as far as I can tell. Even if ranges eventually replaces them, that will still be several years off.
@kadiyamsrikar9565
3 жыл бұрын
@@oracleoftroy your are right mate but c++20 is trying to increase the capabilities and usage of ranges. Module system is added in c++20
@kadiyamsrikar9565
3 жыл бұрын
@@oracleoftroy you are right mate but c++20 is trying to replace iterators and increase the capabilities of ranges . Module system is added in c++20 just like other modern languages.
University: "As a CS student you will always have to learn the newest technologies." Also university: "Yea you gonna use c++-98, cause thats what the professor learned back in the day and he never bothered to update his lecture for 20 years."
@lordnoiado
2 жыл бұрын
Shit, I was pretty annoyed that my current professor doesn't really code in C++20 (it's so good) but I guess it could be worse LMAO
@GalaxiaDeFavio
Жыл бұрын
@Danilo lol that exist?
@Ruhrpottpatriot
Жыл бұрын
@@GalaxiaDeFavio Yeah, like in the Linux Kernel who just recently switched over to GNUC11 after sticking to C89 for decades.
@user-ge2vc3rl1n
9 ай бұрын
@@lordnoiado good luck finding a job that uses C++20
Love how he mentioned university using c++ 2003 but I was using c++ 98 in my university and i graduated last year.
@bobthemagicmoose
3 жыл бұрын
Psh, we're using K&R c with nonstandard function prototypes (the project was something the prof did as a student 30 years ago)
@bennyc655
3 жыл бұрын
lol, while we learn a language call Racket, which no body use nowadays...
@MrCleverOnion
2 жыл бұрын
What year did you graduate?
@corbinlenning3505
2 жыл бұрын
@@MrCleverOnion July 2019
@lordnoiado
2 жыл бұрын
@@corbinlenning3505 That's insane, my professor uses C++17 and I was already about to complain (C++20 has some great features), wow...
I was recently given a C++ assessment for C++03, this was the first time a company interviewed me for such an old version. Seems like certain companies still have 20 years to catch up.
@muadrico
3 жыл бұрын
I updated almost all code bases of all C++ projects in my company from using C++98 to C++17 in the last 5 years.
@badasahog
3 жыл бұрын
actually 17 tho
Another excellent video! I wish I had these when I was learning this stuff. Even though most of these are not new to me I never miss a single c++ series video because they are so well done. Keep it up!
As a JS developer learning C++, seeing the structured binding at the end made me smile. It literally looks the same, and in JS is called destructuring. Nice video
@mateuszabramek7015
3 жыл бұрын
Since TypeScript become popular, to JS were introduced many features from other languages because people from typed languages could understand JS easier and eg. node.js is written in c++. Than came ES6, ES7... Some implementations failed in my opinion like const, which is not really const when it comes to arrays or objects.
@magicweaponr072
3 жыл бұрын
@MyName Here lol. A big chunk of today's web servers are run on Node.JS, entire backends are written just in JavaScript and JavaScript derived technologies. I'd say javascript is as real of a programming language as C, C++, Rust, C#, whatever. Just higher level.
@astrotecn
3 жыл бұрын
@@magicweaponr072 nothing against higher level languages but javascript is specially garbage
@DoubleCoolOp
3 жыл бұрын
@@magicweaponr072 JavaScript is one of the worst languages ever invented, just like php.
@magicweaponr072
3 жыл бұрын
@@DoubleCoolOp well considering how nicely it's evolved and the ecosystem, and variety it's created, your opinion doesn't do it much justice, now does it? :)
was waiting for this one!! Love this series, and that smooth sponsor transition
Great! I was waiting for a good tutorial on this. Thanks Cherno.
Brilliant tutorial on iterators, Cherno. Always good to have such refreshers!
This video is crafted overly well and i love it. Thank you for the thorough explanation of iterators.
Another good reason to use iterators in basic data structures (that you could access by an index) is to have iterators with different behaviors e.g. a reverse iterator (trivial), an iterator that gives you the next random element or that accesses the elements in a specific order or that applies some filter function.
You are too good man. Thanks for this, to the point and easy to understand, no bs.
Great explanation, as always! Waiting for the next episode!
you make my self taught journey of c++ so much easier. Thank you so much
@ifracing
2 жыл бұрын
hows its going the self taught journey? im currently in my 2nd month? i see its been a year for you now.
@epiram
2 жыл бұрын
@@ifracing breh
Me : What are iterators ? Cherno: Iterators are used to iterate . Me:....... Cherno: Sometimes my genius is ........ its almost frightening
@cp_200
3 жыл бұрын
I can Feel You
@xephobia795
3 жыл бұрын
guys i'm gonna be honest... my brain is my brain
Just started my journey of c++ by your playlist....am really really excited 😃
Thanks a lot. I really like the way you explain the iterators. The examples are simple and clear.
Additionally, would be really useful to mention about the usage of the reference '&' for the iterator it self. I.e. instead of using "for (auto kv : map)" - using "for (const auto& kv : map)" would eliminate unnecessary copies when iterating.
@PrinceGupta-jo8lo
3 жыл бұрын
yeah, this is necessary
@TheMR-777
3 жыл бұрын
True! I also use this technique to avoid copying
@matteorossillol7812
3 жыл бұрын
Like said @Peterolen, `kv` is not an iterator here but a `value_type` (see the named requirement LegacyIterator for further information): e.i. the type of the dereferenced iterator. See the range-based for loop for more information about its operation. The `value_type` of `std::map` is `std::pair`, hence the possibility to use the C++17 syntax `auto [a, b] = pair;`.
@navjan13
3 жыл бұрын
@@matteorossillol7812 @rawEngine's comment was regarding lthe auto at ine no. 40
@glitchgatsby4290
2 жыл бұрын
ooof, yeah, that sounds expensive with a bigger map
Excellent video, was worth watching the entire thing. Subscribed
This video is still GOLD. Thank you Cherno. Really useful.
i enjoyed watching every second of this tutorial. Thank you.
Awesome overview! keep up the good work!
Note that the example with structured bindings will copy the elements. To iterate over a reference to the elements use: for (auto& [key, value] : map)
@victor_zsasz
10 ай бұрын
thx!
I'm looking for this tutorial! Thank you for making this!
This is one of the best explanations of iterators I have seen, I was banging my head around google for so long! thanks
You teach soo much clearly and go just one step deeper
I feel kinda smug that my uni has made it all the way to C++ 11.
@LittleRainGames
3 жыл бұрын
atmel studio uses c++ 11, they are getting you ready for MCU programming
@not_ever
3 жыл бұрын
@@LittleRainGames We program MCU in C, Assembly and C++ throughout uni, but have never used atmel studio for any of that.
@robert1200
3 жыл бұрын
my university teaches us C++ 98
@zoriiginalx7544
2 жыл бұрын
C++11 is better than the new wacky standards anyway.
Thank you for still making programming tutorials (and hopefully more gfx!). I was afraid you wouldn’t after your reaction super stardom!
That's exactly the video I was waiting for !
absolutely amazing video. Each video of yours make me love the language even more. I use it a lot in embedded systems and they way C++ elegantly interfaces with the hardware is simply beatiful .
@thestarinthesky_
3 жыл бұрын
I would like to work in embedded systems too in the future :)
@practicalsoftwaremarcus
3 жыл бұрын
Best topic ever
@thestarinthesky_
3 жыл бұрын
@@practicalsoftwaremarcus Great! Which C++ framework should I know?Do you have any advice on being a professional in this field? What else should I learn except core C++ and standard library and data structures and algorithms in C++?
For the video about iterators, an example about how it could be used for something different than iterating over a collection of element would be to iterate over a random class. Maybe you would construct with arguments about the range (min, max, number of values) and iterate through it, but the iterator would generate random numbers on the fly.
I fuckin love you. I was just looking for iterators and didn't find your video about it. Seriously, without you I would not have become as good as I am right now thank god. If I could sub to your patrion I would. Good luck with your work boi!!
Hey Cherno. Just want to leave some feedback to your videos: You are the BEST!!! Thanks a lot for your effort. You make it so easy to learn C++ and you are such a great character with always perfect hair :D!
I have never seen or heard of C++17 structured bindings. I love learning new things about C++!
Hello! Great video! I think it would be interesting for you to make a video about how to implement a custom iterator for a custom STL compatible data structure (may be with some fancy algorithm). In the video you could touch something about template stuff and all these "using value_type = ", etc. Good luck! Looking forward to the new video!
Hey @TheCherno thanks for another great video! Can you also please make a video on different containers, and algorithms in c++, which are most commonly used.
You made my day and just got a new subscriber
Thank you. I learned a lot by watching your channel
Congratulations for channel. Video is much fine. Thank you for teaching. Peace and Health
Thanks. I Was Looking For This
Yes! I've been waiting for iterators !
Thanks, very informative!
Perfect introduction! Thx for that! You're doing really well ;)
Nicely done! Thank you.
As a side note, ++it is generally more efficient than it++. The postfix operator has to create a temporary under the hood in addition to calling ++it.
@Borgilian
3 жыл бұрын
Not really... As far as I know, ++it used to be more efficient for looping through objects/data structures, and pointless for looping through arrays/vectors of primitives. Nowadays the compiler is optimizing it++ (if it's a modern one), so it gets similar performance to ++it. Still, might be good practice to continue differentiating it++ and ++it in code, since the compiler is not all knowing and might not optimize sometimes.
@keris3920
3 жыл бұрын
@@Borgilian I say generally, because there are cases where that is not true. It is true, however, that ++it is at least as efficient as it++. It's not true that it++ is at least as efficient as ++it.
@sukhrajrandhawa5195
3 жыл бұрын
@@Borgilian Using prefix is just good practice though. You should probably only use postfix in the cases where you need the temporary generated since that justifies it's use case. Other than that, you should always be using prefix whether the compiler will optimize the postfix or not.
I was just having a problem with this, thank you so much!
I am going over this area right now at university. So this is an especially useful tutorial.
0:27 yea and mine uses Turbo C which was released in 1993 when C++ wasn't even standardized
@mr.mirror1213
3 жыл бұрын
Lol Indian problems boy (same here)
@codingsaroj18
3 жыл бұрын
yeah my school used turbo c++ in 8th class.
@kadblue2000
3 жыл бұрын
@@codingsaroj18 same what a nightmare! The mouse pointer stopped working halfway through randomly then you had to save the file and restart using the keyboard. Notepad is better than turbo c++.
@Borgilian
3 жыл бұрын
C is actually lean enough for you to learn proper programming without all the OOP and C++ bullshit going on nowadays. You have an opportunity to learn how to code properly and in a way that favors the machine (performance).
nice work. As a student,i think that analyzing comlicated STL template design would be quite interesting.
Thank you for clarifying this, which helped me make sense of it right away: Iterators appeared in the language because not all collections can be iterated over by an index.
Thank you so much for this video
Thank you for the amazing videos :)
Thanks once again for a highly informative video! Is there any significant speed difference between regular indexing and iterators on ordered data structures? For example, when I have multiple for loops running over arrays/matrices, would it be faster to use iterators and de-reference pointers or to obtain the values by the usual indexing?
Expected to see operations between iterators, offsets and so on :)
This was brilliant.
We used turbo c++ in our college before we graduated in 2021. Stuff that has not been used since 1996. It makes the students hate this language. I really hope they update their system and their syllabus up to the current technology. Never had a lot of fun there 😅
It would be great to have a video on static code analyzers and sanitizers like address/thread sanitizers, cppcheck, sourcemonitor, etc.
Thank you for the 70+ videos and the 20 sponsors from skillshare
In a sense I felt like this was much more useful video for map than the actual map video. Or maybe I remember poorly. However I remember struggling with maps in 2018 or so. It was a terrible school task of STL containers where you had a nature park hiking routes with locations and you'd have to return the route with least elevation change between requested A and B. I'm still having nightmares from that, I just couldn't wrap my head around that. And another thing was nested maps... It was kinda funny to do the first C++ class in 2011 and the second right in 2018. A lot had changed but I had no idea, because even today the material for the first class is the same. The fundamentals don't change. So I guess I'd love to see more of those more advanced/complicated applications of these simple tools. Things that force you to think but also demonstrations of what's actually going on in there.
Very nice video! As a junior developer it helps me understand my colleagues code xD
watch all the c++ videos in a week. omg Cherno, you somehow look young->old->young
For those watching for a good reference book: C++ primer is the way to go(imo.).
@snokzor
3 жыл бұрын
it's very academic and I didn't like the bigger exercises and it goes very (too much?) into depth at times but it's a good book, yeah.
@snokzor
3 жыл бұрын
one of the better ones out there to really get into it
@snokzor
3 жыл бұрын
it doesn't go into multithreading and some other stuff tho
@ashishdandge5587
3 жыл бұрын
My input is that this book is for those who are already familiar with programming and beginner to C++.
@rahulsriram6295
3 жыл бұрын
"Sam's Teach Youself C++ in One Hour a day" is the best!
cherno literally saving me through online school
Last for loop for map should be like below for( const auto& [ key, value ] : map )
Nice. Thank you!
great lecture
I am learning c++ with a book called C++ in One Hour a Day. And when i confuse, don't get something, i know where to go. Your videos are AMAZING. Hope that your videos can reach more people.
@ibrakap
3 жыл бұрын
Yerini biliyorsun reis :D
Make a short video of typing and shortcuts
@arsnakehert
3 жыл бұрын
I personally use a vim plugin in every other editor, pretty handy stuff
Time warp - I remember trying to code a card game in Turbo Pascal during computer science in the year 1986/87 I believe. That was not easy at all.
10:47 My man, rhyming. "I wanna iterate through it, How would I do it?"
thanks for the video. About the last two methods, is there versions of them to iterate to a certain position of the map and not to the full range of it?
Note on Game Engine: I make my 'Game Engine' in Flutter/Node.js/Sql etc... I make it fully multi interactive say Yatzee full functions etc. Then i have idea it would be easy to replace the Yatzee with say Chess and if good game engine it would be more or less easy to implement. My real idea is that when games came about in the beginning most where full programs not much to backup change since each program is isolated. Forward Amiga came with operating system where games could use the operating system simplifying the game structure. Forward more things are given to the game engine so the switch between games made simple. My idea is that a good game engine provides all most important features so ease of new creation.
hi cherno . are you planning to do a separate series of videos on c++ STL?
thank you sir
Thank you
As a recent CS grad, I never quite understand when people say "my university used x language or version", because my university assignemnts (especially final year) were mostly generalized to whichever language you wanted to use. Aside from certain exceptions - for example groupwork, and my mobile apps course was taught in SwiftUI on a specific version of Xcode, for logistical reasons - this was the norm. Did/are other students experiencing a different kind of CS degree, perhaps more practical and less theoretical? Additionally, what is the merit of constraining students in this way?
Thematically next would be ranges.
Awesome video
I'm really waiting for the exception in C++ class....
Dude, you are a fantastic communicator. Far better teaching as compared with CS lectures that I've taken.
I was told we are doing this is college because they have to show us the theory along with the way things actually work. You arent "supposed" to do certain things without knowing how they work first according to the colleges.
auto is amazing
Cherno, make video about rust vs cpp and Point to the claims of the rust language that all other things can be applied to the Cpp. For example, writing code that adheres to smart pointers(unique_ptr) And shared ptr for secure concurrent context. My suggestion is to build a library that has all these things together under the name secpp, for example.
Iterators are used extensively in stl algorithms library.
My uni was C++11 last I took the classes. And I thought that was a bit outdated…
8:00 i would recommend you write ++it instead of it++ because its more efficient in iterators
Nice video. Can you discuss the new features of C++20?
Hey Cherno, can you talk about the y_combinator and the best implementation in c++17?
continue the 3d game series PLZ
would love to give your thoughts on the hot chip 2020 for the Xbox Series X . i mean you talked about the great mark cerny presentation , now its Microsoft turn .
This guy is saving my unilife
Please make a video of making a c++ class that's iterable and define all the required methods. Thanks
Please, make a vídeo about Vector vs List arrays. Thanks for sharing your knowledge with us.
@AraAra064
3 жыл бұрын
It depends on what you need to use them for. Vectors: +Good at sequential access and random access +Stored as a block in memory so not much cache misses -Not good at changing the size of the arrays unless you use the .reserve(x) function Lists: +Adding elements doesn't take much time unlike Vectors -Takes a long time to go through the list since the elements aren't stored directly next to each other in memory (cache misses) That's all I can think of right now, I hope I helped.
@victorhugomagalhaes6370
3 жыл бұрын
@@AraAra064 Thanks a lot. Another question, list is better than vector to sort data, right? I'm developing a Heuristic, and I need sort a lot of data, delete and create. I think list is the obvious choice.
@AraAra064
3 жыл бұрын
@@victorhugomagalhaes6370 If you were just sorting, I'd go with vector. But since you need to delete and create stuff, list should be fine. I'd probably test to see which one is faster just in case because I'm not exactly a pro at C++.
@IndividualFreedomNet
2 жыл бұрын
@@victorhugomagalhaes6370 It's not so easy to know in advance if list or vector is better even when you work with lots of data and you need to delete and stuff. So as AraAra said testing both alternatives is the way to go if it really matters, e.g. for performance. It depends a lot on what your data actually is and how well it fits into caches, etc. I would recommend to start with what feels most natural to use for your data (probably list if your data sets are large and you really sort/delete/create a lot) and not worry much about alternatives until you really need an alternative. Because even if vector would be required performance wise (for large data sets) it would be better in many cases only if you take a few other measures like properly making your data cache friendly (e.g. aligning data) and for a real-time application you would even need to do exotic stuff like controlling releasing of memory. And then things get a lot of work...
Beautiful
I can only say that I really like you and your class!🤒🥳
For school I have to compile in C++ 98 😅 Really useful stuff! But i'll remember this video after my class.
it's unbelievable how there's no documentation about this
Your teaching is amazing but from where do you learn all this stuff(c++, Java, game engines, etc.). Please tell me
Is it also true that the iterator reduces the number of implementations in the algorithm library? I heard it allows the algorithms to traverse on any container type.
Please make a series of data structure videos ;---;