Kapittel 1: Datamaskiner og programmeringsspråk

Like dokumenter
Kapittel 1: Datamaskiner og programmeringsspråk

Kapittel 1: Datamaskiner og programmeringsspråk. Java som første programmeringsspråk

Kapittel 1: Datamaskiner og programmeringsspråk. Java som første programmeringsspråk

Kapittel 1. Datamaskiner og programmeringsspråk. 1.1 Programmering

Kapittel 1. Datamaskiner og programmeringsspråk. 1.1 Hva er en datamaskin? En datamaskins bestanddeler

Kapittel 15: Grafiske brukergrensesnitt: Enkel GUI. Del I

Kapittel 15: Grafiske brukergrensesnitt: Enkel GUI. Del I

2 Om statiske variable/konstanter og statiske metoder.

Kapittel 8: Programutvikling

Oversikt. INF1000 Uke 1 time 2. Repetisjon - Introduksjon. Repetisjon - Program

Kapittel 5: Objektkommunikasjon

Kapittel 9: Sortering og søking Kort versjon

Kapittel 7: Mer om arv

Operativsystemer og grensesnitt

INF1000 EKSTRATILBUD. Stoff fra uke 1-5 (6) 3. oktober 2012 Siri Moe Jensen

Oversikt. Informatikk. INF1000: Grunnkurs i objektorientert programmering. Utenom INF1000 Informasjon & hjelp

2 Om statiske variable/konstanter og statiske metoder.

Kapittel 9: Sortering og søking Kort versjon

Introduksjon til programmering og programmeringsspråk. Henrik Lieng Høgskolen i Oslo og Akershus

Læringsmål og pensum. v=nkiu9yen5nc

Forelesning inf Java 1

Kapittel 1 En oversikt over C-språket

NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse. INF 5110, 10/5-2011, Stein Krogdahl

Programmeringsspråket C

Kort om meg. INF1000 Uke 2. Oversikt. Repetisjon - Introduksjon

NOTAT (pensum!) Javas klasse-filer, byte-kode og utførelse

public static <returtype> navn_til_prosedyre(<parameter liste>) { // implementasjon av prosedyren

Kapittel 9: Sortering og søking Kort versjon

TDT4110 Informasjonsteknologi grunnkurs: Kapittel 1 Introduksjon til Programmering og Python. Professor Alf Inge Wang

Kapittel 9: Sortering og søking Kort versjon

INF 1000 høsten 2011 Uke september

Oversikt. INF1000 Uke 2. Repetisjon - Program. Repetisjon - Introduksjon

INF1000 : Forelesning 1 (del 2)

INF1000 undervisningen INF 1000 høsten 2011 Uke september

Litt om Javas class-filer og byte-kode

public static <returtype> navn_til_prosedyre(<parameter liste>) { // implementasjon av prosedyren

Programmeringsspråket C

Programmeringsspråket C

Fra Python til Java, del 2

Introduksjon til programmering og programmeringsspråk

6108 Programmering i Java. Leksjon 1. Introduksjon til programmering og til Java

156C. Algoritmer og maskinspråk. IT1101 Informatikk basisfag. Maskinspråk: det maskinen forstår. Assembler / assemblerspråk

Javas klasse-filer, byte-kode og utførelse (og litt om C# sin CIL-kode)

Kapittel 13: Grafiske brukergrensesnitt INF 100. Java som første programmeringsspråk

Av Stein Gjessing, Institutt for informatikk, Universitetet i Oslo

Innhold uke 4. INF 1000 høsten 2011 Uke 4: 13. september. Deklarasjon av peker og opprettelse av arrayobjektet. Representasjon av array i Java

Forelesning inf Java 1

Introduksjon til objektorientert programmering

Hvordan en prosessor arbeider, del 1

JSP - 2. Fra sist. Hvordan fungerer web? Tjenerside script HTML. Installasjon av Web-tjener Et enkelt JSP-script. Ønsker dynamiske nettsider:

TDT4105 Informasjonsteknologi, grunnkurs (ITGK)

Kodegenerering del 3: Tilleggsnotat fra AHU Samt litt om class-filer og byte-kode INF5110 V2007. Stein Krogdahl, Ifi UiO

Enkle generiske klasser i Java

Hva er programmering?

TDT4110 Informasjonsteknologi, grunnkurs Uke 35 Introduksjon til programmering i Python

Del 1 En oversikt over C-programmering

TDT4105 Informasjonsteknologi, grunnkurs (ITGK)

Obligatorisk Innlevering 2

Forkurs INF1010. Dag 2. Andreas Færøvig Olsen Gard Inge Rosvold Institutt for Informatikk, 14.

Løsningsforslag ukeoppg. 6: 28. sep - 4. okt (INF Høst 2011)

Dagens tema Kapittel 8: Objekter og klasser

Kapittel 11: Unntakshåndtering. Java som første programmeringsspråk

som jobbet nærmest døgnet rundt i 18 måneder i Menlo Park i California for å forberede den neste bølgen innen computing.

Litt Java-historikk. Litt Java-historikk. Ulike varianter for ulike behov. Litt Java-historikk. The Green Team

Kom i gang med programmering i Java

Kapittel 13: Unntakshåndtering

Forelesning inf Java 1

Programmering i C++ Løsningsforslag Eksamen høsten 2005

Kapittel 8: Sortering og søking

Kapittel 13: Unntakshåndtering

Oversikt. Hva er programmering & Java forkurset til INF1000. Hva er en datamaskin. Arne Maus Inst for Informatikk Univ. i Oslo

INF1000: Forelesning 7. Konstruktører Static

Argumenter fra kommandolinjen

Generelt om operativsystemer

Kapittel 11: Unntakshåndtering. Java som første programmeringsspråk

INF1000 : Forelesning 4

INF5110. Oblig 2 presentasjon

Minnehåndtering i operativsystemer

i=0 i=1 Repetisjon: nesting av løkker INF1000 : Forelesning 4 Repetisjon: nesting av løkker Repetisjon: nesting av løkker j=0 j=1 j=2 j=3 j=4

Minnehåndtering i operativsystemer

Velkommen til. INF våren 2016

UNIVERSITETET I OSLO

Kapittel 8: Sortering og søking INF100

Kapittel 8: Sortering og søking INF100

i=0 Repetisjon: arrayer Forelesning inf Java 4 Repetisjon: nesting av løkker Repetisjon: nesting av løkker 0*0 0*2 0*3 0*1 0*4

Forelesning inf Java 4

Eksamen. Objektorientert Programmering IGR 1372

Debugging. Tore Berg Hansen, TISIP

OPPGAVESETT 1 INTRO. Delta på andre forelesning i emnet, der hovedkomponentene til datamaskinen blir introdusert. Ta notater!

Velkommen til INF5110 Kompilatorteknikk

INF Oblig 2 semantikksjekk og kodegenerering

INF1000: Forelesning 7

Dagens tema. Hva er kompilering? Anta at vi lager dette lille programmet doble.rusc (kalt kildekoden): Hva er kompilering?

Velkommen til INF2100

Overordnet maskinarkitektur. Maskinarkitektur zoomet inn. I CPU: Kontrollenheten (CU) IT1101 Informatikk basisfag, dobbeltime 11/9

Fra Python til Java. En introduksjon til programmeringsspråkenes verden. Dag Langmyhr

Generelt om operativsystemer

UNIVERSITETET I OSLO

Forklaring til programmet AbstraktKontoTest.java med tilhørende filer Konto.java, KredittKonto.java, SpareKonto.java

INF225 høsten 2003 Prosjekt del 4: kodegenerering

Transkript:

Kapittel 1: Datamaskiner og programmeringsspråk Redigert av: Khalid Azim Mughal (khalid@ii.uib.no) Kilde: Java som første programmeringsspråk (3. utgave) Khalid Azim Mughal, Torill Hamre, Rolf W. Rasmussen Cappelen Akademisk Forlag, 2006. ISBN: 82-02-24554-0 http://www.ii.uib.no/~khalid/jfps3u/ (NB! Boken dekker opptil Java 6, men notatene er oppdatert til Java 7.) 4/7/2012 1: Datamaskiner og programmeringsspråk 1-1/27

Emneoversikt Datamaskinens virkemåte Programmeringsspråk og programoversettelse: høy- og lavnivå språk Java-modell for progamutvikling og -utføring Kompilering og utføring av Java-program JFPS3U 1: Datamaskiner og programmeringsspråk 1-2/27

Mål med kurset: problemløsing på datamaskin Kursets mål er ikke å lære et bestemt programmeringsspråk (Java, C++, C#) men å gi en introduksjon til programmering for å løse problemer på datamaskinen. Dette omfatter: systematisk problemanalyse konstruksjon av programmer v.h.a. Java d.v.s. problemløsningsteknikker Valg av programmeringsspråk er et pragmatisk problem. Programmeringsmetodikk er i stor grad uavhengig av programmeringsspråk. JFPS3U 1: Datamaskiner og programmeringsspråk 1-3/27

Hva er et program? Et program er en oppskrift for å løse et problem på datamaskinen. Det er en sekvens av instruksjoner uttrykt i et spesifikt programmeringsspråk med presis syntaks og semantikk. Instruksjoner er skrevet (programmert, kodet) av en programmerer. Instruksjoner blir utført av en datamaskin, som kan utføre dem én eller flere om gangen. Eksempler: tekstbehandlingssystem, minibankprogram, videospill, billettbestillingsystem, nettbutikk, blogg JFPS3U 1: Datamaskiner og programmeringsspråk 1-4/27

Syntaks, semantikk, pragmatikk Syntaks grammatiske regler Hvordan et program må skrives (kontrueres) for at det overhodet skal bli godtatt som et syntaktisk riktig program. Semantikk mening Meningen til ulike syntaktisk korrekte deler av språket. Pragmatikk riktig bruk Metoder, regler og konveksjoner for hvordan en bør bruke språket på en fleksibel og forståelig måte. Programmeringsmetodologi. ren pugg (Språk definisjon) mer komplisert (Språk definisjon) læres ved programmering og erfaring (Best practices) JFPS3U 1: Datamaskiner og programmeringsspråk 1-5/27

Programmeringsmetodikk: Objektorientert programmering (OOP) OOP går ut på å identifisere objekter, og hvordan disse samarbeider for å løse et problem. OOP-objekter er ment å modellere objekter fra virkeligheten de har både egenskaper og atferd. JFPS3U 1: Datamaskiner og programmeringsspråk 1-6/27

Læremåte for (;;) programmér; // For evig JFPS3U 1: Datamaskiner og programmeringsspråk 1-7/27

Datamaskinens virkemåte: analogi Apotek Arbeidsinstruks (oppskrifter) Internt lager Daglig leder Regnskap Eksternt lager Resept innlevering Resept utlevering Bruker JFPS3U 1: Datamaskiner og programmeringsspråk 1-8/27

Datamaskinens virkemåte Program Datamaskin hente-dekode-utføre syklus Internt lager (minne) Kontrollenhet (CPU) Aritmetisk/ Logisk enhet (ALU) Eksternt lager (disk) Lese-enhet (tastatur) Skrive-enhet (skjerm) Bruker JFPS3U 1: Datamaskiner og programmeringsspråk 1-9/27

Datamaskin og programvare: løk-modellen maskinvare vindusystem Java programmeringsverktøy Java program Lag av programvarer fører til maksimal utnyttelse av maskinkraft. har organisering i biblioteker og programmer. OS JFPS3U 1: Datamaskiner og programmeringsspråk 1-10/27

To utsnitt (views) av et program (som også er et objekt) grafisk brukergrensesnitt programvarer skjult v.h.a. grensesnitt A maskinvarer OS vindussystem Java program programmerer bruker JFPS3U 1: Datamaskiner og programmeringsspråk 1-11/27

Høynivå språk Programoversettelse x = y * z kildekode Assemblyspråk MOV y, R MUL z, R MOV R, x assemblykode Maskinspråk 0000 0110 0111 0001 0000 0111 0110 0001 0000 0110 0001 0010 maskinkode Meningsbevarende oversettelse Kompilator er et program som oversetter kildekode til lavnivå kode JFPS3U 1: Datamaskiner og programmeringsspråk 1-12/27

Dataspråk Maskinspråk språket som datamaskinen forstår og utfører tett tilknyttet en bestemt maskinarkitektur sekvens av nuller og enere vanskelig for mennesker å forstå f.eks. 0000 0110 0111 0001 er en maskin instruksjon. Assembly språk navn for operasjoner, etc. som finnes i maskinspråk lavnivå: hver instruksjon (pakker minst mulig informasjon) tilsvarer en maskin instruksjon tett tilknyttet et bestemt maskinspråk fremdeles vanskelig for mennesker å forstå f.eks. MOV y, R Høynivå språk Høynivå: hver instruksjon tilsvarer mange lavnivå instruksjoner lettere for mennesker å forstå (eks. C, C++, C#, Java) kan oversettes til mange lavnivå språk v.h.a. kompilatorer, f. eks. x = y * z JFPS3U 1: Datamaskiner og programmeringsspråk 1-13/27

Programoversettelse for Java Høynivå språk x = y * z Java kildekode Mellomliggende språk iload_2 iload_3 imul istore_1 Java byte-kode JFPS3U 1: Datamaskiner og programmeringsspråk 1-14/27

Java modell teksteditor Java kildekode fil* Java byte-kode lastes inn i minne Klasselaster Verifisering JVM: Java virtuellmaskin Java kompilator Interpreter operativsystem Java byte-kode fil* maskinvare Programoversettelse/ kompilering *filer lagres på sekundærlager (disk) Programutføring eller -kjøring oversetter hver Java byte-kode til maskinkode som utføres umiddelbart. JFPS3U 1: Datamaskiner og programmeringsspråk 1-15/27

Java plattformuavhengighet KOMPILERING: Java program Datamaskin 1 Java byte-kode Java byte-kode kompilator UTFØRING: Java byte-kode inndata fra bruker Datamaskin 1 utdata til bruker Virtuell maskin 1 Java byte-kode inndata fra bruker Datamaskin 2 utdata til bruker Virtuell maskin 2 Samme Java byte-kode kan kjøres på forskjellige datamaskiner med forskjellige Java virtuelle maskiner. JFPS3U 1: Datamaskiner og programmeringsspråk 1-16/27

Verktøy: Java Development Kit (JDK 7.0) Et sett med verktøy for programmering i Java, tilgjengelig for forskjellige plattformer. javac: java: javadoc: oversetter Java kildekode til Java byte-kode utfører Java byte-kode (JVM) genererer API dokumentasjon i HTMLformat trenger en teksteditor i tillegg for å skrive Java kildekode. JFPS3U 1: Datamaskiner og programmeringsspråk 1-17/27

State-of-the-art kurs i programmering Programmeringsmetodikk: Programmeringsspråk: Programmeringsverktøy: Maskinvare: Objektorientert programmering (OOP) Java JDK 7.0 + DrJava Kraftige PC er JFPS3U 1: Datamaskiner og programmeringsspråk 1-18/27

Programmering er tidskrevende! Programmering krever tid/arbeid, men er gøy. Nøkkelen til suksess: programmér oppgavene arbeid jevnt med stoffet DET ER IKKE MULIG Å PUGGE! JFPS3U 1: Datamaskiner og programmeringsspråk 1-19/27

Programmeringsspråk: Java Java er et objektorientert programmeringsspråk. I Java kan du skrive to typer programmer: Programmer som kalles for snutter (applets), og er nedfelt i en web-side. En web-side er et dokument på Internetts World Wide Web (WWW) som kan leses ved hjelp av en web-browser eller nettleser (f.eks. Internet Explorer, Opera, FireFox, Chrome). Nettleseren legger alt til rette for at snutten kan utføres av JVM. Programmer som er selvstendige applikasjoner disse trenger ikke ekstra støtte for å kunne utføres direkte av JVM. JFPS3U 1: Datamaskiner og programmeringsspråk 1-20/27

Java programstruktur og -miljø Et Java program er en samling av en eller flere klasser. Kildekode til klasser lagres i tekstfiler. Hver klasse kompileres til en egen.class-fil som består av Java byte-kode. klassedeklarasjon klassenavn metodedeklarasjon public class Hilsen { metodenavn public static void main(string[] args) { handlinger som skal utføres i sekvens parametere } } JFPS3U 1: Datamaskiner og programmeringsspråk 1-21/27

Et enkelt selvstendig program 1. // En liten hilsen 2. public class Hilsen { 3. public static void main(string[] args) { 4. System.out.println("Velkommen til Portveien 2!"); 5. } 6. } Utskrift på skjerm: Velkommen til Portveien 2! JFPS3U 1: Datamaskiner og programmeringsspråk 1-22/27

Linje 1: Linje 2: // En liten hilsen Énlinjes kommentar som brukes til å dokumentere program. Alt f.o.m. // og t.o.m. slutt på linjen har ingen betydning for programutføring. Program uten dokumentasjon er vanskelig å forstå. public class Hilsen { En klasse defineres med en deklarasjon som begynner med nøkkelord class. En klasse har navn. Identifikator Hilsen er navn på klassen. Klassekroppen, som er en blokk,{...}, kan inneholde ytterligere deklarasjoner (metoder og felt). All kildekode i et Java program må være inne i en klasse. Nøkkelord public angir synlighet av en klasse: klassen Hilsen er tilgjengelig til alle andre klasser. JFPS3U 1: Datamaskiner og programmeringsspråk 1-23/27

Linje 3: public static void main(string[] args) { Hvert selvstendig program må ha én metode med navn main for å bli utført. kroppen til en metode er omsluttet av en blokk, {...}. public Nøkkelord public angir synlighet av en metode. Metode main er tilgjengelig til alle andre klasser. static Metode main er deklarert som en statisk metode, dvs den tilhører klassen og ikke instanser av klassen (objekter). void Metoder returner vanligvis verdier. Metodedeklarasjon må da eksplisitt angi type til returnert verdi. Nøkkelord void angir at metoden ikke returnerer en verdi. JFPS3U 1: Datamaskiner og programmeringsspråk 1-24/27

Linje 4: main(string[] args) Parameterliste, (...), brukes til å overføre data til en metode. Metode main tar én parameter, args, som er en tabell av strenger (angitt ved String[]) args inneholder kommandolinje argumenter. System.out.println("Velkommen til Portveien 2!"); Setningen skriver streng "Velkommen til Portveien 2!" på skjermen. Klassen System har en statisk variabel out som betegner standard ut-enhet (vanligvis skjerm) for hvert program som utføres. Metoden println, som tilhører objektet out angitt ved punktum (.) notasjon, skriver ut argumentstreng sendt til den. Semikolon (;) avslutter en setning. Følg oppskriften for å skrive et Java program! Ytterligere forklaringer kommer etter hvert! JFPS3U 1: Datamaskiner og programmeringsspråk 1-25/27

Fremgangsmåten for å skrive og kompilere et program 1. SKRIV programmet v.h.a. en teksteditor. 2. Lagre filen og gi den et navn, f.eks. Hilsen.java Gå ut av teksteditor. 3. KOMPILER kildekode fil ved å gi kommando: javac Hilsen.java Hvis kompilator gir noen feilmelding gå tilbake til teksteditor (filen Hilsen.java), rett feilene, fortsett fra og med pkt. 3. ellers (ingen feilmeldinger). Kompilator har oversatt programmet og laget nye filer (bl.a. Hilsen.class) 4. KJØR programmet ved å gi kommando: java Hilsen Klassenavn må være helt identiske med filnavn (uten.java suffiks) Klassen må definere main()-metoden. JFPS3U 1: Datamaskiner og programmeringsspråk 1-26/27

Oppsummering: Å kjøre et selvstendig program 1 2 Utdata Velkommen til Portveien 2! Hilsen.java Kompilator javac Hilsen.class Tolker java 1 KOMPILER kildekode fil: javac Hilsen.java 2 KJØR programmet: java Hilsen JFPS3U 1: Datamaskiner og programmeringsspråk 1-27/27