89790

Конструктор и деструктор

Лекция

Информатика, кибернетика и программирование

Для инициализации объектов класса в его определении можно включить специальную компонентную функцию (имя которой совпадает с именем класса), называемую конструктор.

Русский

2015-05-13

85.41 KB

2 чел.

Конструктор и деструктор

Содержание

  1.  Конструктор
  •   в struct
  •   в class
  •   конструктор по умолчанию
  •   копирующий конструктор
  1.  Деструктор

Конструктор

Для инициализации объектов класса в его определении можно включить специальную компонентную функцию (имя которой совпадает с именем класса),  называемую  конструктор.

имя_класса ( список_формальных _параметров) { операторы_тела _конструктора }

  •  Нельзя получить адрес конструктора;
  •  Параметром конструктора не может быть его собственный класс, но может быть ссылка на него;
  •  Конструктор нельзя вызывать как обычную компонентную функцию.

Вызов конструктора:

имя_класса имя_объекта (не_пустой_список_фактических_параметров_конструктора);

имя_класса  * имя_указателя_на_объект_класса = new имя_класса (фактические_параметры_конструктора);

Конструкторы вызываются всякий раз, когда создается объект данного класса. Если список параметров пуст, то скобки можно не ставить, при этом вызывается конструктор по умолчанию. Конструктор с одним аргументом может производить преобразование типов, если при объявлении такого конструктора не используется ключевое слово explicit.

Рассмотрим конструкторы на примере класса goods:

class goods{

float price;

char *name;

int coun;

char prod[50];

}

Конструктор по умолчаниюэто конструктор без параметров. Его можно не определять, но в случае описания массива экземпляров класса, или если в классе описаны поля как указатели, то память автоматически не выделится, поэтому конструктор по умолчанию нужно обязательно прописать!

Пример конструктора по умолчанию:

goods(){

name=new char[1];  

name[0]='\0';

prod[0]='\0';

coun=0;

price=0.0;}

Перегрузка конструкторов

Конструкторов может быть несколько и они могут перегружаться, т.е. вызов того или иного конструктора зависит от входных параметров при инициализации экземпляров класса.

Инициализация данных объекта:

  •  с помощью конструктора через передачу значений параметров в тело конструктора
  •  применение списка инициализаторов данных объекта, который помещается между списком параметров и телом конструктора:

Имя_класса (список_параметров): список_инициализаторов_компонентных_данных {тело_конструктора};

Пример перегруженного конструктора со списком инициализаторов:

goods(float p, int c): coun(c), price(p){ name=new char[1]; name[0]='\0'; prod[0]='\0';}

goods(char *new_name, float new_price):coun(1), price(new_price){

name=new char [strlen(new_name)+1];

strcpy(prod,"magazine"); strcpy(name,new_name); }

Копирующий конструктор

При описании экземпляров класса, в котором существуют динамические поля данных, можно использовать инициализацию через оператор присваивания. В этом случае простая передача данных передаст только адрес указателя, а не сами данные.

Для корректной работы программы нужно описать копирующий конструктор.

Копирующим называется конструктор, который в списке параметров содержит параметр типа определяемого класса:

имя_класса (const имя_класса &);

имя_класса (const имя_класса &, int=0);

Вызов копирующего конструктора производится так

имя_класса имя1_объекта_типа_класс = имя2_объекта_типа_класс;

имя_класса имя1_объекта_типа_класс(имя2_объекта_типа_класс);

Пример копирующего конструктора:

goods (const goods& f){

name=new char[strlen(f.name)+1];

strcpy(name, f.name);

coun=f.coun;

price=f.price;

strcpy(prod, f.prod);}

Деструктор (разрушитель объектов)

Компонентная функция, предназначенная для освобождения памяти при уничтожении динамически созданного объекта, называется деструктором и имеет формат:

~имя_класса() {операторы_тела деструктора};

  •  Деструктор не имеет параметров (даже типа void).
  •  Деструктор не имеет возвращаемого значения.
  •  Вызов деструктора выполняется неявно, автоматически, как только объект класса уничтожается или завершается выполнение программы.

Пример описания деструктора:

~goods()

{

  delete name;

}

Пример # 3. Товары склада

#include <iostream>

#include <string.h>

using namespace std;

class goods{

float price;

char *name;

int coun;

char prod[50];

public:

goods(){

name=new char[1];  

name[0]='\0';

prod[0]='\0';

coun=0;

price=0.0;}

goods(float p, int c): coun(c), price(p){

name=new char[1]; name[0]='\0'; prod[0]='\0';}

goods(char *new_name, float new_price):coun(1), price(new_price){

name=new char [strlen(new_name)+1];

strcpy(prod,"magazine"); strcpy(name,new_name); }

goods (const goods& f){

name=new char[strlen(f.name)+1];

strcpy(name, f.name);

coun=f.coun;

price=f.price;

strcpy(prod, f.prod);}

~goods()

{

  delete name;

}

//Метод для вывода данных

void show(){ cout << name << ":“ << prod << «->“ << price << "*“ <<  

coun << "=“  << price*coun << endl;

}

};

//Главная программа

int main()

{

goods a("name",12.5);

goods c(56.0,100), d;

goods b=a;

a.show();    c.show();

d.show();    b.show();

return 0;

}

Пример #4. Символьная строка

Создадим класс «символьная строка». Определим следующие компоненты класса:

  •  Указатель на текстовую строку
  •  Длина строки
  •  Печатает информацию о строке

//stroka.cpp

#include <string.h>

#include <iostream.h>

#include <locale.h>

class stroka

{//скрытые от внешнего доступа данные

char *ch;

int len;

public://конструкторы объектов класса

stroka (int N=80): len(0)

{// выделяем память для массива строк

ch=new char[N+1];  ch[0]=‘\0’;}

// создает объект по заданной строке

stroka (const char *arch)

{len=strlen(arch); ch=new char[len+1]; strcpy(ch,arch);}

int& len_str(void)//возвращает ссылку на длину строки

{return len;}

char *strings(void)//возвращает указатель на строку                

{return ch;}

void display(void)//печатает  информацию о строке

{cout<<“\nДлина строки:”<<len;

cout<<“\nСодержимое строки:”<<ch;}

//Деструктор-освобождает память объекта

~stroka() { delete [] ch;} };

int main()

{

setlocale(LC_ALL,Russian”);

stroka s1,s2(5),s3("infoznaika");

cout << "Dlina stroki "<< s3.strings()<< "="<<s3.len_str()<< endl;

s2.display();

return 0;

}


 

А также другие работы, которые могут Вас заинтересовать

18832. Комерційні банки 268 KB
  Тема 10 Комерційні банки. 1. Поняття призначення та класифікація комерційних банків. 2. Походження та розвиток комерційних банків. 3. Основи організації та специфіка діяльності окремих видів комерційних банків. 4. Активні та пасивні операції комерційних банків. 5. Р...
18833. Валютний ринок і валютні системи 552 KB
  Тема 11: Валютний ринок і валютні системи. Сутність валюти та валютних відносин. Конвертованість валюти. Валютний ринок. Види операцій на валютному ринку. Валютний курс. Валютні системи та валютна політика. Платіжний баланс. Світова валютна система ...
18834. Міжнародні валютно-кредитні установи та форми їх співробітництва з Україною 141.5 KB
  ТЕМА 12 : Міжнародні валютнокредитні установи та форми їх співробітництва з Україною МВФ і його діяльність в Україні 2 Світовий банк 3 Регіональні міжнародні кредитнофінансові інституції 4.Європейськийбанк реконструкції та розвитку 5. Банк міжнарод...
18835. Расчет схемы по постоянному току 146.77 KB
  Расчет схемы по постоянному току. Режим работы схемы по постоянному току определяется элементами: RК RЭ EК EЭ и характеристиками транзистора VT. Запишем уравнения Кирхгофа для выходной цепи: Уравнение 1 представляет собой уравнение прямой которую называют наг...
18836. Расчет по переменному току 269.85 KB
  Расчет по переменному току. Принципиальная схема усилителя имеет вид приведенный на Рис. 3.4.. Рис. 3.4 принципиальная схема усилителя с ОБ. Разделительные конденсаторы СР1 и СР2 нужны для того чтобы: 1 источник входного сигнала и нагрузка не изменяли режим работы тр...
18837. Схема с общей базой 164.86 KB
  Схема с общей базой. При проектировании усилителей на биполярных транзисторах входной переход транзистора всегда включают в прямом направлении а выходной в обратном. На Рис. 3.1 приведена схема усилителя на биполярном транзисторе включенном с общей базой ОБ. Рис. 3...
18838. Расчет по постоянному току 192.58 KB
  Расчет по постоянному току. Режим работы усилителя по постоянному току определяется элементами EК RК RБ и параметрами транзистора VT. Критерии выбора транзистора следующие: по значению граничной частоты усилителя; по предельнодопустимым параметрам UКЭдоп PРас.до
18839. Расчет по переменному току 157.73 KB
  Расчет по переменному току. Для расчету по переменному току необходимо: 1 начало координат на характеристиках транзистора перенести в рабочую точку О по постоянному току. В рабочей точке определить для бесконечно малых приращений параметры транзистора. Наиболее ис
18840. Определение входного сопротивления 79.52 KB
  Определение входного сопротивления Опишем линейную модель усилителя системой уравнений в соответствии с 1 и 2 законами Кирхгофа: Из уравнения 2 определим: и подставим в уравнение 1. Отсюда находим входное сопротивление транзистора. При напряжении колл...