LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Programování v jazyku Java (6) - Řetězce I

V tomto díle si ukážeme jak jsou v Javě ukládány a zpracovávány textové informace.

20.8.2004 14:00 | Petr Hatina | Články autora | přečteno 78604×

Řetězce I

Řětězce slouží k ukládání textových informací. V Javě jsou vnitřně kódovány v UNICODE. Používají dvě základní objektové třídy - String a StringBuffer.

Třída String slouží k ukládání konstantních textových informací, které nehodláme (nebo jen málo) měnit. Hodnota v objektu typu String totiž je konstantní, při změně nebo přiřazení jiné hodnoty je vytvořen v paměti nový objekt a přiřazen původní proměnné. Původní hodnota objektu je posléze v paměti smazána. Což spotřebuje určitou časovou i systémovou režii.

Proto je pro ukládání textových informací, které jsou v programu častěji modifikovány, rozšiřovány či spojovány lépe použít třídu StringBuffer, které se budeme věnovat příště.

String

Proměnnou typu String lze obvykle inicializovat přiřazením textové konstanty:

String s= "Helo World";

Kromě přímého přiřazení pevné textové hodnoty můžeme řetězec inicializovat již při jeho deklaraci i jinak:

String s=  new String() ;    // prázdný řetězec
String s=  new String(String t); //rovnou překopíruje jiný řetězec
String s=  new String(char ch[] );  // řetězec  z pole znaků
String s=  new StringBuffer();    // řetězec z objektu StringBuffer 
String s = new String(byte[] pole,"ISO8859_2") /*vytvoří a převede 
 řetězec z pole znaků v jiné znakové sadě" */

Řetězce můžeme spojovat (s výhradou vůči optimalizaci, viz výše ) operátorem +

String Jmeno="Jan";String Prijmeni="Novak";
String Vizitka= Jmeno+ " "+ Prijmeni;
System.out.println("Jeho inicialy jsou " + Jmeno+ " "+ Prijmeni);

Aktuální délku řetězce vrací metoda length :

int delka=Jmeno.length();

Co provádět nemůžeme, to je porovnání řetězců operátorem ==,protože typ String je odkaz. Musíme použít jeho metodu equals (resp. equalsIgnoreCase) , která ignoruje rozdíly mezi velkými a malými písmeny).

String s1="Jan";boolean ok;
ok=s1.equals("Jan"); //vraci true
ok=s1.equals("jan"); //vraci false 
ok=s1.equalsIgnoreCase("jan"); //takhle je to OK
ok=s1.equals("franta"); //vraci false

Potřebujeme-li při porovnání určit který z řetězců je větší, použijeme metodu compareTo

String s1="Jan";
int i=s1.compareTo("franta"); // vrací záporné číslo

Metoda compareTo vrací 0 pokud jsou oba řetězce stejné,záporné číslo pokud je porovnávaný řetězec menší než předaný poarametr a kladné číslo pokud je větší.

Pro porovnání zda text obsahuje pouze určité skupiny znaků slouží metoda matches, která porovnává řetězec podle regulárních výrazů, tak jak je známe z linuxových příkazů. S regulárním výrazy pracují i metody replaceAll, replaceFirst(), které nahrazují část řetězce jiným textem. Regulárním výrazům v řetězcích budeme věnovat samostatnou kapitolu.

Jednotlivé znaky v řetězci lze měnit pomocí metody replace:

String s="01234567890";
s=s.replace('0','X');   //změní všechny  znaky 0 na X

K metodám, měnícím obsah řetězce patří také toUpperCase a toLowerCase, (převod na velká, resp. malá písmena), a trim, která odstraňuje úvodní a koncové bílé znaky (tj.mezery, tabelátor, konec řádku).

Vyhledávat text v řetězci lze pomocí metody indexOf, která vrací polohu podřetězce v řětězci, (tedy přesně řečeno, vrací index, takže se počítá od 0) či startsWith, která testuje zda řetězec začíná uvedeným textem.

Opačnou funkci, tedy vrácení řetězce na určité pozici obstarávají metody substring a charAt(ta vrací znak na pozici).

String s="01234567890"
int poz= s.indexOf("456") //vyhledá pozici podřetězce v celém řetězci
boolean ok=s.startsWith("0123") //
String sub= s.substring(0,2); //vrací podřetězec od indexu 0 do 2-1

Verze pro tisk

pridej.cz

 

DISKUZE

Spojovani retezcu 20.8.2004 14:39 MarrLiss
proc serial tu? 23.8.2004 22:15 tomiq
L Re: proc serial tu? 23.8.2004 22:27 tomiq
replace a replaceAll 15.9.2009 00:02 Dan Pelíšek
  L Re: replace a replaceAll 15.9.2009 09:24 Petr Balšánek




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

16.7.2018 1:05 /František Kučera

Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.


Přidat komentář

18.6.2018 0:43 /František Kučera
Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.
Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

14.5.2018 7:28 /František Kučera
Květnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 17. 5. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: Audio – zvuk v GNU/Linuxu.
Přidat komentář

7.5.2018 16:20 /František Kučera
Na stránkách spolku OpenAlt vyšla fotoreportáž Pražské srazy 2017 dokumentující srazy za uplynulý rok. Květnový pražský sraz na téma audio se bude konat 17. 5. 2018 (místo a čas ještě upřesníme).
Přidat komentář

17.4.2018 0:46 /František Kučera
Dubnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 4. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tématem tohoto srazu bude OpenStreetMap (OSM) aneb svobodné mapy.
Přidat komentář

16.3.2018 22:01 /František Kučera
Kulatý OpenAlt sraz v Praze oslavíme klasicky: u limonády a piva! Přijďte si posedět, dát si dobré jídlo a vybrat z mnoha piv do restaurace Kulový blesk, který najdete v centru Prahy nedaleko metra I. P. Pavlova na adrese Sokolská 13, Praha 2. Sraz se koná ve čtvrtek 22. března a začínáme v 18:00. Heslo: OpenAlt. Vezměte s sebou svoje hračky! Uvítáme, když si s sebou na sraz vezmete svoje oblíbené hračky. Jestli máte nějaký drobný projekt postavený na Arduinu, nějakou zajímavou elektronickou součástku, či třeba i pěkný úlovek z crowdfundingové akce, neváhejte. Oslníte ostatní a o zábavu bude postaráno.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

16.1.2018 1:08 / Ivan Pittner
verejna ip od o2 ubuntu

15.1.2018 17:26 / Mira Harvalik
Re: Jak udělat HTML/Javascript swiping gallery do mobilu?

30.12.2017 20:16 / Michal Knoll
odmocnina

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2018) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze