dzēst atslēgvārdu programmā C++

dzēšana ir an operators ka ir pieradis iznīcināt masīvu un nav masīvs (rādītājs) objektus kuras dinamiski rada jauns operators.

    dzēšanu var izmantot, izmantojot vai nu dzēst operatoru vai dzēst [ ] operatoru.
  • The jauns operators tiek izmantots dinamiskai atmiņas piešķiršanai, kas saglabā mainīgos lielumus kaudzes atmiņā.
  • Tas nozīmē, ka dzēšanas operators atbrīvo atmiņu no kaudze .
  • Rādītājs uz objektu netiek iznīcināts, tiek iznīcināta rādītāja norādītā vērtība vai atmiņas bloks.
  • Dzēšanas operatoram ir nederīgs atgriešanas veids, kas nozīmē, ka tas neatgriež nekādu vērtību.

Tālāk ir sniegti daži piemēri, kur mēs varam lietot dzēšanas operatoru:

1. Masīva objektu dzēšana

Mēs izdzēšam masīvu, izmantojot [] iekavas.

C++




// Program to illustrate deletion of array> #include> using> namespace> std;> int> main()> {> > // Allocate Heap memory> > int> * array => new> int> [10];> > // Deallocate Heap memory> > delete> [] array;> > return> 0;> }>

2. NULL rādītāja dzēšana

NULL dzēšana neizraisa nekādas izmaiņas un nerada kļūdu.

C++




// C++ program for deleting> // NULLL pointer> #include> using> namespace> std;> int> main()> {> > // ptr is NULL pointer> > int> * ptr = NULL;> > // deleting ptr> > delete> ptr;> > return> 0;> }>

3. Rādītāja dzēšana ar vērtību vai bez tās

Atmiņa, uz kuru norāda norādītais rādītājs, tiks noņemta no kaudzes atmiņas.

C++




// C++ program for deleting pointer with or without value> #include> using> namespace> std;> int> main()> {> > // Creating int pointer> > int> * ptr1 => new> int> ;> > // Initializing pointer with value 20> > int> * ptr2 => new> int> (20);> > cout < <> 'Value of ptr1 = '> < < *ptr1 < <> ' '> ;> > cout < <> 'Value of ptr2 = '> < < *ptr2 < <> ' '> ;> > // Destroying ptr1> > delete> ptr1;> > // Destroying ptr2> > delete> ptr2;> > return> 0;> }>

Izvade

Value of ptr1 = 0 Value of ptr2 = 20 

4. Tukšuma rādītāja dzēšana

Dzēšanas operators ne tikai atbrīvo atmiņu, bet arī izsauc dzēšamā objekta iznīcinātāju. Tāpēc, ja mēs izmantojam tukšuma rādītāju ar dzēšanu, tas novedīs pie nenoteiktas darbības.

C++




// C++ prgram for deleting a void pointer> #include> using> namespace> std;> int> main()> {> > // Creating void pointer> > void> * ptr;> > // Destroying void pointer> > delete> ptr;> > cout < <> 'ptr deleted successfully'> ;> > return> 0;> }>

Izvade

ptr deleted successfully 

5. Malloc() dinamiski piešķirtās atmiņas dzēšana

Malloc() piešķirtās atmiņas atdalīšana, izmantojot dzēšanas operatoru, arī noved pie nedefinētas darbības. Ieteicams izmantot delete for new un free() malloc.

C++




// C++ program for deleting memory dynamically allocated by> // malloc> #include> using> namespace> std;> int> main()> {> > // Dynamic memory allocated by using malloc> > int> * ptr2 = (> int> *)> malloc> (> sizeof> (> int> ));> > delete> ptr2;> > cout < <> 'ptr2 deleted successfully'> ;> > return> 0;> }>

Izvade

ptr2 deleted successfully 

Piezīme : Lai gan iepriekš minētā programma GCC darbojas labi. Nav ieteicams izmantot delete ar malloc().

6. Lietotāja definētu datu tipu mainīgo dzēšana

C++




// C++ program for deleting variables of User Defined data> // types> #include> using> namespace> std;> struct> P {> > // Overloading delete operator for single object> > // deallocation> > static> void> operator> delete> (> void> * ptr,> size_t> sz)> > {> > cout < <> 'custom delete for size '> < < sz < < endl;> > // ::operator delete(ptr) can also be used> > ::operator> delete> (ptr);> > }> > // Overloading delete operator for array deallocation> > static> void> operator> delete> [](> void> * ptr,> size_t> sz)> > {> > cout < <> 'custom delete for size '> < < sz < < endl;> > // ::operator delete(ptr) can also be used> > ::operator> delete> (ptr);> > }> };> int> main()> {> > P* var1 => new> P;> > delete> var1;> > P* var2 => new> P[10];> > delete> [] var2;> }>

Izvade

custom delete for size 1 custom delete for size 18 

Izņēmumi

1. Mēģinājums dzēst objektu bez rādītāja

C++




// C++ program for trying to delete a Non-pointer object> #include> using> namespace> std;> int> main()> {> > int> x;> > // Delete operator always> > // requires pointer as input> > delete> x;> > return> 0;> }>

Izvade

error: type ‘int’ argument given to ‘delete’, expected pointer 

2. Mēģinājums dzēst rādītāju uz lokālā steka piešķirto mainīgo

C++




// C++ program for trying to delete the pointer to a local> // stack-allocated variable> #include> using> namespace> std;> int> main()> {> > int> x;> > int> * ptr1 = &x;> > // x is present on stack frame as> > // local variable, only dynamically> > // allocated variables can be destroyed> > // using delete operator> > delete> ptr1;> > return> 0;> }>

Izvade

main.cpp: In function ‘int main()’: main.cpp:16:12: warning: ‘void operator delete(void*, std::size_t)’ called on unallocated object ‘x’ [-Wfree-nonheap-object] 16 | delete ptr1; | ^~~~ main.cpp:9:9: note: declared here 9 | int x; | ^ free(): invalid pointer 

Saistītie raksti

  • jauns atslēgvārds
  • C++ malloc()