Klasa i obiekt C ++ z przykładem

Spisie treści:

Anonim

Co to jest klasa?

Klasa C ++ łączy dane i metody manipulowania danymi w jedno. Ćwiczenia określają także formy przedmiotów. Dane i metody zawarte w klasie są nazywane elementami członkowskimi klasy. Klasa to typ danych zdefiniowany przez użytkownika. Aby uzyskać dostęp do członków klasy, używamy instancji klasy. Możesz zobaczyć klasę jako plan obiektu.

Klasa będzie prototypem domu. Pokazuje położenie i rozmiary drzwi, okien, podłóg itp. Na podstawie tych opisów możemy zbudować dom. Dom staje się przedmiotem. Z prototypu można stworzyć wiele domów. Możliwe jest również tworzenie wielu obiektów z klasy.

Na powyższym rysunku mamy jeden prototyp domu. Na podstawie tego prototypu stworzyliśmy dwa domy o różnych cechach.

W tym samouczku dowiesz się:

  • Co to jest klasa?
  • Przykład klasy
  • Prywatne i publiczne słowa kluczowe
  • Definicja obiektu
  • Dostęp do członków danych
  • Funkcje składowe klasy
  • Konstruktorzy i niszczyciele

Deklaracja klasy

W języku C + klasa jest definiowana za pomocą słowa kluczowego class. Powinna po niej następować nazwa klasy. Treść klasy jest następnie dodawana między nawiasami klamrowymi {}.

Składnia:

class class-name{// data// functions};
  • Nazwa klasy to nazwa, która ma zostać przypisana do klasy.
  • Dane to dane dla klasy, zwykle deklarowane jako zmienne.
  • Funkcje są funkcjami klasowymi.

Prywatne i publiczne słowa kluczowe

Musiałeś trafić na te dwa słowa kluczowe. Są modyfikatorami dostępu.

  • Prywatny:

Gdy słowo kluczowe private jest używane do zdefiniowania funkcji lub klasy, staje się prywatne. Takie są dostępne tylko z poziomu klasy.

  • Publiczny:

Z drugiej strony słowo kluczowe public upublicznia dane / funkcje. Są dostępne spoza klasy.

Definicja obiektu

Obiekty są tworzone z klas. Obiekty klas są deklarowane w podobny sposób, jak deklarowane są zmienne. Musi zaczynać się nazwa klasy, po której następuje nazwa obiektu. Obiekt typu klasy.

Składnia:

class-name object-name;
  • Nazwa klasy to nazwa klasy, z której ma zostać utworzony obiekt.
  • Nazwa obiektu to nazwa, która ma zostać przypisana do nowego obiektu.

Ten proces tworzenia obiektu z klasy jest nazywany tworzeniem instancji.

Dostęp do członków danych

Aby uzyskać dostęp do publicznych członków klasy, używamy operatora kropki (.). Są to członkowie oznaczeni modyfikatorem dostępu publicznego.

Przykład 1:

#include using namespace std;class Phone {public:double cost;int slots;};int main() {Phone Y6;Phone Y7;Y6.cost = 100.0;Y6.slots = 2;Y7.cost = 200.0;Y7.slots = 2;cout << "Cost of Huawei Y6 : " << Y6.cost << endl;cout << "Cost of Huawei Y7 : " << Y7.cost << endl;cout << "Number of card slots for Huawei Y6 : " << Y6.slots << endl;cout << "Number of card slots for Huawei Y7 : " << Y7.slots << endl;return 0;}

Wynik:

Oto zrzut ekranu kodu:

Objaśnienie kodu:

  1. Dołącz plik nagłówkowy iostream do naszego kodu, aby móc korzystać z jego funkcji.
  2. Dołączanie przestrzeni nazw std do naszego kodu, aby używać jej klas bez wywoływania jej.
  3. Zadeklaruj klasę o nazwie Phone.
  4. Użycie modyfikatora dostępu publicznego, aby oznaczyć zmienne, które zamierzamy utworzyć, jako publicznie dostępne.
  5. Zadeklaruj zmienny koszt podwójnego typu danych.
  6. Zadeklaruj zmienną całkowitą o nazwie slots.
  7. Koniec treści klasy.
  8. Wywołanie funkcji main (). Logikę programu należy dodać w jego treści.
  9. Utwórz obiekt o nazwie Y6 typu Phone. Nazywa się to tworzeniem instancji.
  10. Utwórz obiekt o nazwie Y7 typu Phone. Nazywa się to tworzeniem instancji.
  11. Uzyskaj dostęp do zmiennej / kosztu składowego klasy Phone za pomocą obiektu Y6. Wartość jest ustawiona na 100,0. Koszt Y6 jest teraz ustawiony na 100,0.
  12. Uzyskaj dostęp do pól zmiennych / składowych klasy Phone za pomocą obiektu Y6. Wartość jest ustawiona na 2. Szczeliny dla Y6 są teraz ustawione na 2.
  13. Uzyskaj dostęp do zmiennej / kosztu składowego klasy Phone za pomocą obiektu Y7. Wartość jest ustawiona na 200,0. Koszt Y7 wynosi teraz 200,0.
  14. Uzyskaj dostęp do pól zmiennych / składowych klasy Phone za pomocą obiektu Y7. Wartość jest ustawiona na 2. Szczeliny dla Y7 są teraz ustawione na 2.
  15. Wydrukuj koszt Y6 na konsoli obok innego tekstu.
  16. Wydrukuj koszt Y7 na konsoli obok innego tekstu.
  17. Wydrukuj liczbę gniazd dla Y6 obok innego tekstu.
  18. Wydrukuj liczbę gniazd dla Y7 obok innego tekstu.
  19. Program musi zwrócić wartość po pomyślnym zakończeniu.
  20. Koniec treści funkcji main ().

Co to jest klasa prywatna?

Dostęp do członków klasy oznaczonych jako prywatne są dostępne tylko przez funkcje zdefiniowane w klasie. Żaden obiekt lub funkcja zdefiniowana poza klasą nie może uzyskać bezpośredniego dostępu do takich elementów członkowskich. Dostęp do członka klasy prywatnej mają tylko funkcje członka i znajomego.

Co to jest klasa chroniona?

Członkowie klasy oznaczeni jako chronione mają przewagę nad członkami oznaczonymi jako prywatne. Dostęp do nich można uzyskać za pomocą funkcji należących do klasy ich definicji. Ponadto można uzyskać do nich dostęp z klas pochodnych.

Przykład 2:

#include using namespace std;class ClassA {public:void set_a(int val);int get_a(void);private:int a;};int ClassA::get_a(void) {return a;}void ClassA::set_a(int val) {a = val;}int main() {ClassA a;a.set_a(20);cout << "Value of a is: " << a.get_a();return 0;}

Wynik:

Oto zrzut ekranu kodu:

Objaśnienie kodu:

  1. Dołącz plik nagłówkowy iostream do naszego kodu, aby móc korzystać z jego funkcji.
  2. Uwzględnij przestrzeń nazw std w naszym kodzie, aby używać jej klas bez wywoływania jej.
  3. Utwórz klasę o nazwie ClassA.
  4. Użyj modyfikatora dostępu publicznego, aby oznaczyć element członkowski klasy, który ma zostać utworzony, jako publicznie dostępny.
  5. Utwórz funkcję o nazwie set_a (), która przyjmuje jedną wartość całkowitą val.
  6. Utwórz funkcję o nazwie get_a ().
  7. Użyj modyfikatora dostępu prywatnego, aby oznaczyć element członkowski klasy, który ma zostać utworzony, jako dostępny prywatnie.
  8. Zadeklaruj zmienną całkowitą o nazwie a.
  9. Koniec treści klasy.
  10. Użyj nazwy klasy i operatora rozpoznawania zakresu, aby uzyskać dostęp do funkcji get_a (). Chcemy zdefiniować, co robi funkcja po wywołaniu.
  11. Funkcja get_a () powinna po wywołaniu zwrócić wartość zmiennej a.
  12. Koniec definicji funkcji get_a ().
  13. Użyj nazwy klasy i operatora rozpoznawania zakresu, aby uzyskać dostęp do funkcji set_a (). Chcemy zdefiniować, co robi funkcja po wywołaniu.
  14. Przypisanie wartości zmiennej val do zmiennej a.
  15. Koniec definicji funkcji set_a ().
  16. Wywołaj funkcję main (). Logikę programu należy dodać w treści tej funkcji.
  17. Utwórz instancję klasy ClassA i nadaj jej nazwę.
  18. Użyj powyższej instancji klasy i funkcji set_a (), aby przypisać wartość 20 do zmiennej a.
  19. Drukowanie tekstu obok wartości zmiennej a na konsoli. Wartość zmiennej a uzyskuje się poprzez wywołanie funkcji get_a ().
  20. Program musi zwrócić wartość po pomyślnym zakończeniu.
  21. Koniec treści funkcji main ().

Przykład 3:

#include using namespace std;class ParentClass {protected:int value;};class ChildClass : public ParentClass {public:void setId(int x) {value = x;}void displayValue() {cout << "Value is: " << value << endl;}};int main() {ChildClass c;c.setId(21);c.displayValue();return 0;}

Wynik:

Oto zrzut ekranu kodu:

Objaśnienie kodu:

  1. Dołącz plik nagłówkowy iostream do naszego kodu, aby móc korzystać z jego funkcji.
  2. Uwzględnij przestrzeń nazw std w naszym kodzie, aby używać jej klas bez wywoływania jej.
  3. Utwórz klasę o nazwie ParentClass.
  4. Użyj modyfikatora dostępu chronionego, aby oznaczyć element członkowski klasy, który ma zostać utworzony, jako chroniony.
  5. Utwórz zmienną całkowitą o nazwie value.
  6. Koniec treści klasy.
  7. Utwórz nową klasę o nazwie ChildClass, która dziedziczy ParentClass.
  8. Użyj modyfikatora dostępu chronionego, aby oznaczyć element członkowski klasy, który ma zostać utworzony, jako dostępny dla klas podrzędnych.
  9. Utwórz funkcję o nazwie setId (), która przyjmuje jedną wartość całkowitą x.
  10. Przypisanie wartości zmiennej x do wartości zmiennej.
  11. Koniec definicji funkcji setId ().
  12. Utwórz funkcję o nazwie displayValue ().
  13. Wydrukuj wartość zmiennej o nazwie value na konsoli razem z innym tekstem.
  14. Koniec treści funkcji displayValue ().
  15. Koniec treści klasy o nazwie ChildClass.
  16. Wywołaj funkcję main (). Logikę programu należy dodać w treści tej funkcji.
  17. Utwórz wystąpienie ChildClass i nadaj mu nazwę c.
  18. Użyj powyższej instancji klasy i funkcji setId (), aby przypisać wartość 21 do zmiennej x.
  19. Użyj powyższej instancji klasy, aby wywołać funkcję o nazwie displayValue ().
  20. Program musi zwrócić wartość po pomyślnym zakończeniu.
  21. Koniec treści funkcji main ().

Funkcje składowe klasy

Funkcje pomagają nam manipulować danymi. Funkcje składowe klasy można zdefiniować na dwa sposoby:

  • W definicji klasy
  • Poza definicją klasy

Jeśli funkcja ma być zdefiniowana poza definicją klasy, musimy użyć operatora rozpoznawania zasięgu (: :). Powinny temu towarzyszyć nazwy klas i funkcji.

Przykład 2:

#include #include using namespace std;class Guru99{public:string tutorial_name;int id;void printname();void printid(){cout << "Tutorial id is: "<< id;}};void Guru99::printname(){cout << "Tutorial name is: " << tutorial_name;}int main() {Guru99 guru99;guru99.tutorial_name = "C++";guru99.id = 1001;guru99.printname();cout << endl;guru99.printid();return 0;}

Wynik:

Oto zrzut ekranu kodu:

Objaśnienie kodu:

  1. Dołącz plik nagłówkowy iostream do naszego programu, aby móc korzystać z jego funkcji.
  2. Dołącz plik nagłówkowy ciągu do naszego programu, aby móc korzystać z jego funkcji.
  3. Uwzględnij przestrzeń nazw std w naszym kodzie, aby używać jej klas bez wywoływania jej.
  4. Utwórz klasę o nazwie Guru99.
  5. Użyj modyfikatora dostępu publicznego, aby oznaczyć członków klasy, które zamierzamy utworzyć, jako publicznie dostępnych.
  6. Utwórz zmienną łańcuchową o nazwie tutorial_name.
  7. Utwórz zmienną całkowitą o nazwie id.
  8. Utwórz funkcję o nazwie printname (). Ta funkcja nie jest zdefiniowana w definicji klasy.
  9. Utwórz funkcję o nazwie print (). Ta funkcja jest zdefiniowana w definicji klasy. Jego treść została dodana w definicji klasy.
  10. Wydrukuj wartość zmiennej id obok innego tekstu na konsoli. Zauważ, że zostało to dodane w treści funkcji printid (). Zostanie wykonane tylko wtedy, gdy zostanie wywołana funkcja printid ().
  11. Koniec treści funkcji printid ().
  12. Koniec treści klasy Guru99.
  13. Początek definicji funkcji printname ().
  14. Wydrukuj wartość zmiennej tutorial_name na konsoli razem z innym tekstem. Zauważ, że zostało to dodane w treści funkcji printname (). Zostanie wykonane tylko wtedy, gdy zostanie wywołana funkcja printname ().
  15. Koniec definicji funkcji printname ().
  16. Wywołaj funkcję main (). Logikę programu należy dodać w treści tej funkcji.
  17. Utwórz instancję klasy Guru99 i nadaj jej nazwę guru99.
  18. Użyj powyższego wystąpienia, aby przypisać wartość C ++ do zmiennej tutorial_name.
  19. Użyj instancji guru99, aby przypisać wartość 1001 do zmiennej id.
  20. Użyj instancji guru99, aby wywołać funkcję printname ().
  21. Wywołaj polecenie end (end line), aby wydrukować nowy pusty wiersz na konsoli.
  22. Użyj instancji guru99, aby wywołać funkcję printid ().
  23. Program musi zwrócić wartość po pomyślnym zakończeniu.
  24. Koniec treści funkcji main ().

Konstruktorzy i niszczyciele

Co to są konstruktorzy?

Konstrukcje to specjalne funkcje, które inicjalizują obiekty. Kompilatory C ++ wywołują konstruktor podczas tworzenia obiektu. Konstruktory pomagają przypisywać wartości członkom klasy. Oczywiście dzieje się tak po przydzieleniu im miejsca w pamięci.

Co to są destruktory?

Z drugiej strony niszczyciele pomagają niszczyć obiekty klasowe.

Nazwa konstruktora musi być podobna do nazwy klasy. Konstruktory nie mają typu zwracanego.

Konstruktor można zdefiniować wewnątrz lub na zewnątrz treści klasy. Jeśli jest zdefiniowany poza treścią klasy, powinien być zdefiniowany za pomocą nazwy klasy i operatora rozpoznawania zakresu (: :).

Przykład 3:

#include using namespace std;class ClassA {public:ClassA() {cout << "Class constructor called"<

Wynik:

Oto zrzut ekranu kodu:

Objaśnienie kodu:

  1. Dołącz plik nagłówkowy iostream do kodu, aby używać jego funkcji.
  2. Uwzględnij przestrzeń nazw std w naszym kodzie, aby używać jej klas bez wywoływania jej.
  3. Utwórz klasę o nazwie ClassA.
  4. Użyj modyfikatora dostępu publicznego, aby oznaczyć członka, który zamierzamy utworzyć, jako publicznie dostępny.
  5. Utwórz konstruktora dla klasy.
  6. Tekst do wydrukowania na konsoli po wywołaniu konstruktora. Endl to słowo kluczowe C ++, które oznacza linię końcową. Przenosi kursor myszy do następnej linii.
  7. Koniec treści konstruktora klasy.
  8. Utwórz destruktor dla klasy.
  9. Tekst do wydrukowania na konsoli po wywołaniu destruktora. Endl to słowo kluczowe C ++, które oznacza linię końcową. Przenosi kursor myszy do następnej linii.
  10. Koniec ciała destruktora.
  11. Koniec treści klasy.
  12. Wywołaj funkcję main (). Logikę programu należy dodać w treści tej funkcji.
  13. Utwórz obiekt klasy i nadaj mu nazwę. Zostanie wywołany konstruktor.
  14. Utwórz zmienną całkowitą o nazwie p i przypisz jej wartość 1.
  15. Utwórz blok instrukcji if za pomocą zmiennej p.
  16. Utwórz obiekt klasy i nadaj mu nazwę b. Zostanie wywołany destruktor.
  17. Koniec treści instrukcji if.
  18. Koniec treści funkcji main ().

Podsumowanie:

  • C ++ jest zorientowany obiektowo.
  • Klasy to główne cechy C ++, które sprawiają, że jest on zorientowany obiektowo.
  • Klasa C ++ łączy dane i metody manipulowania danymi w jedno.
  • Klasa to plan obiektu.
  • Klasy określają formę przedmiotu.
  • Dane i metody zawarte w klasie są nazywane elementami członkowskimi klasy.
  • Aby uzyskać dostęp do członków klasy, należy użyć wystąpienia tej klasy.
  • Aby utworzyć klasę, używamy słowa kluczowego class.
  • Funkcje składowe klasy można definiować wewnątrz lub na zewnątrz klasy.