Tato kapitola bude věnována proměnným a primitivním datovým typům. Bohužel se jedná o látku, která sice není příliš náročná, ale je objemná, z tohoto důvodu se operacemi nad těmito typy budeme zabývat až v další kapitole.
Co je to proměnná?
Proměnná je pojmenovaná část paměti, kterou používáme k uložení informace. Vezmeme-li si jako příklad zaměstnance nějaké firmy, tak proměnná popisující jeho plat může mít hodnotu 25000, heslo k jeho uživatelskému účtu bude nenavidimPraci a příznak jeho pohlaví jeMuz bude nastaven na hodnotu PRAVDA.
Typ proměnné
V Javě vždy při deklaraci proměnné určíme její typ. Tento typ později již nemůžeme nijak změnit (v rámci bloku, kde je proměnná platná). Pokud například prohlásíme o proměnné x, že je typu celé číslo, tak se do ní nesmíme později snažit umístit řetězec. Toto není nijak překvapivé pro začátečníka, případně pro člověka se zkušenostmi s jiným silně typovaným jazykem. Ale pro uživatele například PHP to může být šok (PHP je dynamicky typované – typ proměnných se mění automaticky v závislosti na datech).
Silná typovost se proto může zdát být slabinou a zbytečným šikanováním programátora, ale ve skutečnosti velmi usnadňuje práci (vývojové prostředí může lépe radit a pomáhat) a zabraňuje značnému množství chyb z nepozornosti.
Jména proměnných
Jména proměnných v Javě mohou být libovolně dlouhá, ale musí začínat písmenem, symbolem podtržítka (_) nebo dolaru ($) a nesmí být klíčovým slovem jazyka (např. název datového typu). V názvu smíme používat libovolné znaky, protože Java pro zdrojové kódy používá Unicode, ale mějme na paměti, že kód mohou číst i jiní lidé jiných národů. Jak by nám asi bylo příjemné, kdybychom měli půlku kódu v japonských znacích (které ani nemáme na klávesnici).
Konvence pro názvy proměnných říká, že pokud se nejedná o konstanty, tak by měly by být psány camelCasem – první písmeno názvu vždy malým písmenem, pokud název obsahuje více slov, tak první písmeno každého nového slova vždy velké (cisarovyNoveSaty).
Upozornění na závěr: Java je case-sensitive. Proměnné pes a Pes jsou různé.
Primitivní datové typy
Celočíselné datové typy
Pro ukládání celých čísel Java obsahuje čtyři datové typy byte, short, int, long. Tyto typy se liší pouze v rozsahu hodnot, které mohou používat. Všechny obsahují jak kladná, tak záporná čísla (a nelze to ovlivnit).
Důležitou poznámkou je, že všechny celočíselné literály (tj. hodnoty přímo vepsané ve zdrojovém kódu) jsou implicitně typu int. Pokud proto chteme vložit do proměnné typu long hodnotu, která je vyšší než maximální rozsah typu int, tak musíme na konec literálu přidt znak l nebo L.
Typ | Rozsah | Paměť |
---|---|---|
byte | -128 až 127 | 1 bajt (8 bitů) |
short | -32768 až 32767 | 2 bajty (16 bitů) |
int | -2147483648 až 2147483647 | 4 bajty (32 bitů) |
long | -9223372036854775808 až 9223372036854775807 | 8 bajtů (64 bitů) |
Datové typy reálných čísel
Pro reálná čísla existují typy float a double (viz tabulka). Protože tyto typy musí mít velký rozsah (od obrovských čísel po velmi malé zlomky), používá se pro jejich reprezentaci plovoucí desetinné čárky. To znamená, že jsou čísla zapsána tak, aby jejich první platná číslice byla přímo za desetinnou čárkou (tzv. mantisa) a za tímto zápisem následuje číslo reprezentující exponent základu soustavy, kterým když přenásobíme mantisu, tak dostaneme uložené číslo. Takto to vypadá velmi složitě, ale z příkladů (v desítkové soustavě) je jasně patrné, jak to funguje.
Na tomto matematickém cvičení je důležité jedno poselství – typy float a double nejsou přesné, protože obsahují určitý fixní počet míst pro zápis mantisy a exponentu.
Typ | Rozsah | Přesnost | Paměť |
---|---|---|---|
float | -3.4e38 až 3.4e38 | cca. 7 míst | 4 bajty (32 bitů) |
double | -1.7e308 až 1.7e308 | cca. 17 míst | 8 bajtů (64 bitů) |
Poslední poznámkou pro reálná čísla je, že pro literály je implicitním typem double, proto pokud chceme říci kompilátoru, že je daný literál typu float, tak na konec literálu připojíme znak f nebo F.
Datový typ znak
Pro ukládání jednotlivých znaků v Javě slouží typ char, který zabírá v paměti 2 bajty místa. Pro vložení hodnoty znaku do proměnné lze použít buď celočíselného literálu, apostrofů ('A') nebo Unicode sekvence ('\\u0041').
Poznámka: Mezi použitím apostrofů a uvozovek je v Javě rozdíl. Zatímco 'A' znamená znak A, "A" znamená řetězec, který obsahuje jeden znak A.
Logické hodnoty
Pro reprezentaci logických hodnot (pravda/nepravda) slouží typ boolean. Boolean může obsahovat buď hodnotu true – pravda nebo false – nepravda.
Deklarace a inicializace proměnných
Pro vytvoření proměnné (deklaraci) a dosazení hodnoty do proměnné (inicializaci) se dá použít několik různých zápisů. Všechny zápisy jsou správné, některé jsou však správnější (viz komentáře). Následující kód obsahuje deklarace a inicializace všech datových typů, které jsme si dnes ukázali.
Jak si asi všimnete, tak je za každým příkazem středník, to je v Javě povinnost. Povinností ovšem není mít na řádce pouze jeden příkaz, to je obecná kultura.
01.
/*****************************
02.
* Deklarace a inicializace *
03.
*****************************/
04.
int
i1;
//pouze deklarace
05.
i1 =
1500
;
//inicializace
06.
07.
int
i2 =
1500
;
//deklarace s inicializaci - doporuceny postup
08.
int
i3, i4, i5;
//deklarace vice promennych - neni doporuceno
09.
int
i6 =
7
, i7 =
15
, i8 =
17
;
//toto take neni doporuceno
10.
11.
/*****************************
12.
* Cela cisla *
13.
*****************************/
14.
byte
b =
100
;
//byte
15.
16.
short
s = -
30000
;
//short - zaporne cislo
17.
short
s2 =
30000
;
//short - kladne cislo
18.
19.
int
i =
10000
;
20.
21.
long
l =
100
;
22.
long
l2 = 150000000000l;
//long - prilis velke cislo
23.
long
l3 = 150000000000L;
//long - varianta L
24.
25.
/*****************************
26.
* Realna cisla *
27.
*****************************/
28.
double
d =
100.5
;
29.
double
d2 =
0.5
;
30.
double
d3 = .
5
;
//0.5
31.
double
d4 = 5E-
1
;
//0.5
32.
double
d5 =
0
.5e0;
//0.5
33.
34.
float
f =
100
.5f;
35.
float
f2 =
100
.5F;
36.
37.
/*****************************
38.
* Znaky *
39.
*****************************/
40.
char
ch =
'A'
;
41.
char
ch2 =
65
;
// A (ASCII hodnota)
42.
char
ch3 =
'\\u0041'
;
43.
44.
/*****************************
45.
* Logicke hodnoty *
46.
*****************************/
47.
boolean
bool =
true
;
48.
boolean
bool2 =
false
;
49.
50.
/*****************************
51.
* Priklad vypisu *
52.
*****************************/
53.
System.out.println(b);
54.
System.out.println(i);
55.
System.out.println(l);
56.
System.out.println(d5);
57.
System.out.println(f2);
58.
System.out.println(ch3);
59.
System.out.println(bool);
Pokud si chcete tento kód vyzkoušet, tak jej umístěte na stejné místo, na které jsme v minulém díle umístili výpis řetězce Hello world. Zároveň si vyzkoušejte, že lze vypsat proměnné všech datových typů stejným způsobem, jako jsme to minule udělali s oním nápisem. Celý projekt si také můžete stáhnout zde.
Literatura
- HORTON, Ivor. Java 5. Praha : Neocortex spol s.r.o., 2005. 1443 s. ISBN 80-86330-12-5.