ITI0011-2015:praktikum 02

Allikas: Kursused
Redaktsioon seisuga 5. veebruar 2015, kell 07:17 kasutajalt Ago (arutelu | kaastöö) (Uus lehekülg: ' == Üldine == See lehekülg sisaldab 2. praktikumi materjali. == Teemad == * Eclipse * git? * Java keel ** muutujad ** põhilised operaatorid ** funktsioonid * Harjutusüles...')
(erin) ←Vanem redaktsioon | Viimane redaktsiooni (erin) | Uuem redaktsioon→ (erin)
Mine navigeerimisribale Mine otsikasti


Üldine

See lehekülg sisaldab 2. praktikumi materjali.

Teemad

  • Eclipse
  • git?
  • Java keel
    • muutujad
    • põhilised operaatorid
    • funktsioonid
  • Harjutusülesanne

Eclipse

Eclipse on IDE (Integrated Development Environment), mida kasutame Java tundides ülesannete lahendamiseks. Kes tahab, võib kasutada mõnda muud, näiteks:

  • NetBeans [[1]]
  • IntelliJ IDEA [[2]]

Eclipse'i käivitamine

Eclipse'i saab alla tõmmata järgmiselt lehelt: http://eclipse.org/
Sealt paremalt nupp "DOWNLOAD" -> Eclipse IDE for Java Developers. Võit eelnevalt valida opsüsteemi, kui see pole automaatselt õigesti määratud.

Kui olete zip-faili alla tõmmanud, tuleb see lahti pakkida näiteks kodukausta (windowsis c:\users\ago\eclipse). Mingit installeerimist ei toimu. Programmi käivitate vastavast kaustast, näiteks c:\users\ago\eclipse\eclipse.exe .

Programm küsib käivitamisel teilt workspace'i asukohta. Vaikimsi pakutud asukoht (kodukasutas workspace kaust) on täitesti sobiv. Kes tahab, võib selle kuhugi mujale paigutada. Kõik teie loodud failid hakkavad selles kataloogis (ja alamkataloogides) olema.

Eclipse'i tööaken

Kui panete Eclipse'i esimest korda käima, näidatakse teile "Welcome" lehte. Selle saate ülevalt paremalt "Workbench" kinni panna.

Eclipse'i tööaken on jagatud mitmeks erinevaks osaks. Igas osas saate hoida teile sobivaid paneele. Vaikimisi seadustuses paikneb vasakul "Package explorer", all asuvad "Problems", "Javadoc", "Declarations" ja "Console" paneelid. Paremal on näha "Task list" ja "Outline" paneelid. Keskmine osa on eraldatud aktiivsele koodifailile - ehk siis sinna ossa kirjutate koodi. Kõiki paneele saate ümber paigutada (näiteks tõsta mõne paneeli alt paremale jne), ära peita või siis ekraanilt üldse eemaldada. Paneeli saate "ära peita" paneeli üleval paremal servas oleva "-" nupukesega. Peitmise korral ei paista paneel vaikimisi ekraanil välja, küll aga on paremal ääres riba, mille peal see paneel (või paneelide grupp) on nähtav ikoonina. Sealt saab selle jälle nähtavale tuua. "x" kaotab konkreetse paneeli ekraanilt täielikult. Kui võtate paneeli päisest kinni, saate seda lohistada ekraanil teise kohta. Paigutus salvestatakse automaatselt - järgmisel korral, kui Eclipse'i avate, taastatakse see seis, mis teil viimati oli.

Kõik paneelid on kättesaadavad Window -> Show view -> Other... Sealt saate nime ja/või struktuuri järgi otsida. Ehk siis kui kogemata olete midagi ära kaotanud, saate sealt selle taastada.

Näiteks üks võimalus, kuidas tööaken seadistada on nii, et paremal on "Package explorer", vasakul on "Outline" (kui te seda kasutada oskate). Alumises osas on "Problems", "Javadoc", "Console". Kõik sõltub sellest, milliseid vaateid programmeerija oskab ja on harjunud jälgima.

Eclipse'i seadistamine

Eclipse'i seaded on nähtavat Window -> Preferences. Avaneb eraldi dialoog, kus saate seadeid otsida nime ja/või struktuuri järgi. Näiteks üks muudatus, mida õppejõud tavaliselt teeb, on fondi suurendamine. Selleks piisab, kui kirjutada otsingulahtrisse "font". Otsingutulemusena kuvatakse vaid see seadete menüü, kus nimetatud otsisõna leidus. Antud juhul General -> Appearance -> Colors and Fonts. Sealt valin Java -> Java Editor Text Font. Muudan suuruseks näiteks 20.

Otseselt teil mingit vajadust seadistuste muutmiseks pole. Küll aga mõnes olukorras võib see vajalik olla. Eks me kursuse käigus viitame, kui mingeid seadeid oleks vaja muuta.

Eclipse'ile Checkstyle lisa (plugin)

Üks kuruse eesmärke on õpetada teid kirjutama "ilusat" koodi. Selle tarvis on meil kasutusel üks Eclipse'i lisa, mis aitab koodiilu jälgida: Checkstyle. Selleks, et see lisa peale panna, toimige järgmiselt:

  • Help -> Eclipse Marketplace
  • otsingusse "Checkstyle"
  • tulemustest "Checkstyle Plug-in 6.2.0" (peaks olema teine) juurest "install"
  • näitab dialoogi, kus on nimekirjas kaks komponenti, mõlemal peaks "linnuke" juures olema (ehk siis mõlemad on märgistatud automaatselt). Vajutada "Confirm >".
  • "I accept..." (muidugi tekst tuleks läbi ka lugeda...), "Finish"
  • Installeerimise ajal küsib Eclipse kinnitust, kas tahad installeerida tarkvara, mis pole signeeritud. Security Warning, you are installing software that contains unsigned content. Vajuta "OK".
  • Peale installeerimist küsib Eclipse restarti teha, võimaldage see (vajutades "Yes").

Kui Eclipse uuesti käima läheb (ta võib teilt küsida uuest workspace'i asukohta, mis võiks olla täidetud selle asukohaga, mis te eelnevalt määrasite), peaks Checkstyle plugin peal olema.

Järgmiseks tuleb Checkstyle'i jaoks seadistused paika panna. Selleks tuleb alla laadida seadistuste fail: XML-fail. Fail on olemas ka materjalide repositooriumis stuff/checkstyle-iti0011.xml . Võimalik, et kursuse jooksul me uuendame seda faili, kui mõni seadistus tundub liiga leebe või range. Selleks, et seadistused failist rakenduda saaksid, tuleb see fail Eclipse'i plugin'ile külge panna. Selleks:

  • Window -> Preferences
  • otsingusse "Checkstyle" (tegelikult selline menüü on kohe vasakul nimekirjas ka olemas)
  • "Checkstyle" menüüst valides, on näha paremal pool nimekirja "Global Check Configurations", kus peaks olema üks Google'i ja kaks Sun'i seadistust. Meie lisame sinna oma seadistuse.
  • nimekirjast paremal on nupp "New..."
  • avaneb dialoog
  • Type: External Configuration File
  • Name: ITI0011
  • Location: otsite arvutist alla laetud XML-faili üles.
  • "OK"
  • nimekirja peaks ilmuma ITI0011. Märkida see hiirega ära ja vajutada paremalt nuppu "Set as Default"

Nüüd peaks sobiv konfiguratsioon olema peale pandud. Huvi korral võite sealtsamast seadistuste alt vaadata, millised piirangud on selle konfiguratsiooniga peale pandud (nimekirjas aktiivseks teha ja "Configure...").

Automaatselt Checkstyle plugin ei aktiveeru. Selleks, et antud lisast kasu oleks, tuleb see iga projekti puhul käsitsi aktiveerida. Aga enne, kui seda teha saame, peame mõne projekti looma.

Uus projekt

Projekt võib koosneda mitmest Java failist. Üldiselt projekt on üks terviklik programm. Näiteks iga teie koduülesanne võiks olla üks projekt. Samamoodi harjutusülesanded võiksid olla eraldi projektid. Kuigi tunniülesandeid võib ka kokku kõik ühte projekti panna.

Meie loome käesoleva praktikumi jaoks uue projekti. Selleks:

  • File -> New -> Java Project
  • Project name: näiteks "praktikum02´"
  • ülejäänud seadistused võib paika jätta.
  • "Finish"

Vasakule package exploreri paneeli peaks ilmuma kaust (projekt) nimega "praktikum02". Kui te projekti nime ees oleval kolmnurgal klikite, avatakse projekti sisu. Kogu projekti struktuur on näha n-ö kataloogipuuna (analoogiline vaade on ka näiteks Windows Exploreris olemas). Kui te arvutist oma workspace'i üles otsite, siis iga projekt on tegelikult lihtsalt üks kaust. Projekti all on kaust "src" (see on ka päriselt kõvakettal olemas). Esialgu on see kaust tühi.

Lisame esimese koodifaili. Selleks:

  • parem klikk "src" kaustal
  • avanevast menüüst New -> Class
  • avaneb dialoog
  • Name: TereMaailm
  • märgistada ära "public static void main(String[] args)"
  • kustuta praegu "package" sisu ära
  • "Finish"

Vasakul package explorer vaates peaks "src" kaustas olema üks alamkaus nimega "(default package)". Üldiselt lähtekoodi kaust ("src") jaguneb pakettideks. Iga pakett on tegelikult kaust kõvakettal. Kuna ma selle faili puhul lihtsuse mõttes paketti ei lisanud, on see fail tegelikult otse "src" kausta all (kuigi ta nagu näitas, et vahepeal on üks "(default package)" nimeline kaust). Kui me oleks paketi nimeks pannud "tere", siis oleks lähtefail läinud "tere" kausta all jne. Esialgu meil pakette pole vaja väga uurida. Seega siinkohal otseselt vahet pole, kas ja mis nimega paketi alla see sai lisatud.

Tööakna keskmises osas peaks avanema loodud klassi (mis tegelikult on lihtsalt üks fail nimega TereMaailm.java) lähtekood.

Kood peaks välja nägema umbes selline: <source lang="java"> public class TereMaailm {

public static void main(String[] args) { // TODO Auto-generated method stub

}

} </source>

Esimene programm, mille me teeme, prindib käivitamisel teksti ekraanile.

Osa sellest lähtekoodist, mis teil failis algselt on, jääb meil seletamata (õigemini seletame me seda mõne nädala pärast, kui oleme muud põhiasjad läbi käinud). Lühidalt öeldes:

  • 1. rida "public class TereMaailm" näitab klassi nimetuse "TereMaailm". Javas peab üldiselt failinimi ühtima selle sees oleva klassinimega. Kogu klassi sisu jääb {} märkide vahele. Ehk siis sellel real klassi definitsioon hakkab ning viimasel real lõppeb.
  • 3. rida "public static void main(String[] args)" defineerib ära ühe meetodi/funktsiooni, mille nimi on "main". See on eriline meetod, kuna sellest meetodist pannakse käesolev fail/klass käima. Kui sellist meetodit pole, siis seda klassi/faili ei saa otse käivitada. Sulgudes antakse funktsioonile kaasa mingid argumendid.
  • 4. rida " // ..." on kommentaar. See on programmeerijale - arvuti ignoreerib kommentaare. Teil on soovitatav oma koodis kommentaare kasutada, et kirjeldada mingeid tegevusi
  • 6. rida "}" lõpetab main-meetodi
  • 8. rida "}" lõpetab TereMaailm klassi

Meie ülesanne on main-meetodisse kirjutada koodi juurde. See kood pannakse käima siis, kui me selle faili käivitame. Kirjutame main-meetodisse ühe rea juurde: <source lang="java"> public class TereMaailm {

public static void main(String[] args) { // TODO Auto-generated method stub System.out.println("Tere maailm!")

}

} </source>

Kui te täpselt sellise rea lisate faili, peaks teil tekkima 5. rea algusesse punane ristike. See annab märku, et teie koodis on sellel real mingi viga. Enne, kui hakkame seda viga parandama, vaatame natuke, kuidas Eclipse'is vigu saab jälgida.

Tööakna alumises osas peaks teil olema tääb või paneel nimega "Problems". Kui te selle aktiivseks teete, peaksite nägema seal umbes sellist rida "Errors (1 item)". Kui selle rea ees olevale kolmnurgale vajutada, peaks avanema/sulguma vigade nimekiri. Seal on see meie tekitatud viga. Kui teete topeltkliki selle rea peal, avaneb teil koodis see koht, kus mainitud viga on tekkinud. Antud juhul on probleem selles, et Javas kõik käsud lõppevad semikooloniga (Pythonis see polnud vajalik).

Seega, töötav kood võiks olla selline:<source lang="java"> public class TereMaailm {

public static void main(String[] args) { // TODO Auto-generated method stub System.out.println("Tere maailm!");

}

} </source>

Kui tahame näha, mida meie programm teeb, saame ülevalt menüüst võtta Run -> Run As -> Java Application. Sama saab ka klahvikombinatsiooniga ctrl + F11. Kui olete programmi käivitanud, siis peaks automaatselt aktiivseks minema alumine Console paneel, kuhu peaks ilmuma tekst "Tere maailm!". Sellega oleme esimese programmi Javas valmis kirjutanud, kuigi me väga palju ei rääkinud, mida miski rida teeb. Jätkame nüüd Java keele teemadel.

git

TODO

Muutujad

Muutuja (ik variable) on nimeline viide mingile väärtusele, mis paikneb kuskil mälus. Näiteks võib muutuja nimi olla x ja see viitab väärtusele 5. Pseudokoodina võib kirjutada, et x = 5 (tegelikult samamoodi saab matemaatikas muutuja väärtust määrata). Kui edaspidi kuskil kasutatakse x'i, siis on selle väärtus 5. Näiteks x + 3 on väärtuse poolest sama mis 5 + 3. Analoogselt võib mõelda näiteks Exceli lahtritele. Kui te seal kirjutate mingeid valemeid, siis teete seda selliselt: =A1 + B2. A1 ja B2 oleksid nagu muutujad, mille väärtus on vastavates lahtrites.

Javas on igal muutujal lisaks nimele ka andmetüüp. Kui näiteks Pythonis võib kirjutada x = 'tere' ja seejärel kohe x = 3, siis Javas tuleb kõigepealt muutuja tüüp määrata. Edaspidi tohib see muutuja ainult seda tüüpi andmeid hoida. Näiteks täisarvuline andmetüüp on int: int x = 3;. Edaspidi koodis, kui ma olen juba x-ile andmetüübi määranud, saan ma kasutada lihtsalt muutujat (ilma andmetüübita): x = 4;. Viimane näide oli selline, kus deklareeriti muutuja x ning sellele anti kohe väärtuseks 3. Seejärel muudeti x'i väärtus 4-ks.

Sama nimega muutujaid tohib olla vaid üks. Kui koodis on deklareeritud muutuja x, siis rohkem selles koodiosas ei tohis x-nimelist muutujat olla.

Andmetüübid

Andmetüübid Javas jagunevad kahte suuremasse klassi: primitiivsed andmetüübid ja objektid. Esialgu vaatleme primitiivseid andmetüüpe. Primitiivsete andmetüüpide korral kehtib reegel, et muutujal on konkreetne väärtus. Hiljem objektide puhul näeme, mismoodi see on erinev.

All tabelis on välja toodud erinevad primitiivsed andmetüübid Javas:

Tüübe nimi Suurus Väärtused Näide
byte 1 bait (8 bitti) -128..127 byte b = 42;

Muutuja deklareerimine, väärtustamine

Muutuja deklareerimine ehk muutuja tutvustamine programmile käib selliselt:

[andmetüüp] [muutujanimi];

või


[andmetüüp] [muutujanimi] = [algväärtus];

Näiteks:

int y; int x = 10;

Edaspidi igal ajal koodis võib muutuja väärtust muuta:

y = 1; x = 3;

Muutujate nimetamine

Java keeles lubatud muutuja nimed: N, n, x15, a_long_name, time_is_$, HelloWorld. Muutuja nimi on tõstutundlik, ehk siis kõik järgmised on erinevad muutujad: HelloWorld, helloWorld, helloworld, HELLOWORLD, HeLLoWoRLd. Keelekonstruktsioonide nimetused on reserveeritud, seetõttu nimed nagu class, public, static, if, else jne ei ole lubatud.

Kuigi Javas on lubatud väga erinevad nimekujud, on soovitatav järgida neid reegleid:

  • muutuja nimi peaks olema mõistlik (temperature, speed mitte a, b)
  • nimi peaks algama väikese tähega
  • kasutada tuleks täisnimetusi (temperature, mitte temp)
  • kui nimi koosneb ühest sõnast, siis kasutada läbivat väiketähte: weight, speed.
  • kui nimi koosneb kahest või rohkemast sõnast, siis kirjutatakse sõnad kokku ning alates teisest sõnast iga sõna esimene täht peaks olema suur: playAgain, currentSpeed.

Kuna keelekonstruktsioonid on kõik inglisekeelsed (if, while, class jne), siis on soovitatav kasutada inglisekeelseid muutujanimesid (speed, mitte kiirus). Igal juhul võiks loogika olla läbi koodi sama: kui alustasite eestikeelsete muutujanimedega, siis peaks sama loogika kehtima lõpuni. See, kus mõned muutujad on eestikeelsed ja mõned inglisekeelsed, on väga halb komme.

Konstandid

Konstandid on erilisttüüpi muutujad. Nad on samamoodi andmetüübiga ja nimega viited mingile väärtusele. Erinevus tavalisest muutujast on see, et konstandi väärtust ei saa hiljem enam muuta. Konstandi nimetamise reelgid on mõnevõrra erinevad tavamuutujast:

  • kõik tähed nimes on suurtähed: PI, SPEED.
  • sõnad on eristatud alakriipsuga (_): SPEED_OF_LIGHT, NUMBER_OF_GEARS.

Konstandi saab luua klassi päises (enne meetodeid/funktsioone): public static final double PI = 3.14;

Aga konstantidest räägime täpsemalt mõnevõrra hiljem. Praeguses tekstis on konstandid mainitud nimetamise tõttu.

Operatsioonid, tehted

Funktsioonid