7. přednáška - třídy, objekty třídy objekty atributy tříd metody tříd
|
|
- Štěpánka Procházková
- před 7 lety
- Počet zobrazení:
Transkript
1 7. přednáška - třídy, objekty třídy objekty atributy tříd metody tříd Algoritmizace (Y36ALG), Šumperk - 7. přednáška 1
2 Třída jako zdroj funkcionality Třída v jazyku Java je programová jednotka tvořená množinou identifikátorů, které mají třídou definovaný význam a které označují prostředky, které lze v téže či jiných třídách využít. Třída je zdrojem metod popisujících řešení problému rozkladem na podproblémy. Uvnitř třídy mohou být deklarovány proměnné, které jsou použitelné jako nelokální proměnné v metodách dané třídy. Algoritmizace (Y36ALG), Šumperk - 7. přednáška 2
3 Metoda main Povinným základem aplikace, tj. uživatelského programu, je třída, ve které je deklarována spouštěcí metoda přesně takto: public static void main( String[ ] args ) {... Pozn. 1: Metoda main musí být statická, voláme ji dříve než se vytvoří nějaký objekt. Pozn. 2: V jiných jazycích, např. v C++, lze program vytvořit bez použití třídy. Každá třída může obsahovat metodu main, pak se využívá pro: testování funkčnosti objektu, ukázku použití metod objektu. Mnohé třídy nemají deklaraci metody main: např. knihovní třída java.lang.math poskytující matematické funkce Algoritmizace (Y36ALG), Šumperk - 7. přednáška 3
4 Třída jako datový typ Třída je popisem strukturovaného datového typu, tzn. specifikuje datové prvky potřebné pro objekt (proměnné a konstanty; je v nich uložen stav objektu) a množinu metod pro práci s datovými prvky (manipulují s proměnnými, čímž mění stav objektu). Pozn.: Třída sama o sobě nemá přidělenu žádnou paměť. Nedá sepracovat ani s proměnnými ani s metodami (pokud nejsou deklarovány jako static). Objekt (nazývá se též instance třídy) je datový prvek, který je vytvořen podle vzoru třídy. Podle jednoho vzoru třídy lze vytvořit libovolné množství objektů (instancí). V jazyku Java lze objekty vytvářet pouze dynamicky pomocí operátoru new a přistupovat k nim pomocí referenčních proměnných. Algoritmizace (Y36ALG), Šumperk - 7. přednáška 4
5 Třída Třída je návrhový vzor, který umožňuje definovat vlastnosti a chování vlastnosti atributy (proměnné a konstanty) chování metody (funkce a procedury) Příklad: Třída (šablona) obdélník atributy (vlastnosti): šířka, výška, barva, pozice na obrazovce, metody (chování, reakce na požadavky okolí) nastavení barvy, výpočet obvodu, obsahu, posunutí, Algoritmizace (Y36ALG), Šumperk - 7. přednáška 5
6 Obdélník - příklad definice třídy public class Obdelnik { Color barva; int sirka, vyska; Point pozice; Jméno třídy začíná velkým písmenem Atributy objektu - definují typ a jména vlastností int vypoctiobvod(){ return 2*(sirka+vyska); int vypoctiobsah(){ return sirka*vyska; void nastavbarvu(color c){ barva = c; Metody objektu - definují chování, schopnosti, reakce Algoritmizace (Y36ALG), Šumperk - 7. přednáška 6
7 Obdélník - příklad definice třídy public class Obdelnik { Color barva; int sirka, vyska; Point pozice; Jméno třídy začíná velkým písmenem Atributy objektu - definují typ a jména vlastností int obvod(){ return 2*(sirka+vyska); int obsah(){ return sirka*vyska; void nastavbarvu(color c){ barva = c; Metody objektu - definují chování, schopnosti, reakce Metody mohou používat atributy - proměnné. Neobsahují-li klíčové slovo static, pracují s konkrétním objektem. Algoritmizace (Y36ALG), Šumperk - 7. přednáška 7
8 Konstruktor Speciální metoda - konstruktor třídy nastavuje vlastnosti objektu prostřednictvím parametrů (ale může být i bez parametrů), neosahuje návratový typ - nic nevrací, vytváří objekt, jméno je totožné se jménem třídy (jediná metoda začínající velkým písmenem), tato metoda vytvoří objekt, public class Obdelnik {... Obdelnik(int s, int v){ sirka = s; vyska = v; volá se pomocí operátoru new. malyobdelnik = new Obdelnik(2,5); nezapomeňte na deklaraci referenční proměnnémalyobdelnik. Algoritmizace (Y36ALG), Šumperk - 7. přednáška 8
9 Třída versus objekt Třída návrhový vzor, šablona, reprezentovaná zápisem v Javě, existuje i mimo program. Příklad: třída: Obdelnik Objekt jeden konkrétní výrobek vyrobený podle třídy, je vytvořen za běhu programu, žije během života programu (lze jej uložit na disk, není reprezentován kódem programu. Obdelnik maly = new Obdelnik(1,5); Obdelnik velky = new Obdelnik(10,5); Algoritmizace (Y36ALG), Šumperk - 7. přednáška 9
10 Přetížení konstruktorů public class Complex { double re, im; Complex(){ re = 0.0; im = 0.0; Complex(double re){ this.re = re; this.im = 0.0; Complex(double re, double im){ this.re = re; this.im = im; re... členská globální proměnná třídy re... lokální proměnná metody Operátor this je implicitní parametr každé metody, odkazující na tuto instanci. Bez něj by lokální proměnná re, reprezentovaná form. parametrem metody, zastínila nelokální proměnnou re, deklarovanou pro třídu. Algoritmizace (Y36ALG), Šumperk - 7. přednáška 10
11 Přetížení konstruktorů public class Complex { double re, im; Complex(){ re = 0.0; im = 0.0; Complex(double re){ this.re = re; this.im = 0.0; Complex(double re, double im){ this.re = re; this.im = im; Co vytvoří tyto příkazy? 1. Complex c1 = new Complex(); 2. Complex c2 = new Complex(1); 3. Complex c3 = new Complex(1,1); Algoritmizace (Y36ALG), Šumperk - 7. přednáška 11
12 Přetížení konstruktorů: Obdelnik import java.awt.color; import java.awt.point; public class Obdelnik { Color barva; double sirka, vyska; Point pozice; // Konstruktory Obdelnik(){ sirka = vyska = 0; Obdelnik(double a){ sirka = vyska = a; Obdelnik(double sirka, double vyska){ this.sirka = sirka; this.vyska = vyska; Obdelnik(Obdelnik o){ sirka = o.sirka; // parametrem může být i jiný objekt vyska = o.vyska;... Algoritmizace (Y36ALG), Šumperk - 7. přednáška 12
13 Přetížení konstruktorů II Budeme chtít konstruktor, který u vytvářeného obdélníku specifikuje jeho barvu. public class Obdelnik {... Stejný kód. Obdelnik(int s, int v){ Správné by bylo použití jednoho sirka = s; místa pro tento kód. vyska = v; Jednodušší opravy. Obdelnik(int s, int v, Color c){ sirka = s; vyska = v; barva = c; Algoritmizace (Y36ALG), Šumperk - 7. přednáška 13
14 Vzájemné volání konstruktorů Vytvoříme jeden univerzální konstruktor a ostatní jej budou volat. public class Obdelnik {... Obdelnik(int s, int v){ this(s,v,color.black); nastavení implicitní hodnoty volání konstruktoru téže třídy Obdelnik(int s, int v, Color c){ sirka = s; vyska = v; barva = c; Algoritmizace (Y36ALG), Šumperk - 7. přednáška 14
15 Třída pro testování obdélníka public class Obdelnik {... public static void main(string[] args) { Obdelnik maly; maly = new Obdelnik(1,5); Obdelnik velky = new Obdelnik(10,5); System.out.println( Obvod maleho je + maly.obvod()); Není třeba předávat šířku a výšku, každá instance zná své rozměry!! maly 2*(sirka * vyska) = 2 * (1 + 5) = 12 velky Algoritmizace (Y36ALG), Šumperk - 7. přednáška 15
16 Statické a instanční metody Pod pojmem metoda se skrývají dva druhy metod: instanční metody (metody objektů), statické metody (metody třídy). Oba druhy mohou mít parametry a mohou vracet výsledek. Instanční metoda označuje operaci nad objektem čili instancí dané třídy. Je dostupná jen přes referenci na objekt. Voláme ji tedy takto: referenčníproměnná.jménometody( seznam argumentů ) např. maly.vypoctiobvod() vidí statické i nestatické atributy třídy. Zkráceněříkáme, že metoda vypoctiobvod() se volá na objekt maly. Statická metoda je dostupná pomocí jména třídy, aniž je nutno vytvářet nějaký objekt. Voláme ji tedy takto: JménoTřídy.jménoMetody( seznam argumentů ) a také referenčníproměnná.jménometody( seznam argumentů ) Algoritmizace (Y36ALG), Šumperk - 7. přednáška 16
17 Statické metody public class Obdelnik { int sirka. static int vratpocetrohu(){ // sirka = 6; CHYBA, statická metoda nevidí instanční proměnné! return 4; public class ObdelnikTest { public static void main(string[] args) { Obdelnik maly = new Obdelnik(1,5); System.out.println("Pocet rohu obdelnika je " + Obdelnik.vratPocetRohu()); System.out.println("Maly obdelnik ma " + maly.vratpocetrohu() + " rohu."); vypíše 4 4 Algoritmizace (Y36ALG), Šumperk - 7. přednáška 17
18 Statické atributy a metody Některé třídy obsahují pouze statické atributy a statické metody. Knihovna matematických funkcí třída java.lang.math obsahuje statické proměnné (zde konstanty typu double) PI a E. Statické metody reprezentující matematické funkce: sin, cos, tan, goniometrické funkce abs absolutní hodnota min, max log logaritmus sqrt odmocnina pow(double a, double b) a b random vrací náhodné double číslo z intervalu 0;1) round zaokrouhlení a mnohé další Algoritmizace (Y36ALG), Šumperk - 7. přednáška 18
19 Standardní metody třídy Object Každá třída (kromě jediné) v Javě je potomkem třídy Object, která implementuje několik základních metod. Základní metody třídy Object jsou tostring public String tostring(){ return getclass().getname() + "@" + Integer.toHexString(hashCode()); Výsledkem volání x.tostring( ) je řetěz znakové reprezentace objektu x. Metodou je zavedena implicitní typová konverze z typu objektu x na řetězec, použitá např. při výpisu objektu. a equals public boolean equals(object obj) { return (this == obj); Vrací true pouze pokud se jedná o stejné objekty; neporovnává položky!!! Algoritmizace (Y36ALG), Šumperk - 7. přednáška 19
20 Standardní metoda tostring public class ObdelnikTest { public static void main(string[] args) { Obdelnik prvni = new Obdelnik(5,7); System.out.println("Prvni: " + prvni); Vypíše: Prvni: alg7.obdelnik@11b86e7 Algoritmizace (Y36ALG), Šumperk - 7. přednáška 20
21 Standardní metoda equals public class ObdelnikTest { public static void main(string[] args) { Obdelnik prvni = new Obdelnik(5,7); Obdelnik druhy = new Obdelnik(5,7); System.out.println("Stejne? " + (prvni==druhy)); System.out.println("Stejne? " + prvni.equals(druhy)); Vypíše Stejne? false Stejne? false prvni druhy Algoritmizace (Y36ALG), Šumperk - 7. přednáška 21
22 Zastínění metod předka Zastínění (předefinování) metod tostring a equals. public String tostring(){ return ("Obdelnik: " + sirka + " x " + vyska); public boolean equals(object o){ // porovnam jen s obdelniky if(!(o instanceof Obdelnik))return false; Obdelnik obd = (Obdelnik) o; // Proč přetypování? return (sirka == obd.sirka)&&(obd.vyska==vyska); Pomocí operátoru instanceof se zjišťuje, zda je referenční proměnná typu nějaké třídy. Algoritmizace (Y36ALG), Šumperk - 7. přednáška 22
23 Více referencí na jeden objekt, smetí public class ObdelnikTest { public static void main(string[] args) { Obdelnik prvni = new Obdelnik(5,7); Obdelnik druhy = new Obdelnik(5,2); druhy = prvni; System.out.println("Stejne? " + (prvni==druhy)); System.out.println("Stejne? " + prvni.equals(druhy)); Vypíše true true prvni 5x7 Algoritmizace (Y36ALG), Šumperk - 7. přednáška 23
24 Více referencí na jeden objekt, smetí public class ObdelnikTest { public static void main(string[] args) { Obdelnik prvni = new Obdelnik(5,7); Obdelnik druhy = new Obdelnik(5,2); druhy = prvni; System.out.println("Stejne? " + (prvni==druhy)); System.out.println("Stejne? " + prvni.equals(druhy)); Vypíše true true prvni 5x7 druhy 5x2 Algoritmizace (Y36ALG), Šumperk - 7. přednáška 24
25 Více referencí na jeden objekt, smetí public class ObdelnikTest { public static void main(string[] args) { Obdelnik prvni = new Obdelnik(5,7); Obdelnik druhy = new Obdelnik(5,2); druhy = prvni; System.out.println("Stejne? " + (prvni==druhy)); System.out.println("Stejne? " + prvni.equals(druhy)); Vypíše true true prvni druhy 5x7 5x2 Smetí - obd. 5x2 se stal nepřístupným. Paměť přidělená nepřístupným objektům se uvolňuje automaticky (sbírání smetí, garbage collection) Algoritmizace (Y36ALG), Šumperk - 7. přednáška 25
Třída jako datový typ. A0B36PR1-Programování 1 Fakulta elektrotechnická České vysoké učení technické
Třída jako datový typ A0B36PR1-Programování 1 Fakulta elektrotechnická České vysoké učení technické Třídy a objekty Věci okolo nás lze hierarchizovat do tříd (konceptů). Každá třída je reprezentována svými
Třída jako datový typ. BD6B36PJV 01 Fakulta elektrotechnická České vysoké učení technické
Třída jako datový typ BD6B36PJV 01 Fakulta elektrotechnická České vysoké učení technické Objektový přístup programování Modelování problému jako systému spolupracujících tříd Třída modeluje jeden koncept
PŘETĚŽOVÁNÍ OPERÁTORŮ
PŘETĚŽOVÁNÍ OPERÁTORŮ Jazyk C# podobně jako jazyk C++ umožňuje přetěžovat operátory, tj. rozšířit definice některých standardních operátorů na uživatelem definované typy (třídy a struktury). Stejně jako
Paměť počítače. alg2 1
Paměť počítače Výpočetní proces je posloupnost akcí nad daty uloženými v paměti počítače Data jsou v paměti reprezentována posloupnostmi bitů (bit = 0 nebo 1) Připomeňme: paměť je tvořena řadou 8-mi bitových
Úvod do programovacích jazyků (Java)
Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2007/2008 c 2006 2008 Michal Krátký Úvod do programovacích
typová konverze typová inference
Seminář Java Programování v Javě II Radek Kočí Fakulta informačních technologií VUT Únor 2008 Radek Kočí Seminář Java Programování v Javě (2) 1/ 36 Téma přednášky Rozhraní: použití, dědičnost Hierarchie
14.4.2010. Obsah přednášky 7. Základy programování (IZAPR) Přednáška 7. Parametry metod. Parametry, argumenty. Parametry metod.
Základy programování (IZAPR) Přednáška 7 Ing. Michael Bažant, Ph.D. Katedra softwarových technologií Kancelář č. 229, Náměstí Čs. legií Michael.Bazant@upce.cz Obsah přednášky 7 Parametry metod, předávání
8 Třídy, objekty, metody, předávání argumentů metod
8 Třídy, objekty, metody, předávání argumentů metod Studijní cíl Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost třídám a objektům, instančním
Třídy a dědičnost. A0B36PR1-Programování 1 Fakulta elektrotechnická České vysoké učení technické
Třídy a dědičnost A0B36PR1-Programování 1 Fakulta elektrotechnická České vysoké učení technické Dnešní témata Dědičnost Kompozice Typ String Třídy a dědičnost Dopravní prostředek Vzdušný Pozemní Vodní
Generické programování
Generické programování Od C# verze 2.0 = vytváření kódu s obecným datovým typem Příklad generická metoda, zamění dva parametry: static void Swap(ref T p1, ref T p2) T temp; temp = p1; p1 = p2; p2 =
Třída jako zdroj funkcí
Třída jako zdroj funkcí Třída v jazyku Java je programová jednotka tvořená množinou identifikátorů, které mají třídou definovaný význam Základem uživatelského programu v jazyku Java je třída, ve které
Úvod do programování - Java. Cvičení č.4
Úvod do programování - Java Cvičení č.4 1 Sekvence (posloupnost) Sekvence je tvořena posloupností jednoho nebo více příkazů, které se provádějí v pevně daném pořadí. Příkaz se začne provádět až po ukončení
7 Formátovaný výstup, třídy, objekty, pole, chyby v programech
7 Formátovaný výstup, třídy, objekty, pole, chyby v programech Studijní cíl Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost formátovanému výstupu,
Programování v jazyku Java základy OOP
Evropský sociální fond Praha & EU: Investujeme do vaší budoucnosti Programování v jazyku Java základy OOP BI-PJV Programování v jazyku Java Katedra teoretické informatiky Miroslav Balík Fakulta informačních
Vytváření a použití knihoven tříd
Vytváření a použití knihoven tříd doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz Prostory jmen motivace spolupráce
Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007
Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2006/2007 c 2006 Michal Krátký Úvod do programovacích jazyků
Principy objektově orientovaného programování
Principy objektově orientovaného programování Třídy a objekty doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz C E T
Výčtový typ strana 67
Výčtový typ strana 67 8. Výčtový typ V této kapitole si ukážeme, jak implementovat v Javě statické seznamy konstant (hodnot). Příkladem mohou být dny v týdnu, měsíce v roce, planety obíhající kolem slunce
24-2-2 PROMĚNNÉ, KONSTANTY A DATOVÉ TYPY TEORIE DATUM VYTVOŘENÍ: 23.7.2013 KLÍČOVÁ AKTIVITA: 02 PROGRAMOVÁNÍ 2. ROČNÍK (PRG2) HODINOVÁ DOTACE: 1
24-2-2 PROMĚNNÉ, KONSTANTY A DATOVÉ TYPY TEORIE AUTOR DOKUMENTU: MGR. MARTINA SUKOVÁ DATUM VYTVOŘENÍ: 23.7.2013 KLÍČOVÁ AKTIVITA: 02 UČIVO: STUDIJNÍ OBOR: PROGRAMOVÁNÍ 2. ROČNÍK (PRG2) INFORMAČNÍ TECHNOLOGIE
Počítačové laboratoře bez tajemství aneb naučme se učit algoritmizaci a programování s využitím robotů CZ.1.07/1.3.12/04.0006
Počítačové laboratoře bez tajemství aneb naučme se učit algoritmizaci a programování s využitím robotů CZ.1.07/1.3.12/04.0006 Lekce 1 Jazyk Java Tento projekt je spolufinancován Evropským sociálním fondem
Základy objektové orientace I. Únor 2010
Seminář Java Základy objektové orientace I Radek Kočí Fakulta informačních technologií VUT Únor 2010 Radek Kočí Seminář Java Základy OO (1) 1/ 20 Téma přednášky Charakteristika objektově orientovaných
Seminář Java II p.1/43
Seminář Java II Seminář Java II p.1/43 Rekapitulace Java je case sensitive Zdrojový kód (soubor.java) obsahuje jednu veřejnou třídu Třídy jsou organizovány do balíků Hierarchie balíků odpovídá hierarchii
Teoretické minimum z PJV
Teoretické minimum z PJV Pozn.: následující text popisuje vlastnosti jazyka Java zjednodušeně pouze pro potřeby výuky. Třída Zavádí se v programu deklarací třídy což je část programu od klíčových slov
Algoritmizace a programování
Algoritmizace a programování Řídicí struktury jazyka Java Struktura programu Příkazy jazyka Blok příkazů Logické příkazy Ternární logický operátor Verze pro akademický rok 2012/2013 1 Struktura programu
Definice třídy. úplná definice. public veřejná třída abstract nesmí být vytvářeny instance final nelze vytvářet potomky
JAVA Třídy Definice třídy úplná definice [public] [abstract] [final] class Jmeno [extends Predek] [impelements SeznamInterfacu] {... // telo tridy public veřejná třída abstract nesmí být vytvářeny instance
9. přednáška - třídy, objekty
třída String a její použití kolekce, typované kolekce 9. přednáška - třídy, objekty Algoritmizace (Y36ALG), Šumperk - 9. přednáška 1 Třída String Objekty knihovní třídy String jsou řetězy znaků Od ostatních
Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007
Úvod do programovacích jazyků (Java) Michal Krátký 1 Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2006/2007 c 2006 Michal Krátký Úvod do programovacích jazyků
Abstraktní třída a rozhraní
Abstraktní třída a rozhraní Někdy se může stát, zejména při psaní v hierarchické struktuře hodně nadřazených tříd, že tušíme, že bude ve zděděných třídách vhodné použít nějakou metodu. Tuto metodu ještě
11.5.2012. Obsah přednášky 9. Skrývání informací. Skrývání informací. Zapouzdření. Skrývání informací. Základy programování (IZAPR, IZKPR) Přednáška 9
Obsah přednášky 9 Základy programování (IZAPR, IZKPR) Přednáška 9 Základy dědičnosti, přístupová práva Ing. Michael Bažant, Ph.D. Katedra softwarových technologií Kancelář č. 03 022, Náměstí Čs. legií
Programování v C++ 2, 4. cvičení
Programování v C++ 2, 4. cvičení statické atributy a metody, konstruktory 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled Přístupová práva
IRAE 07/08 Přednáška č. 1
Úvod do předmětu OOP Objekt Proč OOP? Literatura, osnova předmětu viz. cvičení Základní prvek OOP sw inženýrství = model reálných objektů (věcí) člověk, auto, okno (ve windows), slovník, = model abstraktní
Úvod do programovacích jazyků (Java)
Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2007/2008 c 2006 2008 Michal Krátký Úvod do programovacích
Mnohotvarost (polymorfizmus)
Mnohotvarost (polymorfizmus) TYPY MNOHOTVAROSTI... 2 PŘETĚŽOVÁNÍ METOD, PŘETĚŽOVÁNÍ OPERACÍ... 3 PŘETÍŽENÍ OPERÁTORŮ... 4 ČASTO PŘETĚŽOVANÉ OPERÁTORY... 4 PŘEPISOVÁNÍ... 7 VIRTUÁLNÍ METODY... 10 SEZNAM
Jazyk C# (seminář 6)
Jazyk C# (seminář 6) Pavel Procházka KMI 29. října 2014 Delegát motivace Delegáty a události Jak docílit v C# funkcionální práce s metodami v C je to pomocí pointerů na funkce. Proč to v C# nejde pomocí
PREPROCESOR POKRAČOVÁNÍ
PREPROCESOR POKRAČOVÁNÍ Chybová hlášení V C# podobně jako v C++ existuje direktiva #error, která způsobí vypsání chybového hlášení překladačem a zastavení překladu. jazyk C# navíc nabízí direktivu #warning,
Pokročilé programování v jazyce C pro chemiky (C3220) Třídy v C++
Pokročilé programování v jazyce C pro chemiky (C3220) Třídy v C++ Třídy v C++ Třídy jsou uživatelsky definované typy podobné strukturám v C, kromě datových položek (proměnných) však mohou obsahovat i funkce
4. ZÁKLADNÍ POJMY Z OBJEKTOVĚ ORIENTOVANÉHO PROGRAMOVÁNÍ
4. ZÁKLADNÍ POJMY Z OBJEKTOVĚ ORIENTOVANÉHO PROGRAMOVÁNÍ OBJEKT Program v Javě je staticky strukturován na třídy, jejichž instance (objekty) za běhu dynamicky programu vznikají a zanikají. Objekt je nejprve
Java - řazení objektů
Java - řazení objektů Kapitola seznamuje se základními principy řazení objektů Klíčové pojmy: Přirozené řazení, absolutní řazení, ideální porovnávatelná třída ŘAZENÍ OBJEKTŮ U objektů není příliš jasné,
Algoritmizace a programování
Algoritmizace a programování Řídicí struktury, standardní metody Problematika načítání pomocí Scanner Některé poznámky k příkazům Psaní kódu programu Metody třídy Math Obalové třídy primitivních datových
Abstraktní datové typy: zásobník
Abstraktní datové typy: zásobník doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz Abstraktní datové typy omezené rozhraní
int t1, t2, t3, t4, t5, t6, t7, prumer; t1=sys.readint();... t7=sys.readint(); prume pru r = r = ( 1+t 1+t t3+ t3+ t4 t5+ t5+ +t7 +t7 )/ ;
Pole Příklad: přečíst teploty naměřené v jednotlivých dnech týdnu, vypočítat průměrnou teplotu a pro každý den vypsat odchylku od průměrné teploty Řešení s proměnnými typu int: int t1, t2, t3, t4, t5,
1. Programování proti rozhraní
1. Programování proti rozhraní Cíl látky Cílem tohoto bloku je seznámení se s jednou z nejdůležitější programátorskou technikou v objektově orientovaném programování. Tou technikou je využívaní rozhraní
KTE / ZPE Informační technologie
7 KTE / ZPE Informační technologie Ing. Petr Kropík, Ph.D. email: pkropik@kte.zcu.cz tel.: +420 377 63 4639, +420 377 63 4606 (odd. informatiky) Katedra teoretické elektrotechniky FEL ZČU Plzeň - ternární
Programování v Javě I. Leden 2008
Seminář Java Programování v Javě I Radek Kočí Fakulta informačních technologií VUT Leden 2008 Radek Kočí Seminář Java Programování v Javě (1) 1/ 45 Téma přednášky Datové typy Deklarace třídy Modifikátory
14.4.1. Typický prvek kolekce pro české řazení
14.4. Co všechno by měl mít typický prvek kolekce 177 Poznámka: Třídy BigInteger, BigDecimal a Date budou vysvětleny v částech [15./183, [16./185 a [18.1./204. 14.4.1. Typický prvek kolekce pro české řazení
Více o konstruktorech a destruktorech
Více o konstruktorech a destruktorech Více o konstruktorech a o přiřazení... inicializovat objekt lze i pomocí jiného objektu lze provést přiřazení mezi objekty v původním C nebylo možné provést přiřazení
OOPR_05. Případové studie
OOPR_05 Případové studie 1 Přehled probírané látky příklad skládání objektů - čára příklad skládání objektů kompozice a agregace přetížené konstruktory pole jako datový atribut 2 Grafický objekt - čára
Programování II. Návrh programu I 2018/19
Programování II Návrh programu I 2018/19 Osnova přednášky Co víme? Objektový návrh programu. Příklad. Co víme? Třída Třída je popisem objektů se společnými vlastnostmi. class private:
Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007
Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2006/2007 c 2006 Michal Krátký Úvod do programovacích jazyků
8. přednáška: Soubory a proudy
8. přednáška: Soubory a proudy Soubor jako posloupnost bytů Ukládání/čtení primitivních typů Ukládání/čtení primitivních typů a objektů (řetězců) Ukládání/čtení objektů do souboru - serializace Obsah Algoritmizace
Seminář Java IV p.1/38
Seminář Java IV Seminář Java IV p.1/38 Rekapitulace Deklarace tříd Proměnné, metody, konstruktory, modifikátory přístupu Datové typy primitivní, objektové, pole Dědičnost Řídící konstrukce Podmínky, cykly
Úvod Třídy Rozhraní Pole Konec. Programování v C# Hodnotové datové typy, řídící struktury. Petr Vaněček 1 / 39
Programování v C# Hodnotové datové typy, řídící struktury Petr Vaněček 1 / 39 Obsah přednášky Referenční datové typy datové položky metody přístupové metody accessory, indexery Rozhraní Pole 2 / 39 Třídy
Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007
Úvod do programovacích jazyků (Java) Michal Krátký Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2006/2007 c 2006 Michal Krátký Úvod do programovacích jazyků
Definice třídy. úplná definice. public veřejná třída abstract nesmí být vytvářeny instance final nelze vytvářet potomky
JAVA Třídy Definice třídy úplná definice [public] [abstract] [final] class Jmeno [extends Predek] [impelements SeznamInterfacu] {... // telo tridy public veřejná třída abstract nesmí být vytvářeny instance
Algoritmizace a programování
Algoritmizace a programování Struktura programu Vytvoření nové aplikace Struktura programu Základní syntaktické elementy První aplikace Verze pro akademický rok 2012/2013 1 Nová aplikace NetBeans Ve vývojovém
Programování v Javě I. Únor 2009
Seminář Java Programování v Javě I Radek Kočí Fakulta informačních technologií VUT Únor 2009 Radek Kočí Seminář Java Programování v Javě (1) 1/ 44 Téma přednášky Datové typy Deklarace třídy Modifikátory
3. přednáška. Obsah: Řídící struktury sekvence, if-else, switch, for, while, do-while. Zpracování posloupnosti
Obsah: Řídící struktury sekvence, if-else, switch, for, while, do-while. Zpracování posloupnosti 3. přednáška nalezení největšího prvku, druhého nejvyššího prvku, algoritmus shozeného praporku. Algoritmizace
Předmluva k aktuálnímu vydání Úvod k prvnímu vydání z roku Typografické a syntaktické konvence... 20
Obsah 5 Obsah Předmluva k aktuálnímu vydání 15 1 Úvod k prvnímu vydání z roku 2000 16 Typografické a syntaktické konvence................ 20 2 Základní pojmy 21 2.1 Trocha historie nikoho nezabije................
1. Téma 12 - Textové soubory a výjimky
1. Téma 12 - Textové soubory a výjimky Cíl látky Procvičit práci se soubory s využitím výjimek. 1.1. Úvod Program, aby byl programem, my mít nějaké výstupy a vstupy. Velmi častým případem je to, že se
Statické proměnné a metody. Tomáš Pitner, upravil Marek Šabo
Statické proměnné a metody Tomáš Pitner, upravil Marek Šabo Úvod Se statickou metodou jsme se setkali už u úplně prvního programu - Hello, world! public class Demo { public static void main(string[] args)
IAJCE Přednáška č. 7. řízení semaforu na křižovatce = přepínání červená/oranžová/zelená
Výčtový typ Motivační příklad řízení semaforu na křižovatce = přepínání červená/oranžová/zelená const int CERVENA = 0; const int ORANZOVA = 1; const int ZELENA = 2; int prististav = CERVENA; while (true)
1. Dědičnost a polymorfismus
1. Dědičnost a polymorfismus Cíl látky Cílem této kapitoly je představit klíčové pojmy dědičnosti a polymorfismu. Předtím však je nutné se seznámit se základními pojmy zobecnění neboli generalizace. Komentář
4.4.2012. Obsah přednášky. Příkaz for neúplný. Příkaz for příklady. Cyklus for each (enhanced for loop) Příkaz for příklady
Základy programování (IZAPR, IZKPR) Přednáška 5 Ing. Michael Bažant, Ph.D. Katedra softwarových technologií Kancelář č. 03 022, Náměstí Čs. legií Michael.Bazant@upce.cz Obsah přednášky Příkazy cyklu -
KTE / ZPE Informační technologie
4 KTE / ZPE Informační technologie Ing. Petr Kropík, Ph.D. email: pkropik@kte.zcu.cz tel.: +420 377 63 4639, +420 377 63 4606 (odd. informatiky) Katedra teoretické elektrotechniky FEL ZČU Plzeň Největší
Programování v jazyku Java hierarchie tříd, přetypování, výjimky
Evropský sociální fond Praha & EU: Investujeme do vaší budoucnosti Programování v jazyku Java hierarchie tříd, přetypování, výjimky BI-PJV Programování v jazyku Java Katedra teoretické informatiky Miroslav
Algoritmizace a programování
Algoritmizace a programování Výrazy Operátory Výrazy Verze pro akademický rok 2012/2013 1 Operace, operátory Unární jeden operand, operátor se zapisuje ve většině případů před operand, v některých případech
Správa paměti. Karel Richta a kol. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Karel Richta, 2016
Správa paměti Karel Richta a kol. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Karel Richta, 2016 Objektové modelování, B36OMO 10/2016, Lekce 2 https://cw.fel.cvut.cz/wiki/courses/xxb36omo/start
Soubor jako posloupnost bytů
Soubory Soubor je množina údajů uložená ve vnější paměti počítače, obvykle na disku Pro soubor jsou typické tyto operace. otevření souboru čtení údaje zápis údaje uzavření souboru Přístup k údajům (čtení
Třídy a dědičnost. BD6B36PJV Fakulta elektrotechnická České vysoké učení technické
Třídy a dědičnost BD6B36PJV Fakulta elektrotechnická České vysoké učení technické Třídy a dědičnost Dopravní prostředek Vzdušný Pozemní Vodní Plazivý Čtyřnohý Motorový AUTA BD6B36PJV-2 2 Dědičnost základní
Algoritmizace a programování. Terminálový vstup a výstup
Algoritmizace a programování Terminálový vstup a výstup Verze pro akademický rok 2012/2013 1 Výpis hodnot Terminálový vstup a výstup budeme používat jako základní způsob interakce programu s uživatelem
Příklad : String txt1 = new String( Ahoj vsichni! ); //vytvoří instanci třídy String a přiřadí ji vnitřní hodnotu Ahoj vsichni!
Java práce s řetězci Trochu povídání.. Řetězce jsou v Javě reprezentovány instancemi tříd StringBuffer a String. Tyto třídy jsou součástí balíčku java.lang, tudíž je možno s nimi pracovat ihned bez nutného
7. Dynamické datové struktury
7. Dynamické datové struktury Java poskytuje několik možností pro uložení většího množství dat (tj. objektů či primitivních datových typů) v paměti. S nejjednodušší z nich, s polem, jsme se již seznámili.
11 Diagram tříd, asociace, dědičnost, abstraktní třídy
11 Diagram tříd, asociace, dědičnost, abstraktní třídy Studijní cíl Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost diagramům tříd, asociaci,
Pole stručný úvod do začátku, podrobně později - zatím statická pole (ne dynamicky) - číslují se od 0
Pole stručný úvod do začátku, podrobně později - zatím statická pole (ne dynamicky) - číslují se od 0 int policko[100]; // tj. pole je od 0 do 99!!! policko[5] = 7; // pozor je to 6. prvek s indexem 5
Jazyk C# (seminář 5)
Jazyk C# (seminář 5) Pavel Procházka KMI 23. října 2014 Přetěžování metod motivace Představme si, že máme metodu, která uvnitř dělá prakticky to samé, ale liší se pouze parametry V C# můžeme více metod
C++ přetěžování funkcí a operátorů. Jan Hnilica Počítačové modelování 19
C++ přetěžování funkcí a operátorů 1 Přetěžování funkcí jazyk C++ umožňuje napsat více funkcí se stejným názvem, těmto funkcím říkáme přetížené přetížené funkce se musí odlišovat typem nebo počtem parametrů,
IRAE 07/08 Přednáška č. 2. atr1 atr2. atr1 atr2 -33
Objekt jako proměnná Objekty a metody Objekt = proměnná referenčního typu vznik pomocí new, chování viz pole jako referenční proměnná minulý semestr Stack Heap objekt ref this 10 20 atr1 atr2 jinyobjekt
Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007
Úvod do programovacích jazyků (Java) Michal Krátký 1 Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programovacích jazyků (Java), 2006/2007 c 2006 Michal Krátký Úvod do programovacích jazyků
přetížení operátorů (o)
přetížení operátorů (o) - pro vlastní typy je možné přetížit i operátory (tj. definovat vlastní) - pro definici slouží klíčové slovo operator následované typem/znakem operátoru - deklarace pomocí funkčního
Regulární výrazy. Vzory
Regulární výrazy Regulární výrazy jsou určeny pro práci s textovými řetězci, jsou součástí J2SDK až od verze 1.4, v předchozích verzích je potřeba použít některou z externích knihoven, např. knihovnu ORO
Třídy a objekty -příklady
Třídy a objekty -příklady doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz Příklad 1 Kvadratická rovnice static void
Martin Flusser. Faculty of Nuclear Sciences and Physical Engineering Czech Technical University in Prague. October 17, 2016
ZPRO cvičení 2 Martin Flusser Faculty of Nuclear Sciences and Physical Engineering Czech Technical University in Prague October 17, 2016 Outline I 1 Outline 2 Proměnné 3 Proměnné - cvičení 4 Funkce 5 Funkce
Datové struktury. Obsah přednášky: Definice pojmů. Abstraktní datové typy a jejich implementace. Algoritmizace (Y36ALG), Šumperk - 12.
Obsah přednášky: Definice pojmů o datový typ, o abstraktní datový typ Datové struktury Abstraktní datové typy a jejich implementace o Fronta (Queue) o Zásobník (Stack) o Množina (Set) Algoritmizace (Y36ALG),
Sada 1 - PHP. 03. Proměnné, konstanty
S třední škola stavební Jihlava Sada 1 - PHP 03. Proměnné, konstanty Digitální učební materiál projektu: SŠS Jihlava šablony registrační číslo projektu:cz.1.09/1.5.00/34.0284 Šablona: III/2 - inovace a
Seznamy a iterátory. Kolekce obecně. Rozhraní kolekce. Procházení kolekcí
Kolekce obecně Seznamy a iterátory doc. Ing. Miroslav Beneš, Ph.D. katedra informatiky FEI VŠB-TUO A-1007 / 597 324 213 http://www.cs.vsb.cz/benes Miroslav.Benes@vsb.cz Kolekce ::= homogenní sada prvků
20. Projekt Domácí mediotéka
Projekt Domácí mediotéka strana 211 20. Projekt Domácí mediotéka 20.1. Základní popis, zadání úkolu V projektu Domácí mediotéka (Dome) se jednoduchým způsobem evidují CD a videa. Projekt je velmi jednoduchý
Algoritmizace a programování
Algoritmizace a programování Typy Základní (primitivní) datové typy Deklarace Verze pro akademický rok 2012/2013 1 Typy v jazyce Java Základní datové typy (primitivní datové typy) Celočíselné byte, short,
Maturitní otázky z předmětu PROGRAMOVÁNÍ
Wichterlovo gymnázium, Ostrava-Poruba, příspěvková organizace Maturitní otázky z předmětu PROGRAMOVÁNÍ 1. Algoritmus a jeho vlastnosti algoritmus a jeho vlastnosti, formy zápisu algoritmu ověřování správnosti
Objekty v PHP 5.x. This is an object-oriented system. If we change anything, the users object.
Objekty v PHP 5.x This is an object-oriented system. If we change anything, the users object. Objektové PHP Objekty se poprvé objevili v PHP ve verzi 4. Nepříliš zdařilý pokus. Programátoři získali nedůvěru
Ukazatel (Pointer) jako datový typ - proměnné jsou umístěny v paměti na určitém místě (adrese) a zabírají určitý prostor (počet bytů), který je daný
Ukazatel (Pointer) jako datový typ - proměnné jsou umístěny v paměti na určitém místě (adrese) a zabírají určitý prostor (počet bytů), který je daný typem proměnné - ukazatel je tedy adresa společně s
Objektově orientované programování
10. října 2011 Pragmatické informace Volitelný předmět, zápočet: zápočtový program(s dokumentací), aktivní účast na cvičení(body v CodExu), praktický test, zkouška: zkoušková písemka na objektový návrh
Class loader. každá třída (java.lang.class) obsahuje referenci na svůj class loader. Implementace class loaderu
Seminář Java Zavádění tříd Radek Kočí Fakulta informačních technologií VUT Duben 2008 Radek Kočí Seminář Java Zavádění tříd 1/ 16 JVM zavádí třídy dynamicky Class loader objekt schopný zavádět třídy abstraktní
Obsah přednášky. Postup při vytváření objektů. Postup při vytváření objektů. Alokace paměti. Inicializace hodnot atributů
Základy programování (IZAPR, IZKPR) Přednáška 7 Ing. Michael Bažant, Ph.D. Katedra softwarových technologií Kancelář č. 03 022, Náměstí Čs. legií Michael.Bazant@upce.cz Obsah přednášky Postup při vytváření
Konstruktory a destruktory
Konstruktory a destruktory Nedostatek atributy po vytvoření objektu nejsou automaticky inicializovány hodnota atributů je náhodná vytvoření metody pro inicializaci, kterou musí programátor explicitně zavolat,
DUM 06 téma: Tvorba makra pomocí VBA
DUM 06 téma: Tvorba makra pomocí VBA ze sady: 03 tematický okruh sady: Tvorba skript a maker ze šablony: 10 Algoritmizace a programování určeno pro: 4. ročník vzdělávací obor: 18-20-M/01 Informační technologie
Programování v C++ 1, 5. cvičení
Programování v C++ 1, 5. cvičení konstruktory, nevirtuální dědění 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled 1 2 3 Shrnutí minule procvičené
Základní pojmy. Úvod do programování. Základní pojmy. Zápis algoritmu. Výraz. Základní pojmy
Úvod do programování Michal Krátký 1,Jiří Dvorský 1 1 Katedra informatiky VŠB Technická univerzita Ostrava Úvod do programování, 2004/2005 Procesor Procesorem je objekt, který vykonává algoritmem popisovanou
Jazyk C++ I. Šablony 2
Jazyk C++ I Šablony 2 AR 2013/2014 Jazyk C++ I Třídy template class TVektor { T *a; int n; static int PocInstanci; public: TVektor(int _n = 0) : n(_n) { a = new T[n]; PocInstanci++; } ~TVektor()
Programování v C++ 3, 3. cvičení
Programování v C++ 3, 3. cvičení úvod do objektově orientovaného programování 1 1 Fakulta jaderná a fyzikálně inženýrská České vysoké učení technické v Praze Zimní semestr 2018/2019 Přehled Dokončení spojového