Programování v jazyku Java soubory a proudy

Rozměr: px
Začít zobrazení ze stránky:

Download "Programování v jazyku Java soubory a proudy"

Transkript

1 Evropský sociální fond Praha & EU: Investujeme do vaší budoucnosti Programování v jazyku Java soubory a proudy BI-PJV Programování v jazyku Java Katedra teoretické informatiky Miroslav Balík Fakulta informačních technologií České vysoké učení technické

2 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í nebo zápis) může být: sekvenční nebo libovolný (adresovatelný) Soubory se sekvenčním přístupem umožňují pouze postupné (sekvenční) čtení nebo zápis údajů Soubory s libovolným přístupem umožňují adresovatelné čtení nebo zápis údaje (podobně jako pole) Způsob přístupu k údajům v souboru není zakódován v souboru, ale je dán programem Zde se budeme zabývat sekvenčními soubory, pro zájemce i adresovatelnými 2/44

3 Soubory a proudy Java rozlišuje soubory (file) a proudy (stream) soubor je množina údajů uložená ve vnější paměti počítače proudy jsou nástroje k přenosu informací např. z/do souboru, ale také do/ze sítě, paměti, jiného programu, atd. informace může mít tvar znaků, bajtů, skupin bajtů (obrázky ), objektů,.. přenos informace se děje dvoj/třívrstevně v proudech (streams): 1. otevření přenosového proudu pro bajty či znaky 2. otevření přenosového proudu pro datové typy Javy 3. filtrace dat podle požadavků bufferování, řádkování, 3/44

4 Textové proudy Reader a writer musí zajistit konverzi znaků Operační systém Java MS Windows, kódování UCS2 WIN 1250 kód 158 znak ž kód 382 reader UNIX, Linux, ISO kód 190 writer 4/44

5 Balíček java.io je rozsáhlý, obecně koncipovaný, slouží ke vstupu, výstupu a přenosu dat. Jeho hlavní součástí jsou třídy realizující tzv. proudy bytů resp. znaků ( byte resp. character streams ). Tyto třídy jsou potomky čtyř abstraktních tříd: InputStream, OutputStream resp. Reader, Writer. Proudy se otvírají automaticky neexistují metody open, avšak se automaticky neuzavírají nutno volat metodu close( ). V návaznosti s dalšími balíčky java.io podporuje: java.net, javax.net, javax.net.ssl - přenos po síti java.util.zip - standardní komprese dat java.util.jar případně s manifestem java.nio, java.nio.channels - inovované I/O umožňuje pracovat na úrovni kanálů. 5/44

6 Proudění dat INPUT SOURCE OUTPUT SINK READ ZDROJ NORA PROCESS WRITE bytes chars soubor paměť roura síť konzole buffer buffer byte číslo znak řádka objekt chars bytes soubor paměť roura síť konzole 6/44

7 java.io java.lang Comparable<T> ObjectStream Field ObjectStream Class File tag interface Serializable byte Console Input Stream Output Stream Flushable Externalizable char FileFilter FilenameFilter File Descriptor java.lang Reader input streams Stream Tokenizer Writer Appendable output Closeable Random AccessFile DataInput DataOutput 7/44

8 Input Stream InputStream Closeable javax.sound.sampled File InputStream Buffered InputStream Filter InputStream ByteArray InputStream Audio InputStream javax.swing java.util.zip Data InputStream Inflater InputStream ProgressMonitor InputStream java.util.zip Piped InputStream DataInput Object InputStream ObjectInput StringBuffer InputStream ObjectStream Constants Sequence InputStream GZIP InputStream Checked InputStream java.security Zip InputStream Digest InputStream java.crypto Jar InputStream Cipher InputStream 8/44

9

10 Čtení a zápis byte streamu int b = read( ) int b F F F F F F 00-FF F F 0 <= b <= 255 b == -1 EOF write( int b ); close( ); byte[ ] b int lng = read( byte[ ] b, ) 0 <= lng < b.length lng == -1 EOF b.length 0 write( byte[ ] b, ) ; close( ); 10/44

11 Reader java.nio java.lang Char Buffer Readable Closeable Reader InputStream Reader File Reader Buffered Reader LineNumber Reader Filter Reader Pushback Reader Piped Reader CharArray Reader String Reader 11/44

12 Čtení a zápis character streamu int c = read( ) int c FFFF F F F F F F F F 0 <= c <= c == -1 EOF write( c ); close( ); char[ ] c int lng = read( char[ ] c, ) 0 <= lng < c.length lng == -1 EOF c.length 0 write( c, ) ; close( ); String s write( s, ) ; close( ); 12/44

13

14 OutputStream Closeable Flushable java.lang Output Stream Appendable org.omg.corba.portable File OutputStream Buffered OutputStream Filter OutputStream ByteArray OutputStream PrintStream Output Stream java.util.zip Data OutputStream Piped OutputStream DataOutput Object OutputStream ObjectOutput ObjectStream Constants Deflater OutputStream GZIP OutputStream Checked OutputStream java.security Zip OutputStream Digest OutputStream java.crypto Jar OutputStream java.util.zip Cipher OutputStream 14/44

15

16 Writer java.lang Closeable Writer Flushable Appendable OutputStream Writer File Writer Buffered Writer Filter Writer Piped Writer CharArray Writer String Writer Print Writer 16/44

17

18 Překlad bytů na znaky InputStreamReader a OutputStreamWriter slouží jako můstky mezi bytovými a znakovými proudy a dále pro volitelný překlad. Konstruktory: InputStreamReader( InputStream in) InputStreamReader( InputStream in, String enc ) s překladem OutputStreamWriter( OutputStream out ) OutputStreamWriter( OutputStream out, String enc ) s překladem Parametr enc udává kódování např. UTF8 Pro zvýšení efektivity radno používat buffery. Např.: Reader in = new BufferedReader( new InputStreamReader( System.in) ); Writer out = new BufferedWriter( new OutputStreamWriter( System.out) ); 18/44

19 Interfejsy DataInput a DataOutput definují (abstraktní) metody pro čtení / zápis všech primitivů z / do proudu: boolean readboolean( ), byte readbyte( ), char readchar( ), double readdouble( ),... atd. a ještě: - void readfully( byte[ ] b ) - int readunsignedbyte( ) - int readunsignedshort( ) - String readutf( ) void writeboolean( boolean v ), void writebyte( byte v ), void writechar( char v ), void writedouble( double v )... atd. a ještě: - void write( byte[ ] b ) - void writeutf( String s ) Třídy DataInputStream, DataOutputStream a RandomAccessFile tyto interfejsy implementují, čímž umějí pracovat se všemi primitivy. 19/44

20 Kopírování souboru po bytech Přetížené konstruktory FileInputStream a FileOutputStream určují soubor pomocí File nebo FileDescriptor anebo přímo jménem. FileOutputStream navíc umožňuje připsat data ke konci existujícího souboru, což se určí parametrem append v konstruktoru. Příklad: try { File ifile = new File("C:\\in"); File ofile = new File("C:\\out"); FileInputStream fis = new FileInputStream( ifile ); FileOutputStream fos = new FileOutputStream( ofile ); int c; while ( ( c = fis.read( ) )!= -1 ) { fos.write(c); } fis.close( ); fos.close( ); } catch ( IOException ex ) { System.err.println( ex ); } 20/44

21 Kopírování textového souboru po řádcích Přetížené konstruktory BufferedReader a BufferedWriter umožňují nastavit velikost bufru. Metoda readline( ) nevrací znaky přechodu na novou řádku. Writer umožňuje připisovat ke konci existujícího souboru metodou append. BufferedReader br = null; BufferedWriter bw = null; try { br = new BufferedReader( new InputStreamReader( new FileInputStream( "C:\\in.txt" ))); bw = new BufferedWriter( new OutputStreamWriter( new FileOutputStream( "C:\\out.txt" ))); String s = null; while ( (s = br.readline( ) )!= null ) { bw.write( s ); bw.newline( ); } } catch ( IOException ex ) { System.err.println( ex ); } finally { if ( br!= null ) br.close( ); if ( bw!= null ) bw.close( ); } 21/44

22 Filtrování textového souboru po řádcích class TextFilter extends LineNumberReader { String s, stop ; public TextFilter( BufferedReader in, String stop ) { super( in ); this.stop=stop; } public String readline( ) { try { while ( (s=super.readline( ) )!= null ) { if ( s.length( ) == 0 ) continue; // odstraní prázdné řádky if ( s.startswith( stop ) ) return null; // podmínka ukončení return s; } } catch ( Exception ex ) { } return null; } } 22/44

23 Překlad souboru Přetížené konstruktory FileReader a FileWriter určují soubor pomocí File nebo FileDescriptor anebo přímo jménem. Kopírování souboru po znacích s překladem defaultního kódu do UTF8: public static void main( String[ ] args ) throws Exception { FileReader fr = new FileReader( "Test.txt" ); OutputStreamWriter osw = new OutputStreamWriter( new FileOutputStream( "Test.UTF8" ), "UTF8" ); int c; while ( (c = fr.read( ) )!= -1 ) osw.write( c ); fr.close( ); osw.close( ); } 23/44

24 Seznam slov v souboru Vstup: První slovo druhé a třetí. Máma mele maso. Mleté maso. Máma a táta se učí programovat. Výstup: Mleté Máma První a druhé maso. mele programovat. se slovo táta třetí. učí 24/44

25 Seznam slov v souboru - Java 5 public class VypisRuznychSlovNewJava { private static Scanner scan; public static void main(string[ ] args) { SortedSet<String> slova = nactivsechnaslova(); vypisjevporadipodleabecedy(slova); }.... } SortedSet<String> možno vkládat pouze řetězce kontroluje se to při překladu, je to typově bezpečné 25/44

26 Seznam slov v souboru - Java 5 private static SortedSet<String> nactivsechnaslova() { SortedSet<String> slova = new TreeSet<String>(); try { scan = new Scanner(new FileInputStream("vstup.txt")); while(scan.hasnext()){ slova.add(scan.next()); //přidá další slovo, pokud se neopakuje, vkládat lze pouze //řetězce typ String } } catch (IOException ex) { System.out.println("Soubor vstup.txt nebyl nalezen."); } return slova; } 26/44

27 Seznam slov v souboru - Java 5 private static void vypisjevporadipodleabecedy(sortedset<string> slova) { for (Iterator<String> it = slova.iterator(); it.hasnext();) { String slovo = it.next(); System.out.println(slovo); } } Z kolekce vybíráme slova typ String, není nutné přetypovávat 27/44

28 Seznam slov v souboru - Java 5 private static void vypisjevporadipodleabecedy (SortedSet<String> slova) { for (String slovo : slova) { System.out.println(slovo); } } Nový cyklus foreach Tento cyklus se čte: Pro každé slovo z kolekce slova proveď jeho výpis 28/44

29 Třída File Objekt typu File představuje soubor resp. adresář nikoli vlastní data na lokálním disku. Umožňuje přístup, informace, manipulace a cestu absolutní či relativní k pracovnímu adresáři ( začíná-li lomítkem či nikoli ). Konstruktory jen určují jen jméno, cestu případně i formou URI. Některé důležitější metody: boolean createnewfile( ) - vytvoří nový skutečný soubor pokud neexistuje boolean mkdir( ) - vytvoří skutečný adresář String getabsolutepath( ) - zjistí absolutní cestu boolean isdirectory( ), boolean isfile( ) - zjistí typ, neexistuje-li pak false String[ ] list( ) - vytvoří seznam souborů a podadresářů v adresáři boolean exists( ) - zjistí existenci boolean canread( ), boolean canwrite( ) - zjistí možnosti práce void delete( ) - zruší soubor nebo adresář long length( ) - zjistí rozsah souboru boolean renameto ( File name ) - přejmenuje soubor resp. adresář long lastmodified( ) - zjistí čas poslední modifikace 29/44

30 Třída File Vytvoření adresáře a souboru, zápis dat a přejmenování : File dir1 = new File( "C:\\K\\L" ); dir1.mkdirs( ); File file1 = new File( dir, "X.txt" ); file1.createnewfile( ); PrintWriter pw = new PrintWriter( file1 ); pw.println( "blablabla" ); pw.close( ); File dir2 = new File( "C:\\K\\M" ); dir1.renameto( dir2 ); File file2 = new File( dir2, "X.txt" ); File file3 = new File( dir2, "Y.txt" ); file2.renameto( file3 ); 30/44

31 Rekurzivní výpis adresáře static final String spc= " "; public static void main( String[ ] args ) { dir( null, "C:\\MyDir", 0 ); } static void dir( File dir, String name, int level ) { File f = ( dir == null )? new File( name ) : new File( dir, name ); String inset = spc.substring( 0, level ); System.out.println( inset + name ); if ( f.isfile( ) ) return; String[ ] sl = f.list( ) ; for ( int i = 0; i < sl.length; i++ ) dir( f, sl[ i ], level+1 ); } 31/44

32 Proudění rourou Konstruktory ( nepřipojené se připojí později metodou connect( ) ): PipedInputStream( PipedOutputStream src ) PipedInputStream( ) ještě nepřipojený PipedOutputStream( PipedInputStream snk ) PipedOutputStream( ) ještě nepřipojený Příklad toku náhodných bytů rourou od producenta ke konzumentovi: class Producer extends Thread { OutputStream os; Producer( OutputStream os ) { this.os = os; } public void run( ) { for ( int i = 0; i < 10; i++ ) try { os.write( (int) ( Math.random( ) * 256) ); } catch ( IOException ex ) { } } } 32/44

33 Proudění rourou class Consumer extends Thread { InputStream is; Consumer( InputStream is ) { this.is = is; } public void run( ) { int i; try { while ( ( i = is.read( ) )!= -1 ) System.out.println( i ); } catch ( IOException ex ) { } } } class TestPipe { public static void main( String[ ] args ) throws Exception { PipedInputStream pi = new PipedInputStream( ); PipedOutputStream po = new PipedOutputStream( pi ); new Producer( po ).start( ); new Consumer( pi ).start( ); } } 33/44

34 Serializace do výstupu Objekty typu Serializable lze přenést objektovým proudem tzv. serializací, jež rozloží hodnoty jeho (nestatických) atributů na byty, přičemž modifikátory přístupu nemají vliv. Všechna pole jsou serializovatelná. Neserializují se atributy označené static či transient ani třídy ani metody. Rekurzivní probírkou referencí se serializují i všechny referované objekty tedy i velmi rozsáhlý graf. Všechny jeho objekty musí být Serializable. FileOutputStream out = new FileOutputStream( "thetime" ); ObjectOutputStream oos = new ObjectOutputStream( out ); oos.writeobject( "Today" ); oos.writeobject( new Date( ) ); oos.close( ); // event. oos.flush Každý další stav téhož objektu lze zapsat jen zavoláním oos.reset( ) před vlastním zápisem. Serializaci lze využít i pro hluboké klonování skrze ByteArray Streamů. 34/44

35 Deserializace vstupu je obnovení objektu ( tj. i celého grafu ) jsou-li k dispozici odpovídající třídy- kompatibilní dle serialversionuid. Deserializace nevolá konstruktory Serializable tříd, neboť by nastavily iniciální hodnoty. Volá však konstruktory nadtříd které nejsou Serializable. Nepřenesené atributy nastaví na jejich defaultní hodnoty dle jejich typu. FileInputStream in = new FileInputStream( "thetime" ); ObjectInputStream ois = new ObjectInputStream( in ); String today = ( String ) ois.readobject( ); Date date = ( Date ) ois.readobject( ); Jelikož metoda ois.readobject( ) vrací typ Object, je vhodné přetypovat. Zjistit typ lze metodou getclass( ) anebo operátorem instanceof(doporučeno). Objektové proudy implementují DataInput resp. DataOutput a tudíž lze proudem přenášet i primitivní hodnoty, řetězy a UTF. 35/44

36 serialversionuid Serializovatelné třídy mají identifikaci verze pomocí přiřazené konstanty serialversionuid stanovené výpočtem či přiřazením. Hodnotu serialversionuid lze zjistit programem jdk1.6\bin\serialver.exe classpath... class,... což je hešová hodnota odvozená z některých charakteristik třídy. Při serializaci se přikládá do objektového proudu viz třída java.io.objectstreamconstants. Při deserializaci se porovná s hodnotou třídy na vstupní straně. Při neshodě se vyhodí výjimka. Programátor může explicitně stanovit, že třídy jsou kompatibilní tím, že třídě vnutí určitou hodnotu atributu např: private static final long serialversionuid= l; 36/44

37 (De)serializace a dědičnost Pokud serializujeme instanci potomka (musí být Serializable) tak 1. buď i rodič implementuje Serializable a pak je serializován v rámci potomka, 2. nebo Předek musí mít bezparametrický konstuktor(implicitní či explicitní). Tento je volán během deserializace. 37/44

38 (De)serializace a dědičnost - příklad public class Rodic { public int a = 3; public Rodic(){ a = 5; } } public class Potomek extends Rodic implements Serializable{ public int p = 3; public Potomek(int pp){ p = pp; } public String tostring() { return "Potomek p " + p + " rodic a " + super.a; }} Potomek p = new Potomek(12); main p.a = 11; System.out.println("Pred serializaci " + p);...serializace p = null; // určitě tam nic nechci nechat... deserializace if(p!=null)system.out.println("po deserializaci " + p); Pred serializaci Potomek p 12 rodic a 11 Po deserializaci Potomek p 12 rodic a 5 38/44

39 Naše vlastní ovládání serializace a deserializace (De)serializace funguje automaticky, ale výběr a pořadí lze ovládat připsáním dvou metod do serializovatelné třídy class A implements Serializable { static int i = 3; // neserializuje se transient int j = 5; // neserializuje se double d = 1.41; private void writeobject( ObjectOutputStream oos ) throws IOException { oos.writeint( i ); // serializuje se oos.defaultwriteobject( ); // serializuje normálně tj. jen d } private void readobject( ObjectInputStream ois ) throws IOException, ClassNotFoundException { i = ois.readint( ); // deserializuje se ois.defaultreadobject( ); // deserializuje normálně tj. jen d j = -1; // bez přenosu jen nastavení }} 39/44

40 java.io.externalizable Pro realizaci vlastních představ lze implementovat třídu tímto interfejsem, definovat explicitní public konstruktor bez parametrů a dvě metody, které jsou plně zodpovědné za ser-deser objektu i dat nadtříd. public void writeexternal( ObjectOutput stream ) throws IOException { stream.writeint( i ); stream.writeobject( "Well done." ); } public void readexternal( ObjectInput stream ) throws IOException, ClassNotFoundException { i = stream.readint( ); String msg = ( String ) ( stream.readobject( ) ); System.out.println( msg ); } Externalizovaný vstup používá konstruktor, serializovaný nikoli. Externalizace je rychlejší než serializace, neboť JVM neanalyzuje strukturu. 40/44

41 Komprese Lze vytvořit standardní soubor.zip,.gzip nebo.jar, který je čitelný standardními programy - např. WinZip. Kompresi provádí Deflater. OutputStream os = new FileOutputStream( "C:\\data.zip" ); ZipOutputStream zos = new ZipOutputStream( os ); ZipEntry ze1 = new ZipEntry( "dir1 \\ dir2 \\ YY" ); zos.putnextentry( ze1 ); for ( int i = 0; i < 10000; i++ ) { zos.write( i ); } ZipEntry z2 = new ZipEntry( "dir1 \\ ZZ" ); zos.putnextentry( ze2 ); for ( int i = 0; i < 10000; i++ ) { zos.write( i ); }... zos.close(); 41/44

42 Dekomprese Takto lze dekomprimovat standardní.zip,.gzip a.jar. Dekompresi provádí Inflater. InputStream is = new FileInputStream( "C:\\data.zip" ); ZipInputStream zis = new ZipInputStream( is ); ZipEntry ze; int i; while ( ( ze = zis.getnextentry( ) )!= null ) { while ( ( i = zis.read( ) )!= -1 ) { System.out.print( i + " " ); } } zis.close( ); 42/44

43 ZipFile a ZipEntry Uložení entry a dat je patrně různé při kompresi ZipOutputStreamem a některými oblíbenými programy např. WinZip 7.0. Pro čtení a dekompresi je pak třeba použít ZipFile. ZipFile zf = new ZipFile ( "C:\\windata.zip" ); Enumeration en = zf.entries( ); while ( en.hasmoreelements( ) ) { System.out.print( en.nextelement( ) ; } ZipEntry ze = zf.getentry( "dir1 / ZZ" ); InputStream is = zf.get InputStream( ze ) ; int i; while ( ( i = zis.read( ) )!= -1 ) { System.out.print( i + " " ) ; } zis.close( ) ; zf.close( ) ; 43/44

44 Třída RandomAccessFile Umožňuje libovolný přístup, čtení, zápis i připisování jakoby bytového pole realizovaného na periferním zařízení. Konstruktory mají mody: r, rw pro čtení i zápis, rws, rwd pro synchonizovanou aktualizaci bratra. Instanční metody: void close( ) uzavře soubor long getfilepointer ( ) - vrátí pointer void seek ( long pos ) - nastaví pointer read ( ), readxxx( ), readline různé způsoby čtení write ( ), writexxx( ) - různé způsoby psaní long length ( ) - zjistí rozsah souboru void setlength ( long newlength ) - změní rozsah souboru int skipbytes ( int n ) - přeskočí FileChannel getchannel ( ) vrátí kanál bratra FileDecriptor getfd ( ) umožňuje připojení a synchronizaci bratra 44/44

Balíček java.io. je rozsáhlý, obecně koncipovaný, slouží ke vstupu, výstupu a přenosu dat.

Balíček java.io. je rozsáhlý, obecně koncipovaný, slouží ke vstupu, výstupu a přenosu dat. Balíček java.io je rozsáhlý, obecně koncipovaný, slouží ke vstupu, výstupu a přenosu dat. Jeho hlavní součástí jsou třídy realizující tzv. proudy bytů resp. znaků ( byte resp. character streams ). Tyto

Více

8. přednáška: Soubory a proudy

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

Více

6. PRÁCE S DATOVÝMI PROUDY

6. PRÁCE S DATOVÝMI PROUDY 6. PRÁCE S DATOVÝMI PROUDY Balík java.io obsahuje třídy, které slouží pro zpracování datových výstupů a vstupů. Pro obvyklou práci se soubory zde můžeme najít třídy File a RandomAccessFile. Většina tříd

Více

Práce se soubory v Javě

Práce se soubory v Javě Práce se soubory v Javě Cílem kapitoly je naučit pracovat se soubory a adresáři v Javě. Na jednoduchých příkladech ukázat procházení adresáře, čtení z textového souboru a zápis do textového souboru. Klíčové

Více

InputStream. FilterInputStream

InputStream. FilterInputStream 6. Vstupy a výstupy Pro práci se vstupy a výstupy nám Java poskytuje celou řadu tříd a jejich metod. Jsou uloženy v balíku java.io. Tato knihovna je založena na mechanizmu tzv. vstupních a výstupních proudů

Více

Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007

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ů

Více

Soubor jako posloupnost bytů

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í

Více

Úvod do programovacích jazyků (Java)

Ú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

Více

Proudy, Zpracovсnэ XML. Radek Koэ

Proudy, Zpracovсnэ XML. Radek Koэ Seminс Java Proudy, Zpracovсnэ XML Radek Koэ Fakulta informanэch technologiэ VUT Bezen 2008 Radek Koэ Seminс Java Proudy, Zpracovсnэ XML 1/ 38 Obsah Vstup/Vstup koncepce proud soubory, adresсe binсrnэ

Více

Design time - vytváří se program - metadata - vytváří se např. třída. Run time - běh programu - ukládá se do paměti počítače - vytváří se např.

Design time - vytváří se program - metadata - vytváří se např. třída. Run time - běh programu - ukládá se do paměti počítače - vytváří se např. Design time - vytváří se program - metadata - vytváří se např. třída Run time - běh programu - ukládá se do paměti počítače - vytváří se např. objekt rysy javy - zavedení jasného pořádku a etikety - přísné

Více

Seminář Java VI p.1/33

Seminář Java VI p.1/33 Seminář Java VI Seminář Java VI p.1/33 Rekapitulace Úvod do kontejnerů - kategorie Iterátory Rozhraní List Rozhraní Set Rozhraní Map Volba implementace Nástroje Souběžný přístup Seminář Java VI p.2/33

Více

Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007

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ů

Více

Úvod do programovacích jazyků (Java)

Ú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

Více

Teoretické minimum z PJV

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

Více

NIO. Aplikační programování v Javě (BI-APJ) - 12 Ing. Jiří Daněček Katedra softwarového inženýrství Fakulta informačních technologií ČVUT Praha

NIO. Aplikační programování v Javě (BI-APJ) - 12 Ing. Jiří Daněček Katedra softwarového inženýrství Fakulta informačních technologií ČVUT Praha NIO Aplikační programování v Javě (BI-APJ) - 12 Ing. Jiří Daněček Katedra softwarového inženýrství Fakulta informačních technologií ČVUT Praha Evropský sociální fond Praha & EU: Investujeme do vaší budoucnosti

Více

Textové soubory. alg9 1

Textové soubory. alg9 1 Textové soubory Textový soubor je posloupnost znaků členěná na řádky každý znak je reprezentován jedním bytem, jehož obsah je dán nějakým kódováním znaků členění na řádky je závislé na platformě a obvykle

Více

1. Téma 12 - Textové soubory a výjimky

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

Více

Enterprise Java (BI-EJA) Technologie programování v jazyku Java (X36TJV)

Enterprise Java (BI-EJA) Technologie programování v jazyku Java (X36TJV) Příprava studijního programu Informatika je podporována projektem financovaným z Evropského sociálního fondu a rozpočtu hlavního města Prahy. Praha & EU: Investujeme do vaší budoucnosti Enterprise Java

Více

Programování v Javě I. Leden 2008

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

Více

UNIVERZITA PARDUBICE. Fakulta elektrotechniky a informatiky. Aplikace tříd souvisejících s přenosem dat mezi operační pamětí a diskem Marek Jelínek

UNIVERZITA PARDUBICE. Fakulta elektrotechniky a informatiky. Aplikace tříd souvisejících s přenosem dat mezi operační pamětí a diskem Marek Jelínek UNIVERZITA PARDUBICE Fakulta elektrotechniky a informatiky Aplikace tříd souvisejících s přenosem dat mezi operační pamětí a diskem Marek Jelínek Bakalářská práce 2013 Prohlášení autora Prohlašuji, že

Více

SOUBORY, VSTUPY A VÝSTUPY POKRAČOVÁNÍ

SOUBORY, VSTUPY A VÝSTUPY POKRAČOVÁNÍ SOUBORY, VSTUPY A VÝSTUPY POKRAČOVÁNÍ Vstupy a výstupy pokračování Kódování textů Texty (řetězce nebo znaky) v jazyce C# jsou v paměti uloženy v kódování označovaném běžně Unicode (kódová stránka 1200).

Více

Programování v Javě I. Únor 2009

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

Více

Definice třídy. úplná definice. public veřejná třída abstract nesmí být vytvářeny instance final nelze vytvářet potomky

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

Více

Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007

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ů

Více

Ošetřování chyb v programech

Ošetřování chyb v programech Ošetřování chyb v programech Úvod chyba v programu = normální záležitost typy chyb: 1) programátorská chyba při návrhu každých 10 000 řádek 1 chyba lze jen omezeně ošetřit (před pádem aplikace nabídnout

Více

Algoritmizace a programování

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

Více

Soubory. Jan Faigl. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze. Přednáška 12 A0B36PR1 Programování 1

Soubory. Jan Faigl. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze. Přednáška 12 A0B36PR1 Programování 1 Soubory Jan Faigl Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Přednáška 12 A0B36PR1 Programování 1 Jan Faigl, 2016 A0B36PR1 Přednáška 12: Soubory 1 / 39 Část 1 Soubory

Více

Soubory. Jan Faigl. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze. Přednáška 12 A0B36PR1 Programování 1

Soubory. Jan Faigl. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze. Přednáška 12 A0B36PR1 Programování 1 Soubory Jan Faigl Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Přednáška 12 A0B36PR1 Programování 1 Jan Faigl, 2016 A0B36PR1 Přednáška 12: Soubory 1 / 39 Část 1 Soubory

Více

Vytváření a použití knihoven tříd

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

Více

Generické programování

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 =

Více

Předmluva k aktuálnímu vydání Úvod k prvnímu vydání z roku Typografické a syntaktické konvence... 20

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................

Více

7. přednáška - třídy, objekty třídy objekty atributy tříd metody tříd

7. přednáška - třídy, objekty třídy objekty atributy tříd metody tříd 7. přednáška - třídy, objekty třídy objekty atributy tříd metody tříd Algoritmizace (Y36ALG), Šumperk - 7. přednáška 1 Třída jako zdroj funkcionality Třída v jazyku Java je programová jednotka tvořená

Více

14.4.2010. Obsah přednášky 7. Základy programování (IZAPR) Přednáška 7. Parametry metod. Parametry, argumenty. Parametry metod.

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í

Více

Úvod Informace o prostředí Práce se soubory Regulární výrazy Konec. Programování v C# Soubory a regulární výrazy. Petr Vaněček 1 / 27

Úvod Informace o prostředí Práce se soubory Regulární výrazy Konec. Programování v C# Soubory a regulární výrazy. Petr Vaněček 1 / 27 Programování v C# Soubory a regulární výrazy Petr Vaněček 1 / 27 Obsah přednášky Informace o prostředí Práce se soubory Regulární výrazy 2 / 27 Zprostředkování informací Třída System.Environment Poskytuje

Více

Jazyk C# (seminář 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

Více

RMI Remote Method Invocation

RMI Remote Method Invocation 2. cvičení RMI Remote Method Invocation 2007/09 ver.2.0 1 RMI co to je? vyvolání metody z jiné JVM lokalizace vzdáleného objektu komunikace se vzdálenými objekty přenos objektu v bytecode typicky klient

Více

Class loader. každá třída (java.lang.class) obsahuje referenci na svůj class loader. Implementace class loaderu

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í

Více

Definice třídy. úplná definice. public veřejná třída abstract nesmí být vytvářeny instance final nelze vytvářet potomky

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

Více

Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007

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ů

Více

14.4.1. Typický prvek kolekce pro české řazení

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

Principy objektově orientovaného programování

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íce

typová konverze typová inference

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

Více

Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007

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ů

Více

Z. Kotala, P. Toman: Java ( Obsah )

Z. Kotala, P. Toman: Java ( Obsah ) Z. Kotala, P. Toman: Java ( Obsah ) 13. Výjimky Výjimka (exception) je definována jako událost, která nastane během provádění programu a která naruší normální běh instrukcí. Výjimka je vyvolána například

Více

4. ZÁKLADNÍ POJMY Z OBJEKTOVĚ ORIENTOVANÉHO PROGRAMOVÁNÍ

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

Více

JAVA. Ještě k funkcionálnímu programování (pokračování z předchozí přednášky)

JAVA. Ještě k funkcionálnímu programování (pokračování z předchozí přednášky) JAVA Ještě k funkcionálnímu programování (pokračování z předchozí přednášky) 1 Funkcionální programování vstup funkce výstup funkce ve FP ~ matematická funkce má parametry vrací výsledek(ky) nemá vedlejší

Více

Semin aˇr Java V yjimky Radek Ko ˇc ı Fakulta informaˇcn ıch technologi ı VUT Unor 2008 Radek Koˇc ı Semin aˇr Java V yjimky 1/ 25

Semin aˇr Java V yjimky Radek Ko ˇc ı Fakulta informaˇcn ıch technologi ı VUT Unor 2008 Radek Koˇc ı Semin aˇr Java V yjimky 1/ 25 Seminář Java Výjimky Radek Kočí Fakulta informačních technologií VUT Únor 2008 Radek Kočí Seminář Java Výjimky 1/ 25 Výjimky Co a k čemu jsou výjimky výjimka je mechanizmus umožňující psát robustní, spolehlivé

Více

Vstup/Výstup, Sokety. Duben 2012

Vstup/Výstup, Sokety. Duben 2012 Seminář Java Vstup/Výstup, Sokety Radek Kočí Fakulta informačních technologií VUT Duben 2012 Radek Kočí Seminář Java Proudy, Zpracování XML, Sokety 1/ 54 Obsah Vstup/Výstup koncepce proudů soubory, adresáře

Více

7. Datové typy v Javě

7. Datové typy v Javě 7. Datové typy v Javě Primitivní vs. objektové typy Kategorie primitivních typů: integrální, boolean, čísla s pohyblivou řádovou čárkou Pole: deklarace, vytvoření, naplnění, přístup k prvkům, rozsah indexů

Více

Seznamy a iterátory. Kolekce obecně. Rozhraní kolekce. Procházení kolekcí

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ů

Více

Java a XML. 10/26/09 1/7 Java a XML

Java a XML. 10/26/09 1/7 Java a XML Java a XML Java i XML jsou přenositelné V javě existuje podpora pro práci s XML, nejčastější akce prováděné při zpracování XML: načítání XML elementů generování nových elementů nebo úprava starého zápis

Více

KTE / ZPE Informační technologie

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ší

Více

Regulární výrazy. Vzory

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

Více

Java a národní prostředí

Java a národní prostředí Java a národní prostředí RICHARD LIPKA 25.4.2016 Nastavení národního prostředí Vstup a výstup speciálních znaků, zpracování řetězců (velká písmena, řazení) Formátování výstupu (čísla, datum, měna) Oddělení

Více

Zápis programu v jazyce C#

Zápis programu v jazyce C# Zápis programu v jazyce C# Základní syntaktická pravidla C# = case sensitive jazyk rozlišuje velikost písmen Tzv. bílé znaky (Enter, mezera, tab ) ve ZK překladač ignoruje každý příkaz končí ; oddělovač

Více

PREPROCESOR POKRAČOVÁNÍ

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,

Více

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

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í

Více

Seminář Java II p.1/43

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

Více

Příklad : String txt1 = new String( Ahoj vsichni! ); //vytvoří instanci třídy String a přiřadí ji vnitřní hodnotu Ahoj vsichni!

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

Více

SOUBORY, VSTUPY A VÝSTUPY

SOUBORY, VSTUPY A VÝSTUPY SOUBORY, VSTUPY A VÝSTUPY Soubory, adresáře a disky Soubory Pro práci se soubory slouží statická třída System.IO.File a nestatická třída System.IO.FileInfo. V prostoru jmen System.IO jsou také definovány

Více

Výčtový typ strana 67

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

Více

JAVA. Krátce o Reflection API

JAVA. Krátce o Reflection API JAVA Krátce o Reflection API 1 Přehled reflection, introspection umožňuje zjišťování informací o třídách, atributech, metodách vytváření objektů volání metod... balík java.lang.reflect třída java.lang.class

Více

Úvod Třídy Rozhraní Pole Konec. Programování v C# Hodnotové datové typy, řídící struktury. Petr Vaněček 1 / 39

Ú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

Více

Abstraktní datové typy: zásobník

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í

Více

Java - výjimky. private void vstup() throws IOException {... }

Java - výjimky. private void vstup() throws IOException {... } Java - výjimky Tato kapitola ukazuje na několika příkladech práci s výjimkami v Javě. Klíčové pojmy: Výjimka, hierarchie výjimek, zachytávání výjimek, blok try-catch, tvorba vlastních výjimek, propagace

Více

Práce s textem. Třída Character. Třída Character. Třída Character. reprezentuje objekty zapouzdřující hodnotu typu char (boxing / unboxing)

Práce s textem. Třída Character. Třída Character. Třída Character. reprezentuje objekty zapouzdřující hodnotu typu char (boxing / unboxing) Třída Character Práce s textem 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 reprezentuje objekty zapouzdřující hodnotu

Více

Definice třídy. úplná definice. public veřejná třída abstract nesmí být vytvářeny instance final nelze vytvářet potomky

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

Více

Programovací jazyk Java

Programovací jazyk Java 1 z 8 Programovací jazyk Java Enumerace (výčty) Složitější definice výčtového typu Konstanty anonymních typů Výčtový typ a datové struktury Java packaging JAR archivy CLASSPATH Apache Ant 10. přednáška

Více

Výjimky. v C# a Javě

Výjimky. v C# a Javě Výjimky v C# a Javě Výjimky v C# Výjimky poskytují v C# způsob, jak reagovat na nečekané události. Uživatel např. zadá místo čísla text nebo soubor, který chceme otevřít, je využíván jiným procesem. To

Více

Úvod do programování - Java. Cvičení č.4

Ú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í

Více

14. Vstupy a výstupy v Javě

14. Vstupy a výstupy v Javě 14. Vstupy a výstupy v Javě Koncepce I/O proudů v Javě, skládání (obalování vlastnostmi) Práce se soubory a adresáři, třída File Binární proudy, třídy InputStream, OutputStream Znakové proudy, třídy Reader,

Více

Algoritmizace a programování. Terminálový vstup a výstup

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

Více

Statické proměnné a metody. Tomáš Pitner, upravil Marek Šabo

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)

Více

Java Výjimky Java, zimní semestr

Java Výjimky Java, zimní semestr Java Výjimky 1 Výjimky (exceptions) hlášení a ošetření chyb výjimka signalizuje nějaký chybový stav výjimka = instance třídy java.lang.throwable dvě podtřídy java.lang.error a java.lang.exception konkrétní

Více

8 Třídy, objekty, metody, předávání argumentů metod

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

Více

UJO Framework. revoluční architektura beans. verze 0.80 http://ujoframework.org/

UJO Framework. revoluční architektura beans. verze 0.80 http://ujoframework.org/ UJO Framework revoluční architektura beans verze 0.80 http://ujoframework.org/ Pavel Pone(c), září 2008 Historie rok 2004 upravené objekty z frameworku Cayenne nevýhodou byla špatná typová kontrola rok

Více

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 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

Více

9. přednáška - třídy, objekty

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

Více

1. Programování proti rozhraní

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í

Více

Výjimky a soubory. Jiří Vokřínek. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze

Výjimky a soubory. Jiří Vokřínek. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Výjimky a soubory Jiří Vokřínek Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Přednáška 4 B0B36PJV Programování v JAVA Jan Faigl, Jiří Vokřínek, 2017 B0B36PJV Přednáška

Více

Část I Výjimky. Část 1 Výjimky. Výjimky a soubory. Část 2 Soubory. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze

Část I Výjimky. Část 1 Výjimky. Výjimky a soubory. Část 2 Soubory. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Část 1 a soubory Jiří Vokřínek Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Přednáška 4 B0B36PJV Programování v JAVA Jan Faigl, Jiří Vokřínek, 2017 B0B36PJV Přednáška

Více

Michal Krátký. Úvod do programovacích jazyků (Java), 2006/2007

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ů

Více

ANT. Aplikační programování v Javě (BI-APJ) - 1 Ing. Jiří Daněček Katedra softwarového inženýrství Fakulta informačních technologií ČVUT Praha

ANT. Aplikační programování v Javě (BI-APJ) - 1 Ing. Jiří Daněček Katedra softwarového inženýrství Fakulta informačních technologií ČVUT Praha ANT Aplikační programování v Javě (BI-APJ) - 1 Ing. Jiří Daněček Katedra softwarového inženýrství Fakulta informačních technologií ČVUT Praha Evropský sociální fond Praha & EU: Investujeme do vaší budoucnosti

Více

Abstraktní třída a rozhraní

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ě

Více

Obsah. Úvod 11 Základy programování 11 Objektový přístup 11 Procvičování 11 Zvláštní odstavce 12 Zpětná vazba od čtenářů 12 Errata 13

Obsah. Úvod 11 Základy programování 11 Objektový přístup 11 Procvičování 11 Zvláštní odstavce 12 Zpětná vazba od čtenářů 12 Errata 13 Úvod 11 Základy programování 11 Objektový přístup 11 Procvičování 11 Zvláštní odstavce 12 Zpětná vazba od čtenářů 12 Errata 13 KAPITOLA 1 Na úvod o Javě 15 Počítačový program 15 Vysokoúrovňový programovací

Více

Java Cvičení 01. CHARLES UNIVERSITY IN PRAGUE faculty of mathematics and physics

Java Cvičení 01.  CHARLES UNIVERSITY IN PRAGUE faculty of mathematics and physics Java Cvičení 01 http://d3s.mff.cuni.cz CHARLES UNIVERSITY IN PRAGUE faculty of mathematics and physics Příklady - Porovnání Co kód vypíše? package cz.cuni.mff.java.example01.tests; public class Test01

Více

VISUAL BASIC. Práce se soubory

VISUAL BASIC. Práce se soubory VISUAL BASIC Práce se soubory Práce se soubory 1/2 2 Vstupní data pro programy bývají uloženy do souborů Vstupy pro výpočet, nastavení vzhledu aplikace Výsledky práce programu je potřeba uchovat uložit

Více

Stromy. Příklady. Rekurzivní datové struktury. Základní pojmy

Stromy. Příklady. Rekurzivní datové struktury. Základní pojmy Základní pojmy Stromy 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 Graf uzly hrany orientované / neorientované Souvislý

Více

JAVA. Ještě k funkcionálnímu programování (pokračování z předchozí přednášky)

JAVA. Ještě k funkcionálnímu programování (pokračování z předchozí přednášky) JAVA Ještě k funkcionálnímu programování (pokračování z předchozí přednášky) 1 Funkcionální programování vstup funkce výstup funkce ve FP ~ matematická funkce má parametry vrací výsledek(ky) nemá vedlejší

Více

Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost rozhraním a výjimkám.

Tento studijní blok má za cíl pokračovat v základních prvcích jazyka Java. Konkrétně bude věnována pozornost rozhraním a výjimkám. 13 Rozhraní, výjimky 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 rozhraním a výjimkám. Doba nutná k nastudování 2 2,5 hodiny

Více

Výjimky a soubory. Jiří Vokřínek. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze

Výjimky a soubory. Jiří Vokřínek. Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze a soubory Jiří Vokřínek Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze Přednáška 4 B0B36PJV Programování v JAVA Jan Faigl, Jiří Vokřínek, 2017 B0B36PJV Přednáška 4: Výjimky

Více

Příklad aplikace Klient/Server s Boss/Worker modelem (informativní)

Příklad aplikace Klient/Server s Boss/Worker modelem (informativní) Příklad aplikace Klient/Server s Boss/Worker modelem (informativní) Jan Faigl Katedra počítačů Fakulta elektrotechnická České vysoké učení technické v Praze A0B36PR2 Programování 2 Jan Faigl, 2015 A0B36PR2

Více

Programování v C++ 1, 5. cvičení

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é

Více

PŘETĚŽOVÁNÍ OPERÁTORŮ

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

Více

Programování v jazyce JavaScript

Programování v jazyce JavaScript Programování v jazyce JavaScript Katedra softwarového inženýrství Fakulta informačních technologií České vysoké učení technické v Praze Pavel Štěpán, 2011 Dědičnost objektů BI-JSC Evropský sociální fond

Více

Pokud zadání nerozumíte nebo se vám zdá nejednoznačné, zeptejte se. Pište čitelně, nečitelná řešení nebudeme uznávat.

Pokud zadání nerozumíte nebo se vám zdá nejednoznačné, zeptejte se. Pište čitelně, nečitelná řešení nebudeme uznávat. Pokud zadání nerozumíte nebo se vám zdá nejednoznačné, zeptejte se. Pište čitelně, nečitelná řešení nebudeme uznávat. 1. Odkrokujte následující program a s použitím notace z přednášky sledujte stav paměti

Více

Remote Method Invocation RMI

Remote Method Invocation RMI Remote Method Invocation RMI Java TM Remote Method Invocation (RMI) umožňuje objektu na jedné Java Virtual Mashine(JVM) jednoduše spustit metodu jiného objektu na vzdálené JVM. Při volání vzdálené metody

Více

Pokud zadání nerozumíte nebo se vám zdá nejednoznačné, zeptejte se. Pište čitelně, nečitelná řešení nebudeme uznávat.

Pokud zadání nerozumíte nebo se vám zdá nejednoznačné, zeptejte se. Pište čitelně, nečitelná řešení nebudeme uznávat. Pokud zadání nerozumíte nebo se vám zdá nejednoznačné, zeptejte se. Pište čitelně, nečitelná řešení nebudeme uznávat. 1. Odkrokujte následující program a s použitím notace z přednášky sledujte stav paměti

Více

Základy jazyka C# Obsah přednášky. Architektura.NET Historie Vlastnosti jazyka C# Datové typy Příkazy Prostory jmen Třídy, rozhraní

Základy jazyka C# Obsah přednášky. Architektura.NET Historie Vlastnosti jazyka C# Datové typy Příkazy Prostory jmen Třídy, rozhraní Základy jazyka C# 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 Obsah přednášky Architektura.NET Historie Vlastnosti

Více

7 Formátovaný výstup, třídy, objekty, pole, chyby v programech

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,

Více