directory
- Class 1.
-
-
- 1.1 C++ can use struct, class to define a class
-
-
- Struct and Class
- 1.1.2 Stack space of memory, automatic allocation and reclamation
- 1.1.3 Disassembly comparison of class and struct
- 1.1.4 Memory of the created object
- 1.1.5 Function Memory layout: Member functions do not occupy the memory used to create objects
- 1.1.6 Member variables memory layout: member variables in a class, to create the object’s member variables to open up memory
- 1.1.7 C++ programming specification
-
-
- 2. The object
-
-
- 1.1 Memory layout of objects
-
-
- 1.1.1 Memory layout of multiple member variables in a class
- 1.1.2 Stack space in memory (4 regions)
-
-
- 3. this
-
-
- 3.1 This is a pointer to the current object
- 3.2 When an object calls a member function, it automatically passes in the memory address of the current object
- 3.3 Can member variables be accessed using this.m_age?
- 3.4 The nature of pointer access to object members
- 3.5 Memory allocation of multi-member variables in a class
- 3.6 How do I use Pointers to access member variables of the object I point to indirectly?
-
-
- 3.6.1 Fetching the address of an object from a pointer
- 3.6.2 Use the address of the object + the offset of the member variable to calculate the address of the member variable
- 3.6.3 Accessing the Storage Space of a Member variable Based on its ADDRESS
-
- 3.7 One question detects Pointers and memory
-
-
- 3.7.1 excuse me the person. The display (); What is the print result?
- 3.7.3 offset
- 3.7.4 if p – > display (); The results and person. The display (); What difference does it make?
- 3.7.5 CC -> INT3 instruction
-
-
- 4. Packaging
-
-
- 4.1 Encapsulation is: privatization of member variables
-
- 5. Layout of memory space
-
-
- 5.1 Code Section (Code Area)
- 5.2 Data Segment (Global Area)
- 5.3 stack space
- 5.4 heap space
-
-
- 5.4.1 Application Scenarios
- 5.4.2 Take the initiative to apply and release
- 5.4.3 Parsing malloc in x86 Environments (32-bit
-
- 1) the malloc
- 5.4.4 new \ delete
- 5.4.5 Memset large data processing function
- 5.4.6 Initialization of heap space
- Also 5.4.7 conclusion
-
-
- 6. Object memory
-
-
- 6.1 Object memory can be stored in three places
-
-
- 6.1.1 Global area (data segment) : global variable
- 6.1.2 Stack space: local variables in a function
- 6.1.3 Heap Space: Dynamically Applying for Memory (malloc, New, etc.)
-
-
- 7. Constructor
-
-
- 7.1 This section describes the usage scenarios of constructors
- 7.2 the characteristics of
-
-
- 7.2.1 The function name is the same as the class name, no return value (void cannot be written), can have arguments, can be overloaded, can have multiple constructors
- 7.2.2 Once a custom constructor is defined, the object must be initialized with one of the custom constructors
-
- 7.3 Constructors are not called for objects allocated by malloc
-
-
- 7.3.1 Don’t use malloc for objects (go to New)
-
- 7.4 Fallacy of constructors
-
-
- 7.4.1 A widely circulated erroneous conclusion recommended by many tutorials and books
- 7.4.2 Correct understanding of fallacies
-
- 7.5 Constructor invocation
-
-
- 7.5.1 Constructor calls when creating objects in global area, Stack space, heap space
-
-
- 8. Initialization of member variables
-
-
- 8.1 Global area, stack space, heap space, no constructor initialization member variable difference
-
-
- 8.1.1 Global zone: Member variables initialized to 0 (int type)
- 8.1.2 Stack space: No member variables are initialized
- 8.1.3 heap space
-
- 8.2 Global area, stack space, heap space, there is a constructor to initialize the difference between member variables
-
-
- 8.2.1 Global zone: Member variables initialized to 0 (int type)
- 8.2.2 Stack space: No member variables initialized
- 8.2.3 heap space
-
- 8.3 the conclusion
-
- 9. Destructor (Destructor)
-
-
- 9.1 Introducing the application scenarios of the destructor
- 9.2 the characteristics of
-
-
- 9.2.1 Functions and destructors
- 9.2.2 Pointers and destructors
-
- 9.3 Malloc and free independent constructors and destructors
- 9.4 Global extents and destructors
- 9.4 Constructors and destructors must be public
-
Class 1.
1.1 C++ can use struct, class to define a class
Struct and Class
1) struct default member privilege public 2) class default member privilege private
Create a class using class
#include <iostream>
using namespace std;
class Person {
public:
// Member variables (attributes)
int age;
// Member function (method)
void run(a) {
cout << "Person::run()-"<< age << endl; }};int main(a) {
// instantiate - Create an object with a class
Person person;
person.age = 20;
person.run(a);return 0;
}
Copy the code
Create a class using struct
#include <iostream>
using namespace std;
struct Person {
// Member variables (attributes)
int age;
// Member function (method)
void run(a) {
cout << "Person::run()-"<< age << endl; }};int main(a) {
// instantiate - Create an object with a class
Person person;
person.age = 20;
person.run(a);return 0;
}
Copy the code
1.1.2 Stack space of memory, automatic allocation and reclamation
The memory for the following Person object and p pointer is in the function stack space, automatically allocated and reclaimed
#include <iostream>
using namespace std;
class Person {
public:
// Member variables (attributes)
int age;
// Member function (method)
void run(a) {
cout << "Person::run()-"<< age << endl; }};int main(a) {
// instantiate - Create an object with a class
Person person;
person.age = 20;
person.run(a); Person* p = &person; p->age =30;
p->run(a);return 0;
}
Copy the code
The person object and the P pointer take up 12 bytes (4 bytes person+8 bytes *p)
1.1.3 Disassembly comparison of class and struct
Class compiled disassembly, as follows mov Dword PTR [EBP-0ch],14h
15: Person person;
16: person.age = 20;
01202672 mov dword ptr [ebp-0Ch],14h
Copy the code
Struct compiled in disassembly, as follows mov Dword PTR [EBP-0ch],14h
15: Person person;
16: person.age = 20;
01202672 mov dword ptr [ebp-0Ch],14h
Copy the code
Struct disassembly and class disassembly are essentially the same as struct disassembly except for 1.1.1
1.1.4 Memory of the created object
#include <iostream>
using namespace std;
struct Car {
int price;
void run(a) {
cout << "run()-"<< price << endl; }};int main(a) {
Car car1;
car1.price = 10;
car1.run(a); Car car2; car2.price =20;
car2.run(a); Car car3; car3.price =30;
car3.run(a);return 0;
}
Copy the code
Disassembly of the above code:
1) Each CAR object opens up 4 bytes of storage space in stack space
2) You can see that all run() is compiled to the: call address,
3) All three run() methods have the same address as call. It can be seen that the compiled run() method is not generated in the same memory as the object
1.1.5 Function Memory layout: Member functions do not occupy the memory used to create objects
Member functions (functions in a class) are not stuffed into the object’s total memory when the object is created. Instead, they are compiled and stored in memory alone (if the function is not called, there will be no memory for the function after compilation and optimization). That is, when 100 objects are created, there will be only one memory for the function
Member functions (functions in a class) store different memory from object storage memory
1.1.6 Member variables memory layout: member variables in a class, to create the object’s member variables to open up memory
For example, int occupies 4 bytes in the 64-bit system. The address of the object is the address of the first member variable in the class in sequence
The following objects, car1 to car3, take up 12 bytes in total
1.1.7 C++ programming specification
Variable name specification reference
Usage scenarios | way | The instance |
---|---|---|
The global variable | g_ | g_count |
Member variables | m_ | m_count |
A static variable | s_ | s_count |
constant | c_ | c_count |
2. The object
1.1 Memory layout of objects
1.1.1 Memory layout of multiple member variables in a class
Member variables of a class are stored consecutively in memory
#include <iostream>
using namespace std;
struct Date {
int year;
int month;
int day;
void display(a) {
cout << "year=" << year
<< "month=" << month
<< "day="<< day << endl; }};int main(a) {
Date date;
cout << sizeof(date) << endl;
return 0;
}
Copy the code
Output: 12 an int occupies 4 bytes (same for x64, x86)
1.1.2 Stack space in memory (4 regions)
The date (object) instance of the created class is stored in stack space and is determined by the number of member variables in the class
#include <iostream>
using namespace std;
struct Date {
// This person object has stack space
// Stack space memory is automatically reclaimed
int year;
int month;
int day;
void display(a) {
cout << "year=" << year
<< "month=" << month
<< "day="<< day << endl; }};int main(a) {
Date date;
date.year = 1;
date.month = 3;
date.day = 5;
cout << "&date=" << &date << endl;
cout << "&date.year="<< &date .year<< endl;
cout << "&date.month=" << &date.month << endl;
cout << "&date.day=" << &date.day << endl;
return 0;
}
Copy the code
Two pictures to understand the memory layout
3. this
3.1 This is a pointer to the current object
3.2 When an object calls a member function, it automatically passes in the memory address of the current object
As you can see, the compiler has already optimized for us by evolving the *person pointer to this and then defaulting to this
3.3 Can member variables be accessed using this.m_age?
No, because this is a pointer, you must use this->m_age to access 1). Points can only be left of object 2) -> Arrows can only be left of Pointers
3.4 The nature of pointer access to object members
Ebp-0ch is the address value of the person1 object
[ebP-0ch] [ebP-0ch] [ebP-0ch] [ebP-0ch]
Mov dword PTR [ebP-8] mov dword PTR [ebP-8] mov eax,dword PTR [ebP-8] Eax mov dword PTR [eax]; ========================== assembler code that assigns 3 to the address of this object ============================== 00A51FA0 mov dword ptr [ebp-8],ecx 19: this->m_age = 3; 00A51FAD mov eax,dword ptr [ebp-8] 00A51FB0 mov dword ptr [eax],3
It’s a little tricky here, but you have to understand the code and disassembly together with the description in this article
3.5 Memory allocation of multi-member variables in a class
#include <iostream>
using namespace std;
struct Person
{
int m_id;
int m_age;
int m_height;
void display(a) {
cout << "m_id = " << m_id
<< ",m_age = " << m_age
<< ",m_height = "<< m_height << endl; }};int main(a) {
Person person;
person.m_id = 10;
person.m_age = 20;
person.m_height = 30;
person.display(a); Person* p = &person; p->m_id =10;
p->m_age = 20;
p->m_height = 30;
p->display(a);return 0;
}
Copy the code
The assembly corresponding to the code above
= = = = = = = = = = = = = = = = = = = = = = = = = = object access = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =18: Person person;
19: person.m_id = 10;
009B26D2 mov dword ptr [ebp- 14h],0Ah
20: person.m_age = 20;
009B26D9 mov dword ptr [ebp- 10h],14h
21: person.m_height = 30;
009B26E0 mov dword ptr [ebp0Ch],1Eh
22: person.display();
009B26E7 lea ecx,[ebp- 14h]
009B26EA call 009B104 b = = = = = = = = = = = = = = = = = = = = = = = = = = to access = = = = = = = = = = = = = = = = = = = = = = = = = = = = = =24: Person* p = &person;
009B26EF lea eax,[ebp- 14h]
009B26F2 mov dword ptr [ebp- 20h],eax
25: p->m_id = 10;
009B26F5 mov eax,dword ptr [ebp- 20h]
009B26F8 mov dword ptr [eax],0Ah
26: p->m_age = 20;
009B26FE mov eax,dword ptr [ebp- 20h]
009B2701 mov dword ptr [eax+4].14h
27: p->m_height = 30;
009B2708 mov eax,dword ptr [ebp- 20h]
009B270B mov dword ptr [eax+8].1Eh
28: p->display();
009B2712 mov ecx,dword ptr [ebp- 20h]
009B2715 call 009B104B
Copy the code
We can see that multi-member variables are in object calls:
1) The address of the object, that is, the first address of the first member variable of the class, is as follows: EBP-14h
2) Multiple member variables are allocated consecutively in memory (according to the member code order of the class in the code area, and currently in little-endian mode)
Again, there are two concepts to understand: storage space and address values (mentioned above)
Person 009B26EF Lea eax = person 009B26EF LEA eax = person 009B26EF LEA eax = person 009B26EF Lea eax = person 009B26EF Lea eax Person* p = &person; Person* p = &person; Person* p = &person; = = = = = = = segmentation = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = 25: p – > m_id = 10; P pointer storage space assigned to eax, 009B26F5 mov eAX,dword PTR [EBP-20h] person.m_age =10 009B26F8 MOV dword PTR [eax], 0 division of ah = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = = 26: p – > m_age = 20. 009B26FE mov eax,dword ptr [ebp-20h] 009B2701 mov dword ptr [eax+4],14h 27: p->m_height = 30; 009B2708 mov eax,dword ptr [ebp-20h] 009B270B mov dword ptr [eax+8],1Eh 28: p->display(); 009B2712 mov ecx,dword ptr [ebp-20h] 009B2715 call 009B104B
3.6 How do I use Pointers to access member variables of the object I point to indirectly?
3.6.1 Fetching the address of an object from a pointer
Mov dword PTR [ebP-20h] mov dword PTR [eAX] mov dword PTR [eAX] mov dword PTR [eAX] mov Dword PTR [eAX],14h [[EBP-20h]
3.6.2 Use the address of the object + the offset of the member variable to calculate the address of the member variable
3.6.3 Accessing the Storage Space of a Member variable Based on its ADDRESS
3.7 One question detects Pointers and memory
3.7.1 excuse me the person. The display (); What is the print result?
#include <iostream>
using namespace std;
struct Person
{
int m_id;
int m_age;
int m_height;
void display(a) {
cout << "m_id = " << m_id
<< ",m_age = " << m_age
<< ",m_height = "<< m_height << endl; }};int main(a) {
Person person;
person.m_id = 10;
person.m_age = 20;
person.m_height = 30;
Person* p = (Person * )&person.m_age;
p->m_id = 40;
p->m_age = 50;
person.display(a);return 0;
}
Copy the code
1) Check the offset of the current member variable for the first time
p->m_id = 40; Mov eax,dword PTR [p] mov dowrd PTR [eax+0],40 // m_id = 0 p->m_age = 50; Assembler: mov dword PTR [eAX +4],50 // m_age offset from person address is 4Copy the code
2) Check the offset of p pointer for the second time
Person* p = (Person * )&person.m_age; // &person.m_age p points to &person.m_age, which is the &person +4 offsetCopy the code
3) Reorganize
p->m_id = 40; Mov eax,dword PTR [p] mov dowrd PTR [eAX +0],40 mov dowrd PTR [&person+4+0],40 // equivalent to person. Mov dword PTR [eax+4],50 mov dowrd PTR [&person+4+4],50 // equivalent to person.m_height =50Copy the code
Final output
3.7.3 offset
The offsets referred to here are all written in the order of the member variables of the class, that is, the order in which the machine code of the class is stored in the code area
class Person {
public:
int age; // The sequence starts
intheight; .int phone;// End of sequence
};
Copy the code
3.7.4 if p – > display (); The results and person. The display (); What difference does it make?
// person calls the display() function passing in &person, i.e., display(&person) &person to this person.display(); // display(&person+4) &person+4 is passed to this p->display();Copy the code
M_height = -858993460
3.7.5 CC -> INT3 instruction
0xccccccc
Cc ->int3: interrupts
4. Packaging
4.1 Encapsulation is: privatization of member variables
Provide public getters and setters for outsiders to access member variables
#include <iostream>
using namespace std;
struct Person{
private:
int m_age;
public:
void setAge(int age) {
if (age < 0) return;
m_age = age;
}
int getAge(a) {
returnm_age; }};int main(a) {
Person person;
person.setAge(4);
cout << person.getAge() << endl;
return 0;
}
Copy the code
Output: 4
5. Layout of memory space
Each memory should have its own independent memory space, which generally has the following large areas (one of the “stack space” is “heap space”).
5.1 Code Section (Code Area)
Used to store code (machine code), read-only
5.2 Data Segment (Global Area)
Static is used to store global variables and is present throughout the program unless the process is closed
#include <iostream>
using namespace std;
// Global variables
int g_age = 10;
int main(a) {
return 0;
}
Copy the code
G_age is a global variable
5.3 stack space
Each function is allocated a contiguous stack space, which is automatically reclaimed after the function is called (note: if the heap space is requested, the heap space must be destroyed manually).
#include <iostream>
using namespace std;
int g_age = 10;
// Call test to create contiguous stack space
void test(a) {
int a = 1;
int b = 2;
int c = a + b;
}
int main(a) {
// Automatic allocation when called, automatic collection after called
test(a);return 0;
}
Copy the code
5.4 heap space
5.4.1 Application Scenarios
During program execution, memory in heap space is often used in order to freely control the life cycle and size of memory
5.4.2 Take the initiative to apply and release
malloc \ free
new \ delete
new [ ] \ delete [ ]
5.4.3 Parsing malloc in x86 Environments (32-bit
1) the malloc
Malloc allocates memory to the heap space because the return value is void *, which needs to be cast based on the type
Malloc (n) => free(n) malloc(n) => free(n)
Int is 4 bytes, which is exactly the size of malloc (4)
#include <iostream>
using namespace std;
int main(a) {
int* p = (int *)malloc(4);
*p = 10;
free(p);
//free(p); Do not recycle more than once, malloc once free
return 0;
}
Copy the code
Char is 1 byte and malloc (4) is 4 bytes in size
#include <iostream>
using namespace std;
int main(a) {
char* p = (char*)malloc(4);
*p = '1';
*(p+1) = '2';
*(p+2) = '3';
*(p+3) = '4';
/* p[0] = '1'; p[1] ='2'; p[2] ='3'; p[3] ='4'; * /
cout << *(p) << endl;
cout << *(p + 1) << endl;
cout << *(p + 2) << endl;
cout << *(p + 3) << endl;
free(p);
return 0;
}
Copy the code
* (p + 1) = ‘2’. Equivalent to p[1] = ‘2’; At this time free §; It destroys 4 bytes (because malloc(4)), and does not reclaim only one byte because char is a byte
5.4.4 new \ delete
The one-to-one correspondence between new and delete
void test2(a) {
int* p = new int; // equivalent to (int*)malloc(4);
*p = 10;
delete p;
char* p1 = new char;// equivalent to (char*)malloc(1); Because char takes 1 byte
*p1 = '10';
delete p1;
char* p2 = new char[4];// equivalent to (char*)malloc(4);
delete[] p2;
}
Copy the code
Delete only destroys the memory of the heap to which the pointer points, not the address (content) of the pointer, as explained in the next chapter, singleton Mode
5.4.5 Memset large data processing function
1) memset(first address, value to assign, length); 2) Memset is the assignment of each byte
void test3(a) {
int* p1 = (int*)malloc(sizeof(int));// *p1 is not initialized
int* p2 = (int*)malloc(sizeof(int));
// Two cases of initialization
// Set each of the four bytes to 1, starting at address P1
// 00000001 00000001 00000001 00000001
memset(p2, 1.4);
// Set 4 bytes to 1
// 00000000 00000000 00000000 00000001
}
Copy the code
3) The memset function is a fast way to clear large data structures (such as objects, arrays, etc.) from memory
4) Object initializes the constructor
struct Person {
int m_age;
Person() {
memset(this.0.sizeof(Person)); }};Copy the code
5.4.6 Initialization of heap space
int* p0 = new int; int* p1 = new int(); Int * p2 = new int(5); // int* p2 = new int(5); // initializing with parentheses (not using memset initializing)Copy the code
It can be seen that it is initialized to set 4 bytes to 5 (not the memset used here)
The memory of -842150451 is CD CD CD CD CD
Also 5.4.7 conclusion
1) After the heap space is applied successfully, the address of the memory space will be returned. 2) The relationship between the heap space and the release must be 1 to 1, otherwise there may be memory leakage. 3) Memory management -> Advantages: improve the development efficiency, avoid improper use or leakage of memory. It’s bad for developers to get to the bottom of it, always stuck in API calls and surface syntax sugar, with no way to optimize performance
6. Object memory
6.1 Object memory can be stored in three places
6.1.1 Global area (data segment) : global variable
6.1.2 Stack space: local variables in a function
When the stack space object is initialized, the member variable defaults to cc cc cc cc
So: person.m_age error
6.1.3 Heap Space: Dynamically Applying for Memory (malloc, New, etc.)
7. Constructor
Constructor (constructor) : called automatically when an object is created, usually to complete the initialization of the object
Privatize constructors: Classes can be inaccessible (objects cannot be created)
7.1 This section describes the usage scenarios of constructors
#include <iostream>
using namespace std;
struct Person{
int m_age;
};
int main(a) {
// Introduce the constructor scene
Person person;
person.m_age = 0;
// When creating multiple objects, you need to give each member variable an initial value
Person person1;
person1.m_age = 0;
Person person2;
person2.m_age = 0;
Person person3;
person3.m_age = 0;
return 0;
}
Copy the code
7.2 the characteristics of
7.2.1 The function name is the same as the class name, no return value (void cannot be written), can have arguments, can be overloaded, can have multiple constructors
7.2.2 Once a custom constructor is defined, the object must be initialized with one of the custom constructors
1) Validation: Once you have custom constructors, you must use one of them
#include <iostream>
using namespace std;
struct Person{
int m_age;
Person() {
m_age = 0;
cout << "Person()" << endl;
}
Person(int age) {
m_age = age;
cout << "Person(int age)" << m_age<< endl;
}
void display(a) {
cout << "age is "<< m_age << endl; }};int main(a) {
Person person1; // Use the constructor Person()
person1.display(a);Person person2(20);// Use constructor Person(int age)
person2.display(a);Person person3(30);// Use constructor Person(int age)
person3.display(a);return 0;
}
Copy the code
Person() age is 0 Person(int age)20 age is 20 Person(int age)30 age is 30Copy the code
Violates the rule that custom functions must use one of them
Correct image error: “Lunch” = “no parameter”
7.3 Constructors are not called for objects allocated by malloc
7.3.1 Don’t use malloc for objects (go to New)
Malloc is a legacy of THE C language, which itself has no object-oriented concepts and does not call constructors
#include <iostream>
using namespace std;
struct Person{
int m_age;
Person(int age) {
m_age = age;
cout << "Person::Person(int age)-" << m_age<< endl;
}
void display(a) {
cout << "Person::display()-"<< m_age << endl; }};int main(a) {
Person* p = (Person*)malloc(sizeof(Person));
p->m_age = 44;
p->display(a);return 0;
}
Copy the code
7.4 Fallacy of constructors
7.4.1 A widely circulated erroneous conclusion recommended by many tutorials and books
By default, the compiler generates an empty, parameterless constructor for each class
1) First look at disassembly with constructors
2) Look again at disassembly without constructors
Assembly language call Person::Person is not called at all
7.4.2 Correct understanding of fallacies
In some special cases, the compiler generates an empty, parameterless constructor for a class
7.5 Constructor invocation
7.5.1 Constructor calls when creating objects in global area, Stack space, heap space
#include <iostream>
using namespace std;
struct Person {
int m_age;
Person() {
m_age = 0;
cout << "Person()" << endl;
}
Person(int age) {
m_age = age;
cout << "Person(int age)"<< endl; }}; Person g_person0;// Person()
//Person g_person1(); Function declaration, no object created // direct error
Person g_person2(10);// Person(int)
int main(a) {
Person person0;// Person()
Person person1(a);// Function declaration, no object created
Person person2(20);// Person(int)
Person* p0 = new Person;// Person()
Person* p1 = new Person(a);// Person()
Person* p2 = new Person(30);// Person(int)
return 0;
}
Copy the code
2) Person Person () is a function declaration (see C++ function declaration and implementation).
8. Initialization of member variables
8.1 Global area, stack space, heap space, no constructor initialization member variable difference
The following code:
#include <iostream>
using namespace std;
struct Person {
int m_age;
};
// Global area: member variables are initialized to 0
Person g_person;
int main(a) {
// stack space: no initialized member variables
Person person;
// heap space: no member variables initialized
Person* p0 = new Person;// Person()
// heap space: member variables are initialized to 0
Person* p1 = new Person(a);// Person()
cout << g_person.m_age << endl;
//cout << person.m_age << endl;
cout << p0->m_age << endl;
cout << p1->m_age << endl;
return 0;
}
Copy the code
Output: 0-842150451 0Copy the code
8.1.1 Global zone: Member variables initialized to 0 (int type)
8.1.2 Stack space: No member variables are initialized
(See: 6.1.2 stack space: local variables in functions)
8.1.3 heap space
Person* p0 = new Person; Person* p1 = new Person(); // Person()Copy the code
8.2 Global area, stack space, heap space, there is a constructor to initialize the difference between member variables
#include <iostream>
using namespace std;
struct Person {
int m_age;
Person() {}};// Global area: member variables are initialized to 0
Person g_person;
int main(a) {
// stack space: no initialized member variables
Person person;
// heap space: no member variables initialized
Person* p0 = new Person;// Person()
// heap space: member variables are initialized to 0
Person* p1 = new Person(a);// Person()
cout << g_person.m_age << endl;
//cout << person.m_age << endl;
cout << p0->m_age << endl;
cout << p1->m_age << endl;
return 0;
}
Copy the code
Output: 0-842150451-842150451Copy the code
8.2.1 Global zone: Member variables initialized to 0 (int type)
The presence or absence of constructors does not affect a feature of the global partition memory space
8.2.2 Stack space: No member variables initialized
(See: 6.1.2 stack space: local variables in functions)
8.2.3 heap space
Because of the custom constructor, the heap space no longer initializes objects. Member variables are entirely determined by the constructor
8.3 the conclusion
If the constructor is custom, the member variables of the memory space other than the global area are not initialized by default and need to be manually initialized by the developer
9. Destructor (Destructor)
Destructor (destructor) : Called automatically when an object is destroyed, usually to clean up the object (heap space)
9.1 Introducing the application scenarios of the destructor
Automatically called when the object is destroyed (reclaimed)
#include <iostream>
using namespace std;
struct Person {
int m_age;
// Symbol of the birth of the new Person object
Person() {
cout << "Person:; Person()" << endl;
}
// The new Person object destroys (recycles) the symbol
~Person() {
cout << "~Person"<< endl; }};int main(a) {
Person person;
return 0;
}
Copy the code
9.2 the characteristics of
The function name starts with ~, has the same name as the class, returns no value (void cannot be written), takes no arguments, cannot be overloaded, and has only one destructor.
9.2.1 Functions and destructors
The following code:
#include <iostream>
using namespace std;
struct Person {
int m_age;
// Symbol of the birth of the new Person object
Person() {
cout << "Person:; Person()" << endl;
}
// The new Person object destroys (recycles) the symbol
~Person() {
cout << "~Person"<< endl; }};int main(a) {
{
Person person;
}
return 0;
}
Copy the code
The results
9.2.2 Pointers and destructors
The following code:
#include <iostream>
using namespace std;
struct Person {
int m_age;
// Symbol of the birth of the new Person object
Person() {
cout << "Person:; Person()" << endl;
}
// The new Person object destroys (recycles) the symbol
~Person() {
cout << "~Person"<< endl; }};int main(a) {
Person*p =new Person;
delete p;
return 0;
}
Copy the code
The results
9.3 Malloc and free independent constructors and destructors
The destructor is not called when the object free is allocated by malloc:
#include <iostream>
using namespace std;
struct Person {
int m_age;
// Symbol of the birth of the new Person object
Person() {
cout << "Person:; Person()" << endl;
}
// The new Person object destroys (recycles) the symbol
~Person() {
cout << "~Person"<< endl; }};int main(a) {
Person* p = (Person*)malloc(sizeof(Person));
free(p);
return 0;
}
Copy the code
The results
9.4 Global extents and destructors
As long as the program is running, the destructor cannot be seen unless the process is killed to stop the program conclusion: the global zone does not see the destructor call
9.4 Constructors and destructors must be public
Both constructors and destructors must be declared public before they can be used by outsiders
class Person {
int m_age;
public:
// Symbol of the birth of the new Person object
Person() {
cout << "Person:; Person()" << endl;
}
// The new Person object destroys (recycles) the symbol
~Person() {
cout << "~Person"<< endl; }};Copy the code