I have a question. In 3:46 You said, that we have to follow the same order when initializing member list as the member variables were declared in the class. As with most things, I went and check that out. But I couldn't find any diffrence when initialazing in order or not. In both ways it worked. Take a look at my example class: class TestClass{ public: int number; string name; TestClass(string name_set, int number_set) : name(name_set), number(number_set) { cout
Ok, I did a little bit more UA-cam research and I think I found out what is going on. First of all my example is a little bit unoftunate to show how the initialization works. If I understand correctly, by using member initializer list, the variables will be initialized in order like they have been declared in the class, and compiler will not care in what order I entered them. So in the class below: class Student{ public: int age; int IQ; Student(int a) : age(a), IQ(5 * age) {} }; everything would be ok if I wanted to print IQ in the main function. But when I would flip the order and declare "IQ" first, and then "age" like that: class Student{ public: int IQ; int age; Student(int a) : age(a), IQ(5 * age) {} }; and then I would like to print out the IQ in the main function , it would be 0, because first, the IQ is initialized, which will be 5 times 0, because age is not initalized at all, and after that age will be initialized. Am I correct now?
The first bullet point here explains it, basically if we do things out of order like that it's not garaunteed to work as we could end up using uninitialized values: medium.com/pranayaggarwal25/using-modern-class-members-and-initializations-c11e931c3ba. :-)
21:10 just pointing out that long int (which is the same as long) is the exact same 4 bytes on x64 systems, which are almost every system nowadays. On such systems long and int are identical, therefore there will be no type-narrowing.
7:24 So,the Major class has two constructors,the constructor is invoked based arguments we passed,then its compile time polymorphism i.e function overloading,Am I right?
Great question Yuw! 😀 It looks to me like in the first example, an object Major is being instantiated using major as an argument, a bit similar to this code here in terms of the general idea: stackoverflow.com/a/12927220
Wow, great question! :-) If we don't put it in, then the constructor for Major will be called and it will be provided with "major" as an argument, which is the same thing that will happen as the code is now. But let's say I have a class SpecialMajor that is a derived class of Major, and let's say it has a constructor that also accepts a string "major" as an argument. Now I *might* want to have the major member variable (with type Major) reference a SpecialMajor object, because it also *is* a Major, it's a dervied type / subtype of Major. But if I want to do that, then I *need* to include the classname like this: major(SpecialMajor(major)) in order for a SpecialMajor object to be instantiated here. Hopefully that helps! :-)
Very useful. All the things you have explained in this video are very important to keep in mind. Thank you so much.
You're welcome Eduardo! :-)
I have a question. In 3:46 You said, that we have to follow the same order when initializing member list as the member variables were declared in the class. As with most things, I went and check that out. But I couldn't find any diffrence when initialazing in order or not. In both ways it worked. Take a look at my example class:
class TestClass{
public:
int number;
string name;
TestClass(string name_set, int number_set) : name(name_set), number(number_set)
{
cout
Ok, I did a little bit more UA-cam research and I think I found out what is going on. First of all my example is a little bit unoftunate to show how the initialization works. If I understand correctly, by using member initializer list, the variables will be initialized in order like they have been declared in the class, and compiler will not care in what order I entered them. So in the class below:
class Student{
public:
int age;
int IQ;
Student(int a) : age(a), IQ(5 * age) {}
};
everything would be ok if I wanted to print IQ in the main function. But when I would flip the order and declare "IQ" first, and then "age" like that:
class Student{
public:
int IQ;
int age;
Student(int a) : age(a), IQ(5 * age) {}
};
and then I would like to print out the IQ in the main function , it would be 0, because first, the IQ is initialized, which will be 5 times 0, because age is not initalized at all, and after that age will be initialized.
Am I correct now?
The first bullet point here explains it, basically if we do things out of order like that it's not garaunteed to work as we could end up using uninitialized values: medium.com/pranayaggarwal25/using-modern-class-members-and-initializations-c11e931c3ba. :-)
@@PortfolioCourses thank you for fast answer! So it turns out, that I noticed that correctly. Thank you again! 😊
@@Klusio19 Yes, sounds like you've got it now. 🙂
21:10 just pointing out that long int (which is the same as long) is the exact same 4 bytes on x64 systems, which are almost every system nowadays. On such systems long and int are identical, therefore there will be no type-narrowing.
7:24 So,the Major class has two constructors,the constructor is invoked based arguments we passed,then its compile time polymorphism i.e function overloading,Am I right?
Amazing😀
.Very helpful
Thank you Sir
You're welcome Jai! 😀 I'm glad you enjoyed the video.
I'm just wondering. What is the difference between major(Major(major)) and major(major) as the member initializer list?
Great question Yuw! 😀 It looks to me like in the first example, an object Major is being instantiated using major as an argument, a bit similar to this code here in terms of the general idea: stackoverflow.com/a/12927220
What will happen if I don't add Major(the class name) in major{Major{major}}
Wow, great question! :-) If we don't put it in, then the constructor for Major will be called and it will be provided with "major" as an argument, which is the same thing that will happen as the code is now. But let's say I have a class SpecialMajor that is a derived class of Major, and let's say it has a constructor that also accepts a string "major" as an argument. Now I *might* want to have the major member variable (with type Major) reference a SpecialMajor object, because it also *is* a Major, it's a dervied type / subtype of Major. But if I want to do that, then I *need* to include the classname like this: major(SpecialMajor(major)) in order for a SpecialMajor object to be instantiated here. Hopefully that helps! :-)
@@PortfolioCourses thanks
You're welcome! :-)
thank you
You’re welcome! :-)
thanks!!
You’re welcome Jose! :-)