Föreläsning 1. Introduktion till programutveckling. Varför ha kännedom om datateknik och programmering? Vad är en dator? Vad är en dator?

Relevanta dokument
Varför ha kännedom om datateknik och programmering?

Föreläsning 1. Föreläsning 1

Varför ha kännedom om datateknik och programmering?

Introduktion till programutveckling

Objektorienterad Programmering (TDDC77)

I Skapa Hej.java och skriv programmet. I Kompilera med javac Hej.java. I Rätta fel och repetera tills du lyckas kompilera ditt program

Programmering med Java. Grunderna. Programspråket Java. Programmering med Java. Källkodsexempel. Java API-exempel In- och utmatning.

Programmering för språkteknologer I, VT2012. Rum

OOP Objekt-orienterad programmering

Laboration 1. "kompilera"-ikonen "exekvera"-ikonen

Inledning. Vad är ett datorprogram, egentligen? Olika språk. Problemlösning och algoritmer. 1DV433 Strukturerad programmering med C Mats Loock

4.4 Swing ett interaktivt grafiskt gränssnitt

Objektorienterad Programmering (TDDC77)

SMD 134 Objektorienterad programmering

OOP F1:1. Föreläsning 1. Introduktion till kursen OOP Vad är Java? Ett första Java-program Variabler Tilldelning. Marie Olsson

Kompilering och exekvering. Föreläsning 1 Objektorienterad programmering DD1332. En kompilerbar och körbar java-kod. Kompilering och exekvering

Föreläsning 2 sept 05 (Onsdag v 36). DD Chapter 2.

JAVAUTVECKLING LEKTION 4

732G Linköpings universitet 732G11. Johan Jernlås. Översikt. Repetition. Felsökning. Datatyper. Referenstyper. Metoder / funktioner

Vem är vem på kursen. Objektorienterad programvaruutveckling GU (DIT011) Kursbok Cay Horstmann: Big Java 3rd edition.

Programmering A. Johan Eliasson

Laboration 1. "kompilera"-ikonen "exekvera"-ikonen

TDIU01 - Programmering i C++, grundkurs

Programmering i C++ En manual för kursen Datavetenskaplig introduktionskurs 5p

EDAA20 Programmering och databaser. Mål komprimerat se kursplanen för detaljer. Checklista. Föreläsning 1-2 Innehåll. Programmering.

Föreläsning 2 Programmeringsteknik och C DD1316. Mikael Djurfeldt

Föreläsningsmaterial (Syntax och variabler)

Arv: Fordonsexempel. Arv. Arv: fordonsexempel (forts) Arv: Ett exempel. En klassdefinition class A extends B {... }

Objektorienterad programmering i Java

Editering, Kompilering och Exekvering av Javaprogram

Objektorienterad programmering i Java I. Uppgifter: 2 Beräknad tid: 5-8 timmar (OBS! Endast ett labbtillfälle) Att läsa: kapitel 5 6

Introduktion till programmering och Python Grundkurs i programmering med Python

Föreläsning 1 & 2 INTRODUKTION

Föreläsning 2. Täcker material från lektion 1, 2, 3 och 4:

(Man brukar säga att) Java är... Denna föreläsning. Kompilering av Java. Historik: Java. enkelt. baserat på C/C++ Allmänt om Java

Hej Då, Karel! Programmering. Vårt första Javaprogram. hh.se/db2004. Java. Grundtyper, variabler och arrayer

Föreläsning 1 & 2 INTRODUKTION

ITK:P1 Föreläsning 1. Programmering. Programmeringsspråket Java. Stark typning Explicit typning Strukturerat Hög säkerhet

Föreläsning 2 Objektorienterad programmering DD1332. Typomvandling

F4. programmeringsteknik och Matlab

Programstruktur och terminologi. Programmet producerar följande utskrift i terminalfönstret: Ett Javaprogram består av en eller flera klasser

NetBeans 7. Avsikt. Projektfönster

Laboration 1. Objektorienterad programmering, Z1. Syfte

Objektorienterad programmering Föreläsning 8. Copyright Mahmud Al Hakim Agenda (halvdag)

Föreläsning 2. Operativsystem och programmering

Klassdeklaration. Metoddeklaration. Parameteröverföring

Lösningsförslag: Instuderingsfrågor, del A

Programmera i C Varför programmera i C när det finns språk som Simula och Pascal??

Enkla datatyper minne

1 Datorn som miniräknare. 1.1 Räkneoperationer. 1.2 Variabler

Parameteröverföring. Exempel. Exempel. Metodkropp

EDAA20 Programmering och databaser. Mål komprimerat se kursplanen för detaljer. Om att lära sig programmera. Föreläsning 1-2 Innehåll.

Lite om felhantering och Exceptions Mer om variabler och parametrar Fält (eng array) och klassen ArrayList.

Datatyper och kontrollstrukturer. Skansholm: Kapitel 2) De åtta primitiva typerna. Typ Innehåll Defaultvärde Storlek

Föreläsning 3-4 Innehåll

Föreläsning 3: Typomvandling, villkor och val, samt textsträngar

Inledande programmering med C# (1DV402) 27+15=42 1 (22)

Föreläsning 3-4 Innehåll. Diskutera. Metod. Programexempel med metod

Introduktion till programmering

Programmering, grundkurs, 8.0 hp, Elektro, KTH, hösten Programmering: att instruera en maskin att utföra en uppgift, kräver olika språk:

Föreläsning 2. Primitiva datatyper Selektering

Föreläsning 3. Iteration while-satsen

Lektion Java Grunder. Javas historia. Programmeringsspråket Java. Skillnaderna mellan Java och C++ JVM (Javas Virtuella Maskin)

Föreläsning 2 Programmeringsteknik och C DD1316. Programmering. Programspråk

Högskolan Dalarna sid 1 av 7 DI-institutionen Hans-Edy Mårtensson Sten Sundin

Eclipse. Avsikt. Nu ska ett fönster liknande figuren till höger synas.

Instuderingsfrågor, del A

Kursplanering för EE3D i kursen Programmering 1, 100p.

Enkla variabler kontra referensvariabel

Inledande programmering med C# (1DV402) Introduktion till programmering

SMD 134 Objektorienterad programmering

Introduktion till programmering D0009E. Föreläsning 1: Programmets väg

Att skriva till och läsa från terminalfönstret

Programmeringsteknik med C och Matlab

Anteckningar 1: Grundläggande saker

Testning av program. Verklig modell för programutveckling

Uppgift 1 - programmet, Uppg6.m, visade jag på föreläsning 1. Luftmotståndet på ett objekt som färdas genom luft ges av formeln

Digitalitet. Kontinuerlig. Direkt proportionerlig mot källan. Ex. sprittermometer. Elektrisk signal som representerar ljud.

Idag. statiska metoder och variabler. private/public/protected. final, abstrakta klasser, gränssnitt, delegering. wrapper classes

TDDC77 Objektorienterad Programmering

Dagens föreläsning. Repetition. Repetition - Programmering i C. Repetition - Vad C består av. Repetition Ett första C-program

F2 Datatyper och variabler. ID1004 Objektorienterad programmering Fredrik Kilander

Mer om klasser och objekt

Iteration while-satsen

Föreläsning 2 Programmeringsteknik DD1310. Programmering. Programspråk

Introduktion till Datalogi DD1339. Föreläsning 2 22 sept 2014

Tentamen ID1004 Objektorienterad programmering October 29, 2013

Inledande programmering med C# (1DV402) Ditt första C#-program med Visual Studio

Föreläsning 2 Programmeringsteknik DD1310. Programmering. Programspråk

Grundläggande programmering med C# 7,5 högskolepoäng

Övning2. Variabler. Data typer

Föreläsnings 9 - Exceptions, I/O

Objektorienterad programmering Föreläsning 4

Läsanvisning: Dessa OH bilder samt kap 1-3

Föreläsning 1: Intro till kursen och programmering

Föreläsning 1: Intro till kursen och programmering

Alla datorprogram har en sak gemensam; alla processerar indata för att producera något slags resultat, utdata.

Föreläsning 1-2 innehåll

Grundkurs i programmering, 6 hp (725G61) Dugga 2 tillfälle 2

TDDC77 Objektorienterad Programmering

Transkript:

Varför ha kännedom om datateknik och programmering? Datorerna har blivit en förutsättning för det västerländska industrisamhällets existens och dess framtida tekniska utveckling. Föreläsning 1 Datorer finns som komponenter i alla typer av tekniska system (i en bil kan uppemot 100 datorer finnas). Man bör ha kännedom av den teknik man använder. Introduktion till programutveckling Många avancerade tekniska tillämpningsprogram är programmerbara, för att utnyttja dessa till fullo behövs grundläggande kunskaper i programmering. Föreläsning 1 Man bör känna till de möjligheter som programmering av datorer erbjuder och de svårigheter som hör till. Den problemlösningsmetodik som används är tillämpningsbar inom många andra områden.... Introduktion till programutveckling Vad är en dator? von Neumann modell Exekverar kommandon Vad är en dator? Spara värden Ett sätt (av många) är att betrakta en dator som en bearbetningsmaskin, vilken i likhet med andra bearbetningsmaskiner tar en råvara och från denna producerar en förädlad produkt. Transformera indata till utdata Exekvera kommandon - Kommando: uppdrag att ändra minne * råvara bearbetningsmaskin förädlad produkt Program: - stor sekvens av kommando - utfört ett efetr ett av CPUn *Programmet För en dator utgörs både råvaran och produkten av data. data finns också i minnet men ändras e. indata 3 DATOR utdata 4

Data vs. information Data vs. information En dator är således en bearbetningsmaskin för information. För att kunna bearbeta informationen måste denna ges till datorn i form av data. Datorn kan sedan, på ett eller annat sätt, bearbeta dessa data. Som resultat av bearbetningen erhålles någon form av utdata som sedan kan tolkas för att utvinna ny information. När vi bearbetar data i en dator är det e indatavärdena och utdatavärdena i sig själva som är det ressanta, utan den information som representeras av dessa datavärden. Information kan definieras som den innebörd en mottagare lägger in i givna data. Informationen uppstår först när mottagen data tolkas av mottagaren och därmed får en viss innebörd. bearbetning av information existerande information ny information data + tolkning = information representera information som data tolka den information som finns representerad i datan DATOR data indata bearbetning av data utdata data 5 6 Mer om data Mer om data Data är kodad information som kan förekomma i många olika former, t.ex tal, texter, bilder, ljud och ljus. Exempel: Hur kan 13 tolkas? som tecknet 1 följt av tecknet följt av tecknet 3 data = kodad information t.ex. rätt kombination till portkoden Samma information kan presenteras på många olika dataformat, och samma data kan med olika tolkning representera olika information. som strängen "13" t.ex. namnet på en pub Exempel: Hur kan heltalet 6 kodas? Med 10-talssystemet: 6 Med romerska siffror: VI som heltalet 13 i 10-talssystemet (1310) (eller 610 för att särskilja mellan olika talsystem) 1 0 1*10 + *10 + 3*10 som heltalet 13 i 8-talssystemet (138) Med "streck": Med binära talsystemet: 110 Med bokstäver: "sex" 1 0 1*8 + *8 + 3*8 = 8310 (eller 110 för att särskilja mellan olika talsystem) Det erna dataformatet i en dator är binära tal, d.v.s. sekvenser av 0 och 1. 7 8

Datorprogram Datorprogram Internt i datorn representeras ett program på ett format som kallas maskinkod. maskinkod Maskinkoden utgörs av binära tal: Tänkbar betydelse operationsdelen: Den grundläggande idén, som gör datorn så användbar och flexibel, är att dess arbete styrs via ett datorprogram. datorprogram Datorprogrammen kan bytas ut samt varieras och utformas allt efter de behov och krav som den aktuella tillämpningen ställer. En dator har således e en specificerad arbetsuppgift, utan är ett generellt verktyg för att bearbeta information och kan utnyttjas för nästan alla användningsområden. läs in innehållet på adressen till register A 0010000000111000 addera innehållet på adressen till innehållet i register A En algoritm är en ordnad, ändlig följd av 0011000000111001 elementära och entydiga 0101000000111010 spara register A på adressen operationer/instruktioner som löser en klass av uppgifter. operationsdel adressdel Program Maskinkoden består av en operationsdel och en adressdel. Operationsdelen anger vad som skall göras och adressdelen anger var den data finns som berörs av operationen. indata DATOR utdata Att skriva program direkt i maskinkod är allt annan än människovänligt, varför särskilda programspråk har utvecklats. 9 10 Vad är ett datorprogram? Ett dataprogram är en beskrivning av hur ett problem skall lösas, uttryckt på sådant sätt att datorn kan förstå och utföra de olika stegen i beskrivningen. En algoritm är en ordnad, ändlig följd av elementära och entydiga operationer/instruktioner som löser en klass av uppgifter. En beskrivning av hur ett visst problem skall lösas kallas för en algoritm. algoritm Först när man har en algoritm kan man börja skriva sitt program med hjälp av ett programmeringsspråk. Ordnad: Den följd i vilken operationerna utförs är bestämd. Ändlig: Algoritmen kommer alltid till ett slut. Människa Människa Problem Problem Algoritm Algoritm Människa Datorprogram Datorprogram Dator Elementära: Varje operation gör en sak (på den aktuella abstraktionsnivån). Gör Gör arbetet arbetet Entydiga: Det är aldrig någon tvekan om vad en viss operation innebär, och betydelsen ändras e under tillämpningen av algoritmen. Löser: Algoritmen utmynnar i ett resultat som relaterar till den givna uppgiften. Resultatet kan vara framgång eller misslyckande, men det finns alltid ett resultat och resultatet är alltid giltigt. Ett problem kan oftast lösas på många olika sätt, dvs det kan finnas många algoritmer för ett och samma problem. Således finns det i allmänhet e endast en rätt lösning till ett programmeringsproblem, utan många. En rätt lösning kan dock vara en dålig lösning, eftersom det vanligtvis finns (som vi kommer att se senare) fler krav på ett datorprogram än att det enbart skall producera rätt resultat. Klass av uppgifter: Algoritmen kan användas för att lösa varje praktisk situation där ett problem av den aktuella formen föreligger. 11 1

Då operationerna i en algoritm exekveras - på ett noggrant sätt resulterar detta i att den arbetsuppgift som beskrivs av algoritmen blir verkställd, dvs en algoritm måste terminera. terminera Alla algoritmer kan uttryckas med hjälp av följande enkla styrkonstruktioner: styrkonstruktioner sekvens (följd) För att kunna utföra arbetsuppgiften som beskrivs av en algoritm måste man: kunna förstå varje steg i algoritmen selektion (val) iteration (upprepning) hopp (skall normalt e användas, ger svårbegripliga algoritmer) Alla algoritmer kan uttryckas med hjälp av följande enkla styrkonstruktioner: styrkonstruktioner kunna utföra de instruktioner som stegen beskriver. Stegen i en algoritm måste således vara otvetydiga och exekverbara. sekvens (följd) selektion (val) 13 14 iteration (upprepning) hopp (skall normalt e användas, ger svårbegripliga algoritmer) N0 till basen I instruktionsboken för ett frysskåp finns under rubriken Om skåpet e fungerar tillfredsställande följande algoritm: Flödesdiagrammet beskriver en algoritm för att omvandla ett decimalt heltal N0 till basen. Undersök följande innan Ni begär service: 1. Att stickproppen sitter i ordentligt.. Att säkringen är hel. 3. Att det e är strömavbrott. 4. Att alla manöverprogram är rätt inställda. 5. Att dörren är ordentligt stängd. 6. Att skåpet e står för nära en värmekälla. 7. Att e ett tjockt frost/islager bildats. Om kompressorn gör upprepade startförsök utan resultat, stäng av skåpet i 0 min och försök sedan på nytt ett par gånger. Tilldelning: i := 0 Dividera Ni med : Ni/ = kvot + rest Tilldelningar: di := rest Ni+1 := kvot i := i+1 nej kvot = 0 ja Tilldelning: resultat := (di-1...d1d0) Slut 15 16

En algoritm är oberoende av språket i vilken den är beskriven. Om man utvecklar algoritmen direkt som ett datorprogram kommer man att dränkas i detaljer. Lösningen blir ostrukturerad, bristfällig och oftast felaktig. Ett datorprogram är en algoritm som är beskriven på sådant sätt att stegen i algoritmen kan förstås och utföras av en dator. Problemlösningsfas Problem Problem För att kunna skriva ett datorprogram för att lösa ett givet problem måste man ha tillgång till en algoritm som ger en lösning till problemet innan man kan skriva datorprogrammet! Ej framkomlig väg programkonstruktion => algoritmkonstruktion => problemlösning Algoritm Program Kodningsfas Koda direkt -metoden leder i bästa fall till program som är: svåra att förstå svåra att validera svåra att lokalisera fel i svåra att korrigera fel i svåra att anpassa till nya utvidgningar. Vid utveckling av ett större program är det troligast att man överhuvudtaget e lyckas skriva ett fungerande program! När vi utvecklar algoritmer använder vi oss oftast av pseudokod, pseudokod vilket är en informell blandning av ett "riktigt" programspråk och ett mänskligt språk som svenska eller engelska. 17 18 programkonstruktion => algoritmkonstruktion => problemlösning Råd på vägen Först när man har en algoritm kan man börja skriva sitt program med hjälp av ett programmeringsspråk. Lika viktigt som att programmet är begripligt för datorn, lika viktigt är det att programmet är begripligt för människan. Ett program är e en isolerad och oföränderlig enhet programmet ingår Tänk först, koda sedan! vanligtvis i ett större system och är i allmänhet i behov av återkommande och modifieringar, t.ex på grund av förändringar i det överordnade koda, ju längreunderhåll tid (orsakad kommer det attny hårdvara, ny organisation eller Datorer gör endastju det detidigare blir instruerade attdu göra - börjar det är programmerarens systemet av nya användarkrav, ansvar att algoritmen är riktig och kodas i programspråket på ett korrekt sätt. ny lagstiftning). ta innan du har ett fungerande program! Ett programspråk tillhandahåller de styrkonstruktioner som erfordras för att representera en algoritm så att algoritmen kan utföras av en dator. Människa Människa Problem Problem Algoritm Algoritm Människa Datorprogram Datorprogram Råd på vägen Dator Gör Gör arbetet arbetet Tänk först, koda sedan! Ju tidigare du börjar koda, ju längre tid kommer det att ta innan du har ett fungerande program! 19 0

Vad är programmering? Vad är programmering? Programmeringsarbetet kan indelas i följande faser: Programmering kan definieras som samtliga arbetssteg som behövs för att kunna lösa ett problem med hjälp av en dator. Att kunna programmera är således e enbart att behärska ett visst P R O G R A M M E R I N G programspråk, utan framförallt att känna till metoder för att strukturera och lösa problem så att en dator kan användas som hjälpmedel. Programmering handlar i mycket stor utsträckning om problemlösning och metodkännedom. För att bli framgångsrik måste programmeraren ha en disciplinerad och strukturerad arbetsmetodik. Verkligt problem Utarbeta en exakt definition av problemet Analysera problemet Utarbeta en lösningsskiss/modell till problemet Representera lösningen i en lämplig algoritm Kodning i ett lämpligt programspråk Testning och validering av programmet Dokumentation av programmet Underhåll av programmet Datorprogram som löser problemet 1 Vad är ett programspråk? Vad är ett programspråk? Att skriva ett program är att instruera datorn vad den skall göra. Problemet med en dator är att den kräver att få instruktioner på ett speciellt sätt (s.k. maskinkod), vilket skiljer sig ifrån det sätt som människor sinsemellan kommunicerar. Att skriva ett program är att instruera datorn vad den skall göra När vi vet vad vi vill få datorn att göra, vill vi alltså översätta från någonting vi kan förstå till någonting som datorn kan förstå. Översätta från någonting vi kan förstå till någonting som datorn kan förstå. Problematiskt att använda mänskligt språk - omfångstrikt - mångtydigt - e strikt definierat. En tanke skulle vara att vi uttryckte det vi ville göra, dvs programmerade, i mänskligt språk. Men problemet med det mänskliga språket är att det är omfångsrikt, mångtydigt och e strikt definierat. - Igår sköt jag en hare med gevär på 100 meter. - Ett gevär på 100 meter, det var då ingen liten bössa. - Nä, nä. Med en bössa sköt jag en hare på 100 meter. - En hare på 100 meter. Det var då ingen dålig stek du fick. - Fattar du e. På 100 meter sköt jag en hare med gevär. - En hare med gevär? Då var det i alla fall tur att du sköt först. - Igår sköt jag en hare med gevär på 100 meter. - Ett gevär på 100 meter, det var då ingen liten bössa. - Nä, nä. Med en bössa sköt jag en hare på 100 meter. - En hare på 100 meter. Det var då ingen dålig stek du fick. - Fattar du e. På 100 meter sköt jag en hare med gevär. - En hare med gevär? Då var det i alla fall tur att du sköt först. Den kompromissen man gjort mellan mänskligt språk och maskinkod är att skapa särskilda programmeringsspråk, som är strikt definierade men fortfarande liknar något vi människor är vana att förstå och formulera. Istället används programmeringsspråk, som är strikt definierade men fortfarande liknar något vi människor är vana att förstå och formulera. I kursen kommer vi att använda programmeringsspråket Java. 3 4

Förberedelser inför kodning: Analys Förberedelser inför kodning: Design Problem: Design: Design: Skriv ett program som läser två heltal och skriver ut summan av talen. Algoritm: 1. Skriv texten Ange första talet:.. Läs tal1. 3. Skriv texten Ange andra talet:. 4. Läs tal. 5. Addera tal1 och tal och spara resultatet i summa. 6. Skriv texten Summan av talen är. 7. Skriv ut summa. Analys: Analys: Indata: De två heltalen som skall adderas. Utdata: Summan av de inlästa talen. Exempel på körning: Ange första talet: 5 Ange andra talet: 10 Summan av talen är 15 Datarepresentation: tal1, tal och summa är heltal (som i Java avbildas med hjälp av datatypen ). 5 6 Innan implementationen Varför Java? Java är ett modernt programspråk med flera tilltalande egenskaper: För att kunna skriva ett program som implementerar algoritmen ovan måste vi veta hur man i det aktuella programspråket: avbildar objekten i algoritmen som dataobjekt skriver ut text läser värden till heltalsvariabler adderar två heltalsvariabler lagrar ett värde i en heltalsvariabel skriver ut värdet av heltalsvariabler Detta skall vi förhoppningsvis lära oss innan föreläsningen är slut. 7 stödjer strukturerad programmering är ett objektorienterat språk, vilket underlättar utveckling av stora programsystem är plattformsoberoende tillhandahåller verktyg för att skapa grafiska användargränssnitt är utvecklat med tanke på Internet-användningar har möjligheter till att skriva parallella program tillhandahåller ett omfattande klassbibliotek, med färdigskrivna programmoduler egrerar ny teknologi med nya klassbibliotek tillgång till bra kompilatorer som finns kostnadsfritt relativt lätt att lära sig. 8

Strukturen hos ett Javaprogram Ett första Javaprogram public class Hello { public static void main (String[] args) { System.out.prln("Hello world!"); System.out.pr("This is a message from the computer."); } // main } // Hello Ett program i Java består av ett antal samverkande klasser, klasser som kommunicerar med varandra via meddelanden för att lösa uppgiften. Programmet har en huvudklass, huvudklass vilken innehåller en main-metod main-metod som är själva startpunkten för programmet. Programmet skriver ut texten Hello world! Mall för "enkla program": public class Klassnamn { public static void main (String[] args) { deklarationer och satser }//main }//Klassnamn This is a message from the computer. i datorns kommandofönster. kommandofönster 9 30 Ett första Javaprogram Något om klassen System public class Hello { public static void main (String[] args) { System.out.prln("Hello world!"); System.out.pr("This is a message from the computer."); } // main } // Hello Klassen System kan (något förenklat) sägas vara en uppsättning programenheter som någon redan utvecklat. Klassen System innehåller bland annat ett antal så kallade klassmetoder med vilka andra program kan kommunicera för att få saker utförda. Metoderna System.out.prln(det_som _skall_skrivas_ut) System.out.pr(det_som_skall_skrivas_ut) Namnet vi valt på huvudklassen (programmet) är Hello. main-metoden består av två satser: satser System.out.prln("Hello world!"); System.out.pr("This is a message from the computer."); används för att få utskrifter i kommandofönstret. En metod består av ett namn och en parameterlista. parameterlista System.out.prln("Hello world! "); Varje sats avslutas med ett semikolon (;). Båda satserna är anrop till klassmetoder i klassen System, dvs klassen Hello samverkar med klassen System. När man gör ett anrop av en metod brukar man säga att man skickar meddelande. meddelande Klassen Hello skickar alltså meddelanden till klassen System. metodens namn 31 parameterlista 3

Något om klassen System Kompilering och exekvering Vårt program Skillnaden mellan metoderna pr och prln är att metoden prln automatiskt skriver ut ett radslutstecken, radslutstecken vilket betyder att nästa utskrift hamnar på en ny rad. public class Hello { public static void main (String[] args) { System.out.prln("Hello world! "); System.out.pr("This is a message from the computer."); } // main } // Hello I anropet System.out.prln("Hello world!"); är det en textsträng vi vill skriva ut. För att ange att det rör sig om en textsträng måste textsträngen omges av citationstecken. citationstecken Klassen System finns i Javas standardbibliotek (API:n) i ett paket med namnet java.lang. måste lagras på en textfil med namnet Hello.java, dvs namnet på klassen samt suffixet.java. I filen Hello.java finns nu programmet i form av källkod. källkod För att kunna exekvera (köra) programmet måste källkoden först kompileras, kompileras d.v.s. översättas till ett format som förstås av datorn. Kompileringen görs med hjälp av en kompilator. kompilator 33 34 Kompilering och exekvering Kompilering och exekvering För att kompileringen skall lyckas måste programmet vara syntaktiskt korrekt, korrekt dvs följa de språkregler som finns i Java. Annars uppstår kompileringsfel, kompileringsfel pga att kompilatorn e förstår vad som programmeraren menar. public class Hello { public static void main (String[] args) { System.out.prln("Hello world! "); System.out.pr("This is a message from the computer."); } // main } // Hello När kompileringen av källkoden lyckas, skapas en ny fil Hello.class. Denna fil innehåller programmet i ett format som kallas Javabytekod och detta format förstås av datorn. Används kommandofönstret kompileras programmet med kommandot Programmet måste lagras på en textfil med namnet Hello.java, dvs namnet på klassen samt suffixet.java. Filen Hello.java innehåller programmet i form av källkod. källkod För att kunna exekvera (köra) programmet måste man kompilera källkoden. Kompileringen görs av en kompilatorn. kompilatorn javac Hello.java och exekveras med kommandot java Hello I kursen kommer vi att använda en speciell texteditor, JGrasp, i från vilken man kan både kompilera och exekvera programmet. 35 36

Användning av dialogrutor för utskrift JGrasp JGrasp är en texteditor i vilken man får olika former av stöd vid skrivandet av sitt program, och från vilken man kan kompilera och exekvera programmet. I Java finns ett paket som heter Swing, som innehåller standardklasser för att skapa grafiska användargränssnitt. användargränssnitt I Swing finns klassen JOptionPane som innehåller metoder för att skapa dialogrutor för in- och utmatning. För utmatning har klassen JOptionPane bl.a metoden showmessagedialog. import javax.swing.joptionpane; public class Hello { /*Detta program ger en hälsning från datorn */ public static void main (String[] args) { JOptionPane.showMessageDialog(null,"Hello world! \n" + "This is a message from the computer."); } // main } // Hello Kommandofönster 37 38 Användning av dialogrutor för utskrift Dialogrutor för inmatning För inmatning har klassen JOptionPane bl.a metoden showinputdialog. import javax.swing.joptionpane; public class Hello { /* Detta program ger en hälsning från datorn */ public static void main (String[] args) { JOptionPane.showMessageDialog(null,"Hello world! \n" + "This is a message from the computer."); } // main } // Hello import javax.swing.joptionpane; public class Greeting { public static void main (String[] arg) { String name = JOptionPane.showInputDialog("Vad heter du?"); String greeting = "Välkommen " + name; JOptionPane.showMessageDialog(null,greeting); } //main } // Greeting Kommentarer: Klassen JOptionPane finns i paketet javax.swing och och måste importeras till programmet, vilket görs med satsen import javax.swing.joptionpane; Kommentarer: '\n' är ett specialtecken som anger radslut (radslutstecken radslutstecken). Metoden showinputdialog returnerar en textsträng (allt som skrivs in via tangentbordet är text!). Denna sträng måste tas om hand och lagras i en variabel av klassen String, som används i Java för att avbilda textsträngar. Operatorn + används (i denna kontext) för att slå ihop två textsträngar. Note: Klassen System som användes i förra programmet finns i ett paket som heter java.lang, detta paket behöver dock e importeras eftersom detta görs automatiskt. Inläsningen från showinputdialog aktiveras när användaren trycker OK-knappen. 39 40

Textvariabler Inbyggda primitiva typer i Java I Java finns 8 olika enkla typer (eller primitiva typer) typer som används för att avbilda enkla slag av objekt och som används som byggstenar för att konstruera mera komplexa objekt. Textvariabler avbildas i Java med hjälp av standardklassen String. För att tilldela en variabel ett värde används tilldelningsoperatorn =. För att slå samman två texter finns för klassen String operatorn +. Exempel: När nedanstående satser utförs String texten; texten = "Hej"; texten = texten + " Kalle"; kommer variabeln texten att refererar till ett objekt som innehåller texten "Hej Kalle". Datatyp Användning Storlek byte för att avbilda heltal 8 bits short för att avbilda heltal 16 bits för att avbilda heltal 3 bits long för att avbilda heltal 64 bits float för att avbilda reella tal 3 bits double för att avbilda reella tal 64 bits boolean för att avbilda logiska värden 16 bits char för att avbilda tecken för att avbilda tecken Klassen String kommer att behandlas mer utförligt senare i kursen. 41 4 Vad är en variabel? Numeriska datatyper i Java I ett datorprogram används variabler för att lagra olika typer av data. För att avbilda heltal kommer vi enbart att behandla och för att avbilda reella tal kommer vi enbart att behandla double. I Java finns olika slag av variabler och de variabler som används för att lagra enkla datatyper kallas enkla variabler. variabler En variabel kan ses som en namngiven behållare i vilken man kan lagra ett värde av en viss typ. Datatyp Storlek Min. värde Max. värde byte 8 bits -18 17 antal short 16 bits 3 bits 3767 147483647 Observera!! -3768-147483647 1935 long 64 bits -9337036854775808 9337036854775807 I matematiken betyder begreppet variabel något annat. float 3 bits ca +/-1.4 E-45 7 siffrors noggrannhet ca +/3.4 E+38 7 siffrors noggrannhet double 64 bits ca +/- 4.9 E-34 15 siffrors noggrannhet ca +/-1.8 E+308 15 siffrors noggrannhet Variabels namn kopplas till ett visst minnesutrymme i datorns primärminne där variabelns värde lagras i form av bits. antal 100110100011110101000000000000000000000111100011110010000100010100100 43 44

Deklarationer av variabler Deklarationer av variabler Deklarationerna antal; double vikt, produktpris; innebär att tre variabler skapas. En variabel måste deklareras innan den används i programmet. Variabeldeklarationer har följande utseende: antal; Storleken (antalet bits) på minnesutrymmet som associeras med en variabel beror på variabelns datatyp. antal vikt produktpris??? Dessa variabler har odefinierade värden (eftersom värdet bestäms av det bitmönster som råkar ligga i minnesutrymmet). Värdet av en variabel är odefinierat tills variabeln explicit har tilldelats ett v ärde i programmet. Bitmönstret i minnesutrymmet som är associerat med en variabel bestämmer tillsammans med variabelns datatyp vilket värde variabeln har. När tilldelningssatserna antal = 10; vikt = 1.87; produktpris = 4.75; har utförts har respektive variabel tilldelas värden: antal 100110100011110101001100000000111000000100100011000010000100010100100 Variabelns typ avgör hur många bits variabeln omfattar och hur värdet av dessa bits skall tolkas antal vikt produktpris 10 1.87 4.75 45 46 Deklarationer av variabler Deklarationer av variabler En variabel kan tilldelas ett värde direkt i deklarationssatsen: nummer = 13; double pris = 45.5, volym = 1.5; nummer pris volym 13 45.5 1.5 Värdet av en variabel kan när som helst läsas av. En variabel kan när som helst tilldelas ett nytt värde. Antag att vi gjort följande variabeldeklaration antal = 10; Utförs nu tilldelningssatsen antal = antal + 35; //antal tilldelas värdet av antal + 35 förändras värdet på variabeln antal En variabel deklareras exakt en gång, gång dvs varje variabel måste ha ett unikt namn. Deklareras samma variabler flera gånger erhålls ett kompileringsfel. Exempel: bredd = 13; double bredd = 45.5; En felutskrift fås från kompilatorn "bredd is already defined" vid satsen double bredd = 45.5; antal 10 antal 45 Observera de två olika betydelserna variabeln antal har i tilldelningssatsen antal = antal + 35; Felaktig deklaration Minnesutrymmet för variabeln 47 innehållet i minnesutrymmet för variabeln 48

Operationer på datatypen Operationer Att endast lagra data i variabler är ganska oressant. Syftet med ett datorprogram är att från någon form av indata producera utdata. Utdatan är, i en eller annan mening, en förädlad form av indatan. indata Program Notation a+b a-b a*b a/b a%b a>b a<b a >= b a <= b a == b a!= b +a -a utdata För att från indatan kunna producera utdata, måste vi kunna göra beräkningar på de värden som lagras i variablerna i programmet. De primitiva datatyperna har ett antal fördefinierade operationer, operationer som används för att utföra beräkningar. Med hjälp av operationerna kan man bygga upp komplicerade uttryck. uttryck Betydelse addition Resultatets datatyp subtraktion multiplikation heltalsdivision modulus (rest vid heltalsdivision) större än boolean mindre än boolean större eller lika med boolean mindre eller lika med boolean lika med boolean e lika med boolean samma som a negationen av a Observera! Motsvarande operationer finns för byte, short och long. 49 50 Heltalsdivision och rest vid heltalsdivision Till var och en av de primitiva typerna finns en omslagsklass, omslagsklass som innehåller information om datatypen samt en del användbara metoder och konstanter. konstanter Utryck Dividend Divisor Kvot Rest 6 / 6 6 % 6 6 6 4 6 = 4 * 6 + 100 / 40 100 % 40 100 40 0 100 = * 40 + 0 /4 %4 Omslagsklasser Omslagsklasserna heter: Integer, Double, Character, Boolean,... 4 0 Omslagsklassen Integer innehåller bl.a följande konstanter och metoder: =0*4+ -5 / -5 % -5 - -1-5 = - * + -1 7 / -3 7 % -3 7-3 - 1 7 = - * -3 + 1 static final MAX_VALUE det största värdet som kan lagras i en static final MIN_VALUE det minsta värdet som kan lagras i en static String tostring( n) ger heltalet n som en sträng static parseint(string str) ger strängen str som en Kommentar: static anger att entiteten är en klassentitet final anger att entiteten e kan förändra sitt värde heltal! Dessa begrepp kommer att förklaras utförligt senare. 51 5

Omslagsklasser Det färdiga programmet /* Programmet läser in och adderar två heltal, samt skriver ut resultatet. */ import javax.swing.joptionpane; public class AddTwoIntegers { public static void main (String[] arg) { String input = JOptionPane.showInputDialog("Ange första talet"); number1 = Integer.parseInt(input); input = JOptionPane.showInputDialog("Ange andra talet"); number = Integer.parseInt(input); sum = number1 + number; JOptionPane.showMessageDialog(null, "Summan av talen är " + sum); } //main } // AddTwoIntegers Exempel: Anropet Integer.parseInt("134") returnerar heltalet 134 Anropet Integer.parseInt("abc") ger NumberFormatException Anropet Integer.toString(5678) returnerar strängen "5678" Satserna System.out.prln("Största heltal: " + Integer.MAX_VALUE); System.out.prln("Minsta heltal: " + Integer.MIN_VALUE); ger utskriften: Största heltal: 147483647 Minsta heltal: -147483648 53 54