Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
|
|
- Juuso Aho
- 8 vuotta sitten
- Katselukertoja:
Transkriptio
1 ITKA203 Käyttöjärjestelmät tentti Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen <paavo.j.nieminen@jyu.fi> Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja syntymäaikasi sekä kurssin nimi. Lisäksi vastauspaperisi tulee sisältää 48 peräkkäistä numeroitua kohtaa, joissa on joko tehtävässä pyydetty vastaus tai viiva tyhjän vastauksen merkiksi. Mikäli tehtävässä ei mainita poikkeuksista, jokainen oikea vastaus tuo 0.5 pistettä. Kyllä/ei -väittämissä sekä muissa kysymyksissä, joissa on kaksi vaihtoehtoa (A tai B), väärä vastaus tuo miinuspisteitä pistettä, jotta odotusarvoksi täydellä arvaamisella tulee selkeästi hylätty pistemäärä. Esimerkkeihin perustuvissa tehtävissä oletetaan, että järjestelmässä ei ole yhtäaikaa muita käyttäjiä, prosesseja, vikoja tai muutakaan, jotka muuttaisivat toimintaa siitä, miltä se esimerkissä suoraviivaisesti näyttää. Oletetaan myös, että kaikki käyttöjärjestelmä- ja alustakirjastokutsut toimivat ilman poikkeuksia tai virheitä. Moniselitteisiä kysymyksiä ei ole laitettu mukaan tahallisesti. Mikäli jokin tehtävä on vahingossa sellainen, että vastaus ei olekaan yksikäsitteinen, laita vastauspaperiisi tehtävän kohdalle kommentti, jossa kerrot, miksi mielestäsi näin on. Virheellisiksi osoittautuvat kysymykset poistetaan tämän tenttikerran arvostelusta ja muokataan kysymyspankissa yksiselitteisempään muotoon tulevaisuutta varten. Numeroidut kysymyskohdat 1 48 Tutkittava esimerkki tehtäviin 1 2: Kurssin luennoilta ja demoista tutussa ympäristössä (Linux,bash) tehty yksittäinen, POSIX-syntaksin mukainen komentorivi: arg arg cat grep -i "a b c" sort -f -r kissa > cat 1. Montako komentoa rivillä on yhteensä? 2. Montako argumenttia rivillä on yhteensä? Ohje tehtäviin 3 5: Yhdistä lauseen loppua vastaava kirjain numeroituun alkuun siten, että kukin lause on totta. Alkuihin on yksikäsitteinen oikea loppu. Jokainen loppu voi sopia useampaan alkuun tai ei yhteenkään. Tehtävässä tutkitaan prosessien tilasiirtymäkaaviota, jonka selitetekstit on korvattu numeroilla: Suspended User running New Exit Kernel running 5 6 Ready 3 4 Blocked (4) sivu 1 (7)
2 3. Tilasiirtymä nro 1 tapahtuu, 4. Tilasiirtymä nro 5 tapahtuu, 5. Tilasiirtymä nro 6 tapahtuu, A. kun käyttöjärjestelmän vuorontaja siirtää suoritukseen toisen prosessin, vaikka nykyinenkin prosessi pystyisi jatkamaan laskemista jo seuraavassa konekielikäskyssään. B. kun prosessi aloittaa käyttöjärjestelmän vuorontajalta saamansa aikaikkunan käytön. C. kun prosessille on lähetetty odottelusignaali esim. näppäilemällä pääteyhteydessä Ctrl-Z. D. kun prosessori siirtyy keskeytyksen tai käyttöjärjestelmäkutsun käsittelyyn. Ohje tehtäviin 6 7: Yhdistä lauseen loppua vastaavat kirjaimet (vähintään yksi, mutta mahdollisesti useita) lauseenalun perään siten, että muodostuvat lauseet vastaavat todellisuutta. Vastauksessa on oltava listattuna kaikki todellisuutta vastaavat vaihtoehdot. Vaihtoehtoiset loput (mahdollisesti useita sopivia): 6. Laiteriippuva I/O -ohjelmisto A. voi tulla suoritukseen sovellusohjelman pyynnön seurauksena. 7. Laitteistoriippumaton I/O -ohjelmisto B. sisältää laiteohjainten ajurit. C. voi tulla suoritukseen prosessorin keskeytyksen seurauksena. D. määrittää järjestelmälle yhtenäisen lohkokoon. 8. Väite: Prosessin kaikilla säikeillä on aina sama sisältö jokaisessa prosessorin rekisterissä (esim. AMD64:n RIP:ssä ja RAX:ssä) Ohje tehtävään 9: Yhdistä lauseen loppua vastaavat kirjaimet (vähintään yksi, mutta mahdollisesti useita) lauseenalun perään siten, että muodostuvat lauseet vastaavat todellisuutta. Vastauksessa on oltava listattuna kaikki todellisuutta vastaavat vaihtoehdot. Lauseen alku: 9. Kurssilla käsitelty käyttöjärjestelmän Vaihtoehtoiset loput (mahdollisesti useita sopivia): A. kellokeskeytyksen tulee tapahtua 50, 100 tai 1000 kertaa sekunnissa rajapintastandardi POSIX (vuoden 2008 versio) määrää, että B. shell-komento c99 käynnistää C99-standardin mukaisen C- kääntäjän C. komento startx käynnistää X-ikkunointijärjestelmän D. Avustus (engl. Help) on valikkopalkin oikeanpuoleisin valikko Ohje tehtäviin 10 13: Yhdistä lauseen loppua vastaava kirjain numeroituun alkuun siten, että kukin lause on totta. Alkuihin on yksikäsitteinen oikea loppu. Jokainen loppu voi sopia useampaan alkuun tai ei yhteenkään. 10. Prosessitaulu A. liittyy useiden eri prosessien käsittelyyn. 11. Prosessielementti (PCB) B. on prosessikohtainen. 12. Sivutaulu C. ei välttämättä liity prosessien tarpeisiin. 13. Ready-jono 14. Väite: Tietokonejärjestelmän tuottavuutta (engl. throughput) eli aikayksikössä loppuun saatujen tehtävien määrää voidaan kasvattaa lisäämällä kellokeskeytyksien määrää aikayksikössä. sivu 2 (7)
3 Ohje tehtäviin 15 18: Yhdistä lauseen loppua vastaava kirjain numeroituun alkuun siten, että kukin lause on totta. Alkuihin on yksikäsitteinen oikea loppu. Jokainen loppu voi sopia useampaan alkuun tai ei yhteenkään. 15. Keskinäinen poissulku (engl. mutual exclusion, MutEx) B. liittyy tietokoneiden muistihierarkian perusideaan. A. on osa prosessorilaitteiston toimintaa. 16. FLIH (first-level interrupt handling) C. on tietoverkkoon liitetyn laitteen osoite. D. liittyy kilpa-ajotilanteiden (engl. race condition) ratkomiseen. 17. Semafori (semaphore) 18. IP-rekisteri (instruction pointer) Tutkittava esimerkki tehtäviin 19 20: Kurssin luennoilta ja demoista tutussa ympäristössä (Linux,bash) tehtyjä tuttuja komentoja ja niiden tulosteita (merkistökoodaus on UTF-8): tenttikys]$ whoami nieminen tenttikys]$ ls -l total 16 -rw-r--r--. 1 nieminen users May 17 22:34 kayttojarjestelmat.tex -rw-r--r--. 1 nieminen users 4 May 17 22:35 moi [nieminen@halava tenttikys]$ cat moi > kayttojarjestelmat.tex [nieminen@halava tenttikys]$ 19. Väite: komentojen jälkeen tiedoston kayttojarjestelmat.tex pituus on pienempi kuin tavua. 20. Väite: komentojen jälkeen annettava komento cat moi tulostaisi konsoliin tekstin "kayttojarjestelmat.tex"ja rivinvaihdon. Ohje tehtävään 21: Järjestä seuraavat muistikomponentit niiden nopeuden mukaan: A=kovalevy, B=keskusmuisti, C=välimuisti, D=rekisteri. 21. Vastauksessasi on neljä järjestettyä kirjainta: nopein ensin, hitain viimeisenä. 22. Väite: Päätavoite ohjelmistokerrosten ja niiden välisten rajapintojen määrittelyssä on estää kilpailijoita toteuttamasta tuotteita, jotka toimivat samalla tavoin kuin valmistajan oma tuote. Ohje tehtävään 23: Yhdistä lauseen loppua vastaavat kirjaimet (vähintään yksi, mutta mahdollisesti useita) lauseenalun perään siten, että muodostuvat lauseet vastaavat todellisuutta. Vastauksessa on oltava listattuna kaikki todellisuutta vastaavat vaihtoehdot. Lauseen alku: Vaihtoehtoiset loput (mahdollisesti useita sopivia): 23. Prosessorin keskeytys A. toimii vain moniydinprosessorissa. B. on yhtä nopea toimenpide kuin aliohjelmakutsuun siirtyminen (esim. AMD64:n käskyn call suorittaminen). C. voi aiheutua käyttäjätilassa toimivan prosessin toimenpiteiden johdosta. D. voidaan estää sovellusohjelmassa käyttämällä synkronointia. 24. Väite: Tyypillisen käyttöjärjestelmän lähdekoodin määrä on ollut laskusuhdanteessa 1970-luvulta alkaen, johtuen kyseisen vuosikymmenen merkittävistä keksinnöistä koodin rakenteeseen liittyen. sivu 3 (7)
4 Ohje tehtäviin 25 28: Yhdistä lauseen loppua vastaava kirjain numeroituun alkuun siten, että kukin lause on totta. Alkuihin on yksikäsitteinen oikea loppu. Jokainen loppu voi sopia useampaan alkuun tai ei yhteenkään. 25. I/O -ohjelmisto (engl. I/O subsystem) A. ei ole välttämätön osa nykyaikaista käyttöjärjestelmää. B. käsittelee sivukeskeytyksen (engl. page fault). 26. Käyttöjärjestelmän virtuaalimuistin C. toimittaa signaaleja (esim. apuohjelmalla kill lähetettyjä). hallintaosio (engl. virtual memory management) 27. IPC (engl. inter-process communication) D. määrittelee nimet/osoitteet koneeseen liitetyille laitteille. E. tarvitaan vain virtuaalikoneeseen asennetussa käyttöjärjestelmässä. F. tarvitaan bittioperaatioiden, kuten AND ja OR, hoitamiseksi. 28. Graafinen tiedostoselain (engl. file browser) 29. Väite: POSIXin semafori on binäärinen lippumuuttuja. 30. Väite: POSIXin semaforikutsun sem_post(s) suorituksessa semaforin s arvo muuttuu aina. Tutkittava esimerkki tehtäviin 31 33: Luentoesimerkeistä tuttua C-kielistä ohjelmanpätkää muistuttava koodi (POSIXin pthread-kirjastoa hyödyntävä; mahdollisesti rikottu jollain selkeällä tavalla tai sitten ei). Oletetaan tehtävässä, että kaikki kutsut aina onnistuvat, eikä mitään ulkopuolisia vaikutuksia ole: #define N 1000 pthread_mutex_t mymutex = PTHREAD_MUTEX_INITIALIZER; uint64_t summa = 0; void * saikeen_koodi(void *v) { int i; for (i = 1; i <= N; i++){ summa++; return NULL; int main(int argc, char *argv[]) { pthread_t saiea, saieb; pthread_create(&saiea, NULL, saikeen_koodi, NULL); pthread_create(&saieb, NULL, saikeen_koodi, NULL); pthread_join(saiea, NULL); pthread_join(saieb, NULL); if (summa==2000){ return 0; // homma toimi else { return 1; // homma ei toiminut 31. Väite: Esimerkin main() palauttaa aina 0:n, mikäli sen suoritus ylipäätään onnistuu loppuun saakka ilman esteitä ja kaikki sen sisältämät aliohjelmakutsut onnistuvat ilman virhekoodia. 32. Väite: Esimerkissä on periaatteessa mahdollista tilanne, jossa säikeessä A muuttuja i==123 ja säikeessä B muuttuja i==456 samaan aikaan. 33. Väite: Esimerkin ohjelma voi aiheuttaa lukkiutumistilanteen (engl. deadlock), jossa sen suoritus jää jumiin. 34. Väite: P.J. Denningin ym luvulla kehittelemä lokaalisuusperiaate (engl. principle of locality) on pohjana sille, että konekieliset aliohjelmat voivat kutsua itseään rekursiivisesti. sivu 4 (7)
5 Tutkittava esimerkki tehtäviin 35 36: C-mäisenä pseudokoodina tehty ehdotus rengaspuskuria käyttävän tuottaja-kuluttaja -ongelman ratkaisemiseksi POSIX-tyyppistä semaforipalvelua käyttäen. Yhteistä muistia käytetään puskurioperaatioissa. Semafori EMPTY mallintaa rengaspuskurin vapaata, kirjoitettavissa olevaa tilaa ja FULL mallintaa kirjoitettua mutta toistaiseksi käsittelemätöntä tilaa. tuottaja(){ while(true) { // tuotetaan loputtomiin tuota(); // tehdään yksi datapätkä sem_wait(empty); sem_wait(mutex); siirra_puskuriin(); sem_post(mutex); sem_post(empty); kuluttaja(){ while(true) { // kulutetaan loputtomiin sem_wait(full); sem_wait(mutex); lue_puskurista(); sem_post(mutex); sem_post(full); kuluta(); // käytetään yksi datapätkä main(){ EMPTY=tee_semafori( PUSKURIN_KOKO ); FULL=tee_semafori( 0 ); MUTEX=tee_semafori( 1 ); kaynnista_saie(tuottaja); kaynnista_saie(kuluttaja); 35. Väite: Semaforien alustus on oikeellinen ongelman ratkaisemiseksi. 36. Väite: Semaforien käyttö säikeissä on oikeellinen ongelman ratkaisemiseksi. Tutkittava esimerkki tehtäviin 37 39: luennolla ja monisteessa esitetyn kaltainen minimalistinen shellohjelma (kommentit poistettu, rivit numeroitu, näytetty vain olennainen toimintopätkä): 1 while(true){ 2 luekomento(komento, argumentit); 3 pid = fork(); 4 if (pid > 0) { 5 status = wait(); 6 else if (pid == -1) { 7 ilmoita("fork() epäonnistui!"); 8 exit(1); 9 else { 10 exec(komento, argumentit); 11 ilmoita("komentoa ei voitu suorittaa!"); 12 exit(1); Väite: Rivi 10 tapahtuu fork() -kutsun luomassa lapsiprosessissa. 38. Väite: Rivin 8 suorittaminen lopettaa koko minimalistisen shellin suorituksen. sivu 5 (7)
6 39. Väite: Rivin 12 suorittaminen lopettaa koko minimalistisen shellin suorituksen. Tutkittava esimerkki tehtäviin 40 43: Kuvitellaan, että meillä on käytössä yksinkertainen tietokone, jonka virtuaalimuistiosoitteissa on 20 bittiä, joista ensimmäiset 8 ilmoittavat sivunumeron ja loput 12 ilmoittavat tavuindeksin sivun sisällä. Fyysiset muistiosoitteet ovat 24-bittisiä. Keskusmuistista on varattu prosessien käyttöön tasan 8 kehystä fyysistä muistia osoitteissa 0x x107fff. Virtuaalimuistin kokonaiskoko on 0x tavua (n. 16 megatavua). Tietorakenteiden tilanne tarkasteluhetkellä on seuraava. Prosessien sivutauluista näytetään vain kartoitetut osat kahden prosessin (PID:t 2 ja 7) osalta. Prosessin (PID=2) sivutaulun kartoitetut rivit: virt. fyys. muist. dirty diskindex sivu sivu (P) (D) 0x02 0x x0010 0x03 0x x0022 0x2e 0x x00bb 0x7f 0x x00bc Prosessin (PID=7) sivutaulun kartoitetut rivit: virt. fyys. muist. dirty diskindex sivu sivu (P) (D) 0x02 0x x0004 0x03 0x x0008 0x04 0x x00f2 0x2e 0x x006c 0x7f 0x x0007 Järjestelmän kehystaulu: fyys. omistajan omistajan aikayksiköt edellisen sivu PID PTE# käyttökerran jälkeen x x x x7f 150 0x x x x45 8 0x x2e 12 0x x45 4 0x x2e 175 0x x7f Mihin fyysiseen muistiosoitteeseen kohdistuisi prosessin 7 tekemä kirjoitus virtuaalimuistiosoitteeseen 0x7f123? 41. Mistä virtuaaliosoitteesta prosessi 7 saisi käyttöönsä tavun, joka sijaitsee kovalevyllä indeksissä 0xf2345 heittovaihto-osion / -tiedoston (engl. swap space) alusta lukien? 42. Prosessi 2 suorittaa hyppykäskyn aliohjelmaan muistiosoitteessa 0x2e07f. Tapahtuuko prosessorissa sivuvirhe / sivunvaihtokeskeytys? 43. Prosessissa 876 aiheutuu sivunvaihtokeskeytys. Korvausalgoritmi on LRU. Onko jonkin sivun sisältö tallennettava levylle? sivu 6 (7)
7 Tutkittava esimerkki tehtäviin 44 46: Kurssin luennoilta tutulla symbolisella konekielellä (GNU assembler; AT&T -syntaksi) kirjoitettu, rivi riviltä kommentoitu ohjelmanpätkä: _start: movq $3,%rcx # luku 3 rekisteriin RCX movq $6,%rdi # luku 6 rekisteriin RDI silimu: inc %rdi # lisää 1 rekisterin RDI arvoon dec %rcx # vähennä 1 rekisterin RCX arvosta jz ulos # hyppää, jos edellisen käskyn tulos oli 0 jmp silimu # hyppää aina ulos: dec %rdi # vähennä 1 rekisterin RDI arvosta 44. Kuinka monta konekielikäskyä ohjelmanpätkän jälki sisältää, ts. kuinka monta käskyä sen suorittaminen alusta loppuun vaatii? 45. Mikä on rekisterin RCX sisältö ohjelmanpätkän suorituksen lopuksi? 46. Mikä on rekisterin RDI sisältö ohjelmanpätkän suorituksen lopuksi? Tutkittava esimerkki tehtäviin 47 48: Kurssin esimerkeistä tuttua Linuxille käännettyä C-ohjelmaa ajetaan x arkkitehtuurilla, ja debuggerilla on nähtävissä seuraavat hetkelliset tiedot Rekistereitä: RIP (käsky) 0x RSP (huippu) 0x00007fffffffdcc0 RBP (kanta) 0x00007fffffffdcf0 Muistin sisältöä (kaikki muuttujat 64-bittisiä eli 8-tavuisia): 0x7fffffffdd08: 0x x7fffffffdd00: 0x00007fffffffde38 0x7fffffffdcf8: 0x kanta --> 0x7fffffffdcf0: 0x00007fffffffdd50 0x7fffffffdce8: 0x x7fffffffdce0: 0x x7fffffffdcd8: 0x x7fffffffdcd0: 0x x7fffffffdcc8: 0x huippu --> 0x7fffffffdcc0: 0x Kuinka monta tavua muistia on varattu nykyisen aktivaation väliaikaisten muuttujien (eli. lokaalit muuttujat ja tarvittavat paikalliset kopiot parametreista) säilyttämistä varten? Ilmoita kymmenjärjestelmän lukuna. 48. Mikä tulee olemaan RIP-rekisterin sisältö siinä vaiheessa, kun tämä meneillään oleva aliohjelmaaktivaatio on jossain vaiheessa loppunut ja siihen sisältyvä käsky ret on viimeisimpänä suoritettu. Vapaaehtoinen vapaa sana Halutessasi voit antaa loppuun palautetta tai kommentoida muuten kurssia tai tenttiä. Vastauksen muoto on vapaa, eikä se vaikuta arvosteluun. sivu 7 (7)
Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 20.5.2016 Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja
Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti tentti 12.6.2015 Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi
Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 19.8.2016 Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja
Kevään 2018 kurssin luennot, demot, esimerkkiohjelmat (yhteensopiva kevään 2017 kurssin kanssa) / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 6.7.2018 Kevään 2018 kurssin luennot, demot, esimerkkiohjelmat (yhteensopiva kevään 2017 kurssin kanssa) / Paavo Nieminen Yleisiä ohjeita: Muista
Kevään 2018 kurssin luennot, demot, esimerkkiohjelmat (yhteensopiva kevään 2017 kurssin kanssa) / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 17.8.2018 Kevään 2018 kurssin luennot, demot, esimerkkiohjelmat (yhteensopiva kevään 2017 kurssin kanssa) / Paavo Nieminen Yleisiä ohjeita: Muista
Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 10.7.2015 Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja
Kevään 2018 kurssin luennot, demot, esimerkkiohjelmat (yhteensopiva kevään 2017 kurssin kanssa) / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 16.5.2018 Kevään 2018 kurssin luennot, demot, esimerkkiohjelmat (yhteensopiva kevään 2017 kurssin kanssa) / Paavo Nieminen Yleisiä ohjeita: Muista
Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 18.8.2017 Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja
Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 20.5.2015 Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista vastauspaperiin oma nimi, syntymäaika
Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 7.7.2017 Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja
ITKA203 Käyttöjärjestelmät tentti (MALLITENTTI 2017)
ITKA203 Käyttöjärjestelmät tentti 13.5.2017 (MALLITENTTI 2017) Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Tentin ja kurssin arvosteluperusteet 2017:
Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti 19.5.2017 Kevään 2017 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista merkitä vastauspaperiin oma nimesi ja
Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen
ITKA203 Käyttöjärjestelmät tentti MALLITENTTI Kevään 2015 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Yleisiä ohjeita: Muista vastauspaperiin oma nimi, syntymäaika
ITKA203 Käyttöjärjestelmät tentti 2016 (MALLITENTTI)
ITKA203 Käyttöjärjestelmät tentti 2016 (MALLITENTTI) Kevään 2016 kurssin luennot, demot, esimerkkiohjelmat / Paavo Nieminen Tentin ja kurssin arvosteluperusteet 2016: Tentissä
2 Konekieli, aliohjelmat, keskeytykset
ITK145 Käyttöjärjestelmät, kesä 2005 Tenttitärppejä Tässä on lueteltu suurin piirtein kaikki vuosina 2003-2005 kurssin tenteissä kysytyt kysymykset, ja mukana on myös muutama uusi. Jokaisessa kysymyksessä
ITKA203 Käyttöjärjestelmät -- kesä tenttitärpit
ITKA203 Käyttöjärjestelmät -- kesä 2011 -- tenttitärpit Yleistä tenttitärpeistä Jokaisessa kysymyksessä on pistemäärä, jonka arvoiseksi se laajuudeltaan katsotaan. Jokaiseen tenttikertaan tulen valitsemaan
Tenttitärpit. HUOM: Luvataan, että tämä on lopullinen tenttitärppikokoelma, mutta varaan silti oikeuden tehdä pieniä muutoksia, erityisesti:
ITKA203 Käyttöjärjestelmät, kesä 2007 Tenttitärpit Tässä on suurin piirtein kaikki vuodesta 2003 alkaen kurssin tenteissä koskaan kysytyt kysymykset, ja mukana on myös muutama uusi. Jos osaat vastata jokaiseen,
IT K 1 45 K ä yt t öj ä rj estelmät
IT K 1 45 K ä yt t öj ä rj estelmät Tenttikysymyksiä ja vastauksia Aliohjelman suoritusperiaate, ts. selvitä pinon käyttö ja paluuarvon välittäminen (3p) 1. Ennen aliohjelman aloittamista kutsuja tallettaa
ITKA203 Käyttöjärjestelmät -- tentin yleiskuva -- kevät 2015
ITKA203 Käyttöjärjestelmät -- tentin yleiskuva -- kevät 2015 Tentin ja kurssin pisteytys Tentin muoto on tänä vuonna uusittu täysin, painottaen kysymyksiä, joiden oikeat vastaukset ovat yksiselitteisiä
TIEP114 Tietokoneen rakenne ja arkkitehtuuri, 3 op. Assembly ja konekieli
TIEP114 Tietokoneen rakenne ja arkkitehtuuri, 3 op Assembly ja konekieli Tietokoneen ja ohjelmiston rakenne Loogisilla piireillä ja komponenteilla rakennetaan prosessori ja muistit Prosessorin rakenne
TIEP114 Tietokoneen rakenne ja arkkitehtuuri, 3 op. Assembly ja konekieli
TIEP114 Tietokoneen rakenne ja arkkitehtuuri, 3 op Assembly ja konekieli Tietokoneen ja ohjelmiston rakenne Loogisilla piireillä ja komponenteilla rakennetaan prosessori ja muistit Prosessorin rakenne
ITKP102 Ohjelmointi 1 (6 op)
ITKP102 Ohjelmointi 1 (6 op) Tentaattori: Antti-Jussi Lakanen 12. huhtikuuta 2019 Tee kukin tehtävä omalle konseptiarkille. Noudata ohjelmointitehtävissä kurssin koodauskäytänteitä. Yksi A4-kokoinen lunttilappu
Käyttöjärjestelmät: prosessit
Käyttöjärjestelmät: prosessit Teemu Saarelainen Tietotekniikka teemu.saarelainen@kyamk.fi Lähteet Stallings, W. Operating Systems Haikala, Järvinen, Käyttöjärjestelmät Eri Web-lähteet Käyttöjärjestelmä
4. Luento: Prosessit ja säikeets. Tommi Mikkonen, tommi.mikkonen@tut.fi
4. Luento: Prosessit ja säikeets Tommi Mikkonen, tommi.mikkonen@tut.fi Agenda Prosessi Säikeet Keskeytykset Keskeytyskäsittely Käyttöjärjestelmäkutsut Prosessielementti Prosessin hallinta Suunnittelunäkökohtia
11/20: Konepelti auki
Ohjelmointi 1 / syksy 2007 11/20: Konepelti auki Paavo Nieminen nieminen@jyu.fi Tietotekniikan laitos Informaatioteknologian tiedekunta Jyväskylän yliopisto Ohjelmointi 1 / syksy 2007 p.1/11 Tämän luennon
Arto Salminen,
4. Luento: Prosessit ja säikeet Arto Salminen, arto.salminen@tut.fi Agenda Prosessi Säikeet Keskeytykset Keskeytyskäsittely Käyttöjärjestelmäkutsut Prosessielementti Prosessin hallinta Suunnittelunäkökohtia
IDL - proseduurit. ATK tähtitieteessä. IDL - proseduurit
IDL - proseduurit 25. huhtikuuta 2017 Viimeksi käsiteltiin IDL:n interaktiivista käyttöä, mutta tämä on hyvin kömpelöä monimutkaisempia asioita tehtäessä. IDL:llä on mahdollista tehdä ns. proseduuri-tiedostoja,
ATK tähtitieteessä. Osa 3 - IDL proseduurit ja rakenteet. 18. syyskuuta 2014
18. syyskuuta 2014 IDL - proseduurit Viimeksi käsiteltiin IDL:n interaktiivista käyttöä, mutta tämä on hyvin kömpelöä monimutkaisempia asioita tehtäessä. IDL:llä on mahdollista tehdä ns. proseduuri-tiedostoja,
Ohjelmointi 1 / 2009 syksy Tentti / 18.12
Tentti / 18.12 Vastaa yhteensä neljään tehtävään (huomaa että tehtävissä voi olla useita alakohtia), joista yksi on tehtävä 5. Voit siis valita kolme tehtävistä 1 4 ja tehtävä 5 on pakollinen. Vastaa JOKAISEN
ITKP102 Ohjelmointi 1 (6 op)
ITKP102 Ohjelmointi 1 (6 op) Tentaattori: Antti-Jussi Lakanen 20. huhtikuuta 2018 Vastaa kaikkiin tehtäviin. Tee kukin tehtävä omalle konseptiarkille. Noudata ohjelmointitehtävissä kurssin koodauskäytänteitä.
Käyttöjärjestelmät: poissulkeminen ja synkronointi
Käyttöjärjestelmät: poissulkeminen ja synkronointi Teemu Saarelainen Tietotekniikka teemu.saarelainen@kyamk.fi Lähteet Stallings, W. Operating Systems Haikala, Järvinen, Käyttöjärjestelmät Eri Web-lähteet
Prosessi perinteisesti
Käyttöjärjestelmät t I Luento 11: SÄIKEETS Stallings, Luku 4.1 Sisält ltöä Prosessi vs. säie Miksi säikeitä? ULT: Käyttäjätason säikeet KLT: Säikeiden toteutus ytimessä Säikeen tilat Käyttöjärjestelmän
Ongelma(t): Miten tietokoneen käyttöjärjestelmä toimii sisäisesti, jotta resurssit saadaan tehokkaaseen käyttöön?
Ongelma(t): Miten tietokoneen käyttöjärjestelmä toimii sisäisesti, jotta resurssit saadaan tehokkaaseen käyttöön? 2013-2014 Lasse Lensu 2 Systeemiohjelmat ovat tietokoneen laitteistoa lähellä olevia ohjelmia,
815338A Ohjelmointikielten periaatteet Harjoitus 2 vastaukset
815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 2 vastaukset Harjoituksen aiheena on BNF-merkinnän käyttö ja yhteys rekursiivisesti etenevään jäsentäjään. Tehtävä 1. Mitkä ilmaukset seuraava
Stallings, Luku 4.1. KJ-I I S2005 / Tiina Niklander, kalvot Auvo HäkkinenH
Käyttöjärjestelmät t I Luento 11: SÄIKEETS Stallings, Luku 4.1 KJ-I S2005 / Tiina Niklander, kalvot Auvo Häkkinen 11-1 Sisält ltöä Prosessi vs. säie Miksi säikeitä? ULT: Käyttäjätason säikeet KLT: Säikeiden
ITKP102 Ohjelmointi 1 (6 op)
ITKP102 Ohjelmointi 1 (6 op) Tentaattori: Antti-Jussi Lakanen 7. huhtikuuta 2017 Vastaa kaikkiin tehtäviin. Tee jokainen tehtävä erilliselle konseptiarkille. Kirjoittamasi luokat, funktiot ja aliohjelmat
ITKA203 Käyttöjärjestelmät -- tenttitärpit -- kevät 2014
ITKA203 Käyttöjärjestelmät -- tenttitärpit -- kevät 2014 Yleistä tentistä ja tärpeistä Jokaisessa kysymyksessä on pistemäärä, jonka arvoiseksi se laajuudeltaan katsotaan. Jokaiseen tenttikertaan tullaan
Tietojenkäsittelyn perusteet 2. Lisää käyttöjärjestelmistä
Tietojenkäsittelyn perusteet 2 Lisää käyttöjärjestelmistä 2011-02-09 Leena Ikonen 1 Systeemiohjelmat Systeemiohjelmiin kuuluvat Kääntäjät ja tulkit (+debuggerit) Käyttöjärjestelmä Linkittäjät Lataajat
Luento 2. Timo Savola. 31. maaliskuuta 2006
UNIX-käyttöjärjestelmä Luento 2 Timo Savola 31. maaliskuuta 2006 Osa I Prosessit Prosessien hierarkia Jokaisella prosessilla on numero (process ID, pid) Jokaisella prosessilla on
ITKP102 Ohjelmointi 1 (6 op)
ITKP102 Ohjelmointi 1 (6 op) Tentaattori: Antti-Jussi Lakanen 22. huhtikuuta 2016 Vastaa kaikkiin tehtäviin. Tee jokainen tehtävä erilliselle konseptiarkille! Kirjoittamasi luokat, funktiot ja aliohjelmat
815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 5 Vastaukset
815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 5 Vastaukset Harjoituksen aiheena ovat aliohjelmat ja abstraktit tietotyypit sekä olio-ohjelmointi. Tehtävät tehdään C-, C++- ja Java-kielillä.
5. HelloWorld-ohjelma 5.1
5. HelloWorld-ohjelma 5.1 Sisällys Lähdekoodi. Lähdekoodin (osittainen) analyysi. Lähdekoodi tekstitiedostoon. Lähdekoodin kääntäminen tavukoodiksi. Tavukoodin suorittaminen. Virheiden korjaaminen 5.2
Hellä ensikosketus. Tomi Kiviniemi
Hellä ensikosketus Tomi Kiviniemi Asialista Vähän debuggauksen filosofiaa. GDB:n peruskäyttö Netbeansissä. GDB:n peruskäyttö komentoriviympäristössä. Hieman edistyneempää sähellystä komentoriviympäristössä.
PRINCIPLES OF PROGRAMMING LANGUAGES - DEBUGGER
PRINCIPLES OF PROGRAMMING LANGUAGES - DEBUGGER Group 16 Ville Laatu Henri Myllyoja - i SISÄLLYSLUETTELO 1. DEBUGGERI YLEISESTI... II 1.1 Debuggerin käyttämien... ii 1.2 Debuggerin käynnistäminen... ii
Stallings, Luku 4.1. KJ-I S2004 / Tiina Niklander, kalvot Auvo Häkkinen 4-1. KJ-I I S2004 / Tiina Niklander, kalvot Auvo Häkkinen 12-1
"! $# Stallings, Luku 4.1 KJ-I S2004 / Tiina Niklander, kalvot Auvo Häkkinen 4-1 %& ()* +,.-0/212321416587912: 12;?5A@ 165 12;
Palvelut. Sulautetut järjestelmät Luku 2 Sivu 1 (??) Sulautetut käyttöjärjestelmät
Sulautetut järjestelmät Luku 2 Sivu 1 (??) Palvelut Käyttöjärjestelmän tehtävänä on tarjota ohjelmoijalla erilaisia palveluita Tyypillisin palvelu, jota sulautetut käyttöjärjestelmät tarjoavat on prosessien
4. Lausekielinen ohjelmointi 4.1
4. Lausekielinen ohjelmointi 4.1 Sisällys Konekieli, symbolinen konekieli ja lausekieli. Lausekielestä konekieleksi: - Lähdekoodi, tekstitiedosto ja tekstieditorit. - Kääntäminen ja tulkinta. - Kääntäminen,
Jakso 12 Yhteenveto. Keskeiset asiat Teemu Kerola, K2000
Jakso 12 Yhteenveto Keskeiset asiat 1 Tavoitteet (4) Ymmärtää tietokonejärjestelmän keskeiset piirteet sillä suoritettavan ohjelman näkökulmasta Miten tietokonejärjestelmä suorittaa sille annettua ohjelmaa?
Tietokoneen toiminta, K Tavoitteet (4)
Jakso 12 Yhteenveto Keskeiset asiat 1 Tavoitteet (4) Ymmärtää tietokonejärjestelmän keskeiset piirteet sillä suoritettavan ohjelman näkökulmasta Miten tietokonejärjestelmä suorittaa sille annettua ohjelmaa?
Luento 4. Timo Savola. 21. huhtikuuta 2006
UNIX-käyttöjärjestelmä Luento 4 Timo Savola 21. huhtikuuta 2006 Osa I Shell Lausekkeet Komentoriville kirjotettu komento on lauseke echo "foo" echo $USER MUUTTUJA=1 ls -l Rivinvaihto
TAMPEREEN TEKNILLINEN YLIOPISTO Digitaali- ja tietokonetekniikan laitos. Harjoitustyö 4: Cache, osa 2
TAMPEREEN TEKNILLINEN YLIOPISTO Digitaali- ja tietokonetekniikan laitos TKT-3200 Tietokonetekniikka I Harjoitustyö 4: Cache, osa 2.. 2010 Ryhmä Nimi Op.num. 1 Valmistautuminen Cache-työn toisessa osassa
Operaattoreiden ylikuormitus. Operaattoreiden kuormitus. Operaattoreiden kuormitus. Operaattoreista. Kuormituksesta
C++ - perusteet Java-osaajille luento 5/7: operaattoreiden ylikuormitus, oliotaulukko, parametrien oletusarvot, komentoriviparametrit, constant, inline, Operaattoreiden ylikuormitus Operaattoreiden kuormitus
Käyttöjärjestelmän rakenne
Käyttöjärjestelmän rakenne Tietokonejärjestelmä = Laitteisto + ohjelmisto Sovellus saa laitteiston käyttöönsä kj:n avustuksella CPU ja muisti Oheislaitteet KJ tarjoaa laitteiston käytössä tarvittavat palvelunsa
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 2.3.2011 T-106.1208 Ohjelmoinnin perusteet Y 2.3.2011 1 / 39 Kertausta: tiedoston avaaminen Kun ohjelma haluaa lukea tai kirjoittaa tekstitiedostoon, on ohjelmalle
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 2.3.2009 T-106.1208 Ohjelmoinnin perusteet Y 2.3.2009 1 / 28 Puhelinluettelo, koodi def lue_puhelinnumerot(): print "Anna lisattavat nimet ja numerot." print
Metropolia Ammattikorkeakoulu
Metropolia Ammattikorkeakoulu UNIX-käyttöjärjestelmä TX00BW20 Sami Sainio sami.sainio@metropolia.fi Kurssin rakenne ja arvostelu 7 x luennot ja laboratorioharjoitukset Pieni projekti? Kurssin lopussa tentti
Luento 1 Tietokonejärjestelmän rakenne
Luento 1 Tietokonejärjestelmän rakenne Järjestelmän eri tasot Laitteiston nopeus 1 Tietokonejärjestelmä Käyttäjä Tietokonelaitteisto Oheislaitteet (peripheral or I/O devices) Tietokone (computer) 2 Luento
Luento 1 Tietokonejärjestelmän rakenne
Luento 1 Tietokonejärjestelmän rakenne Järjestelmän eri tasot Laitteiston nopeus 1 Tietokonejärjestelmä Käyttäjä Tietokonelaitteisto Oheislaitteet (peripheral or I/O devices) Tietokone (computer) 2 Tietokone
Luento 1 Tietokonejärjestelmän rakenne. Järjestelmän eri tasot Laitteiston nopeus
Luento 1 Tietokonejärjestelmän rakenne Järjestelmän eri tasot Laitteiston nopeus 1 Tietokonejärjestelmä Käyttäjä Tietokonelaitteisto Oheislaitteet (peripheral or I/O devices) Tietokone (computer) 2 Tietokone
Luento 1 Tietokonejärjestelmän rakenne. Järjestelmän eri tasot Laitteiston nopeus
Luento 1 Tietokonejärjestelmän rakenne Järjestelmän eri tasot Laitteiston nopeus 1 Tietokonejärjestelmä Käyttäjä Tietokonelaitteisto Oheislaitteet (peripheral or I/O devices) Tietokone (computer) 2 Tietokone
Luento 1 (verkkoluento 1) Tietokonejärjestelmä
Luento 1 (verkkoluento 1) Tietokonejärjestelmä Järjestelmän eri tasot Ohjelman sijainti Ohjelman esitysmuoto Laitteiston nopeus 1 Tietokonejärjestelmä Käyttäjä This image cannot currently be displayed.
Taulukot. Jukka Harju, Jukka Juslin 2006 1
Taulukot Jukka Harju, Jukka Juslin 2006 1 Taulukot Taulukot ovat olioita, jotka auttavat organisoimaan suuria määriä tietoa. Käsittelylistalla on: Taulukon tekeminen ja käyttö Rajojen tarkastus ja kapasiteetti
Ohjelmassa muuttujalla on nimi ja arvo. Kääntäjä ja linkkeri varaavat muistilohkon, jonne muuttujan arvo talletetaan.
Osoittimet Ohjelmassa muuttujalla on nimi ja arvo. Kääntäjä ja linkkeri varaavat muistilohkon, jonne muuttujan arvo talletetaan. Muistilohkon koko riippuu muuttujan tyypistä, eli kuinka suuria arvoja muuttujan
Liite 1. Projektin tulokset (Semaforit Javassa) Jukka Hyvärinen Aleksanteri Aaltonen
Helsingin Yliopisto, tietojenkäsittelytieteen laitos Rinnakkaisohjelmointi (syksy 2006) Liite 1. Projektin tulokset (Semaforit Javassa) Jukka Hyvärinen Aleksanteri Aaltonen a. Käyttötarkoitus ja sovellusalue
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 1.4.2009 T-106.1208 Ohjelmoinnin perusteet Y 1.4.2009 1 / 56 Tentti Ensimmäinen tenttimahdollisuus on pe 8.5. klo 13:00 17:00 päärakennuksessa. Tämän jälkeen
815338A Ohjelmointikielten periaatteet Harjoitus 3 vastaukset
815338A Ohjelmointikielten periaatteet 2015-2016. Harjoitus 3 vastaukset Harjoituksen aiheena ovat imperatiivisten kielten muuttujiin liittyvät kysymykset. Tehtävä 1. Määritä muuttujien max_num, lista,
ltö Luento 6: VIRTUAALIMUISTI Luento 7: Segmentointi Segmentointi ja sivutus yhdistettynä Yhteiskäytöstä Suoritus virtuaalimuistissa
Käyttöjärjestelmät t I Luento 6: VIRTUAALIMUISTI Stallings, Luku 8.1 Sisält ltö Ohjelman suoritus virtuaalimuistissa Sivutus Osoitemuunnospuskuri TLB Lisää sivutauluista Luento 7: Segmentointi Segmentointi
Pikaintro käyttöjärjestelmiin
Tietotekniikan laitos Jyväskylän yliopisto TIES406 Tietotekniikan opintojen aktivointi, luento 17.8.2011 Outline Tietokonelaitteisto 1 Tietokonelaitteisto 2 3 4 Outline Tietokonelaitteisto 1 Tietokonelaitteisto
TAMPEREEN TEKNILLINEN YLIOPISTO
TAMPEREEN TEKNILLINEN YLIOPISTO Digitaali- ja Tietokonetekniikan laitos TKT-3200 Tietokonetekniikka ASSEMBLER: QSORT 06.09.2005 Ryhmä 00 nimi1 email1 opnro1 nimi2 email2 opnro2 nimi3 email3 opnro3 1. TEHTÄVÄ
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 28.2.2011 T-106.1208 Ohjelmoinnin perusteet Y 28.2.2011 1 / 46 Ohjelmointiprojektin vaiheet 1. Määrittely 2. Ohjelman suunnittelu (ohjelman rakenne ja ohjelman
5/20: Algoritmirakenteita III
Ohjelmointi 1 / syksy 2007 5/20: Algoritmirakenteita III Paavo Nieminen nieminen@jyu.fi Tietotekniikan laitos Informaatioteknologian tiedekunta Jyväskylän yliopisto Ohjelmointi 1 / syksy 2007 p.1/17 Tämän
Luento 1 (verkkoluento 1) Ohjelman sijainti Ohjelman esitysmuoto Laitteiston nopeus
Luento 1 (verkkoluento 1) Tietokonejärjestelmä Järjestelmän e eri tasot Ohjelman sijainti Ohjelman esitysmuoto Laitteiston nopeus 1 Tietokone- järjestelmäj ä Käyttäjä Tietokonelaitteisto Oheislaitteet
Luento 3. Timo Savola. 7. huhtikuuta 2006
UNIX-käyttöjärjestelmä Luento 3 Timo Savola 7. huhtikuuta 2006 Osa I Käyttöoikeudet Käyttöoikeudet Monen käyttäjän järjestelmä Prosessit kuuluvat eri käyttäjille Tiedostot kuuluvat
Luento 6: VIRTUAALIMUISTI
Käyttöjärjestelmät t I Luento 6: VIRTUAALIMUISTI Stallings, Luku 8.1 KJ-I S2005 / Tiina Niklander; kalvot Auvo Häkkinen 6-1 Sisält ltö Ohjelman suoritus virtuaalimuistissa Sivutus Osoitemuunnospuskuri
Concurrency - Rinnakkaisuus. Group: 9 Joni Laine Juho Vähätalo
Concurrency - Rinnakkaisuus Group: 9 Joni Laine Juho Vähätalo Sisällysluettelo 1. Johdanto... 3 2. C++ thread... 4 3. Python multiprocessing... 6 4. Java ExecutorService... 8 5. Yhteenveto... 9 6. Lähteet...
Ohjelmointi 2 / 2010 Välikoe / 26.3
Ohjelmointi 2 / 2010 Välikoe / 26.3 Välikoe / 26.3 Vastaa neljään (4) tehtävään ja halutessa bonustehtäviin B1 ja/tai B2, (tuovat lisäpisteitä). Bonustehtävät saa tehdä vaikkei olisi tehnyt siihen tehtävään
Ohjelmointi 1 / syksy /20: IDE
Ohjelmointi 1 / syksy 2007 10/20: IDE Paavo Nieminen nieminen@jyu.fi Tietotekniikan laitos Informaatioteknologian tiedekunta Jyväskylän yliopisto Ohjelmointi 1 / syksy 2007 p.1/8 Tämän luennon rakenne
Jakso 4 Aliohjelmien toteutus
Jakso 4 Aliohjelmien toteutus Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio 1 Aliohjelmatyypit (2) Korkean tason ohjelmointikielen käsitteet: aliohjelma, proseduuri parametrit funktio parametrit,
Ohjelmointiharjoituksia Arduino-ympäristössä
Ohjelmointiharjoituksia Arduino-ympäristössä Yleistä Arduino-sovelluksen rakenne Syntaksi ja käytännöt Esimerkki ohjelman rakenteesta Muuttujat ja tietotyypit Tietotyypit Esimerkkejä tietotyypeistä Ehtolauseet
Luentomuistiinpanoja
Luentomuistiinpanoja Tässä on luennolla käsiteltyjä asioita, jotka eivät ole muissa materiaaleissa ainakaan aivan samoilla sanoilla esitettynä. Osa lienee vähintään yhtä hyvin varsinaisessa luentomonisteessa.
4. Lausekielinen ohjelmointi 4.1
4. Lausekielinen ohjelmointi 4.1 Sisällys Konekieli, symbolinen konekieli ja lausekieli. Hyvä ohjelmointitapa. Lausekielestä konekieleksi: - Lähdekoodi, tekstitiedosto ja tekstieditorit. - Kääntäminen
Aliohjelmatyypit (2) Jakso 4 Aliohjelmien toteutus
Jakso 4 Aliohjelmien toteutus Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio Aliohjelmatyypit (2) Korkean tason ohjelmointikielen käsitteet: aliohjelma, proseduuri parametrit funktio parametrit,
Eloisuusanalyysi. TIE448 Kääntäjätekniikka, syksy Antti-Juhani Kaijanaho. 16. marraskuuta 2009 TIETOTEKNIIKAN LAITOS. Eloisuusanalyysi.
TIE448 Kääntäjätekniikka, syksy 2009 Antti-Juhani Kaijanaho TIETOTEKNIIKAN LAITOS 16. marraskuuta 2009 Sisällys Sisällys Seuraava deadline Vaihe E tiistai 1.12. klo 10 koodigenerointi (ilman rekisteriallokaatiota)
Suoritin. Jakso 5 Suoritin ja väylä. TTK-91 muistin rakenne. TTK-91 suorittimen rakenne
Jakso 5 Suoritin ja Suorittimen rakenne Väylän rakenne Käskyjen suoritussykli Poikkeukset ja keskeytykset Suoritin suoritin - CPU ALU rekisterit CU MMU Välimuisti (cache) muisti (kirjastorutiinit) ohjelma
Luento 4 Aliohjelmien toteutus
Luento 4 Aliohjelmien toteutus Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio 1 Aliohjelmatyypit (2) Korkean tason ohjelmointikielen käsitteet: aliohjelma, proseduuri parametrit funktio parametrit,
Java-kielen perusteet
Java-kielen perusteet Tunnus, varattu sana, kommentti Muuttuja, alkeistietotyyppi, merkkijono, literaalivakio, nimetty vakio Tiedon merkkipohjainen tulostaminen 1 Tunnus Java tunnus Java-kirjain Java-numero
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 2.2.2011 T-106.1208 Ohjelmoinnin perusteet Y 2.2.2011 1 / 37 Kännykkäpalautetteen antajia kaivataan edelleen! Ilmoittaudu mukaan lähettämällä ilmainen tekstiviesti
Ohjelmoinnin peruskurssien laaja oppimäärä
Ohjelmoinnin peruskurssien laaja oppimäärä Luento 11: Rinnakkaisuus Riku Saikkonen (osa kalvoista on suoraan ei-laajan kurssin luennoista) 25. 4. 2012 Sisältö 1 Rinnakkaisuusmalleja: säie ja prosessi 2
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 20.1.2010 T-106.1208 Ohjelmoinnin perusteet Y 20.1.2010 1 / 40 Arvon pyytäminen käyttäjältä Käyttäjän antaman arvon voi lukea raw_input-käskyllä. Käskyn sulkujen
Sisältöä SÄIKEET, SMP
LUENTO 5 Sisältöä SÄIKEET, SMP Stallings, Luku 4 Prosessi vs. säie Miksi säikeitä? ULT: Käyttäjätason säikeet KLT: Säikeiden toteutus ytimessä SMP Windowsin säikeet 1 2 Säikeet (multithreading) Prosessi
Suoritin. Luento 5 Suoritin ja väylä. TTK-91 muistin rakenne. TTK-91 suorittimen rakenne
Luento 5 Suoritin ja Suorittimen rakenne Väylän rakenne Käskyjen suoritussykli Poikkeukset ja keskeytykset KOKSI:n rakenne Suoritin suoritin - CPU ALU rekisterit CU MMU Välimuisti (cache) muisti (kirjastorutiinit)
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 2.2.2009 T-106.1208 Ohjelmoinnin perusteet Y 2.2.2009 1 / 43 Funktiot Tähän asti esitetyt ohjelmat ovat oleet hyvin lyhyitä. Todellisessa elämässä tarvitaan kuitenkin
TIE448 Kääntäjätekniikka, syksy Antti-Juhani Kaijanaho. 17. marraskuuta 2009
TIE448 Kääntäjätekniikka, syksy 2009 Antti-Juhani Kaijanaho TIETOTEKNIIKAN LAITOS 17. marraskuuta 2009 Sisällys Sisällys Seuraava deadline Vaihe E tiistai 1.12. klo 10 koodigenerointi (ilman ta) Vaihe
Luento 5 (verkkoluento 5) Suoritin ja väylä
Luento 5 (verkkoluento 5) Suoritin ja väylä Käskyjen suoritussykli Suorittimen tilat Poikkeukset ja keskeytykset 1 Suorituksenaikainen suorittimen ja muistin sisältö muisti suoritin konekäskyjen suorituspiirit,
12. Javan toistorakenteet 12.1
12. Javan toistorakenteet 12.1 Sisällys Yleistä toistorakenteista. Laskurimuuttujat. While-, do-while- ja for-lauseet. Laskuri- ja lippumuuttujat. Tyypillisiä ohjelmointivirheitä. Silmukan rajat asetettu
Jakso 4 Aliohjelmien toteutus
Jakso 4 Aliohjelmien toteutus Tyypit Parametrit Aktivointitietue (AT) AT-pino Rekursio 1 Aliohjelmatyypit (2) Korkean tason ohjelmointikielen käsitteet: aliohjelma, proseduuri parametrit funktio parametrit,
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 31.1.2011 T-106.1208 Ohjelmoinnin perusteet Y 31.1.2011 1 / 41 Luentopalaute kännykällä käynnissä! Ilmoittaudu mukaan lähettämällä ilmainen tekstiviesti Vast
Jakso 5 Suoritin ja väylä
Jakso 5 Suoritin ja väylä Suorittimen rakenne Väylän rakenne Käskyjen suoritussykli Poikkeukset ja keskeytykset TTK-91:n ja KOKSI:n rakenne 1 Suoritin muisti suoritin - CPU ALU CU rekisterit MMU (kirjastorutiinit)
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 3.3.2010 T-106.1208 Ohjelmoinnin perusteet Y 3.3.2010 1 / 44 Kertausta: tiedoston avaaminen Kun ohjelma haluaa lukea tai kirjoittaa tekstitiedostoon, on ohjelmalle
Ohjelmoinnin perusteet Y Python
Ohjelmoinnin perusteet Y Python T-106.1208 4.3.2009 T-106.1208 Ohjelmoinnin perusteet Y 4.3.2009 1 / 35 Tiedostot Tiedostojen käsittelyä tarvitaan esimerkiksi seuraavissa tilanteissa: Ohjelman käsittelemiä