Indholdsfortegnelse:
Video: Curso Java 09 - Bucles for anidados @JoseCodFacilito 2025
Fejl i Java-programmer kan forekomme på forskellige tidspunkter. Du kan dog generelt klassificere, når der opstår en fejl i to kategorier, på kompileringstid og runtime, som beskrevet i de følgende afsnit.
Kompilere tidsfejl
Kompilatoren konverterer din applikationskode til Java byte-kode. Under denne proces tager den den læsbare kode, du skriver, og konverterer den til noget, som Java Runtime Environment (JRE) forstår.
For at udføre denne proces skal kompilatoren parse koden, hvilket betyder at den læser koden på en måde, der entydigt bestemmer præcist, hvad du vil have, at programmet skal gøre, når du vil have det til at gøre det, og hvordan du vil have opgaven udført. Hvis du bryder reglerne for at skrive entydig kode, viser kompilatoren en fejlmeddelelse. Denne besked er faktisk en slags undtagelse.
Parsing betyder at læse det input, du giver, såsom kode i læsbar form, og omdanne den til noget andet, som f.eks. Java byte-kode. En applikation kan også analysere brugerindgang. For eksempel kan en bruger skrive en streng, som din applikationskode bliver til et nummer.
Så, parsing er en handling at læse en eller anden type input, fortolke den pågældende input på en bestemt måde og derefter producere output baseret på det tolkede input. En parser genererer en fejl, når input ikke er, hvad det forventer.
Hvis brugeren f.eks. Indtaster en streng, der indeholder bogstavet C, og du forventede en streng, der indeholder et tal, som 123, vil parseren generere en undtagelse, der siger, at indtastningen er forkert.
Kompileringstidsfejl er det nemmeste at håndtere, fordi kompilatoren normalt fortæller dig præcis, hvad der er galt og hvor fejlen er opstået. Selvom oplysningerne ikke er nøjagtige, vil kompilatoren i det mindste komme dig til det rigtige område af den ødelagte kode, så du kan søge efter den fejl, den indeholder.
For at sikre, at alle forstår præcist, hvordan Java-sproget skal arbejde, opbygger udviklere en specifikation for det. Denne specifikation omfatter sprogelementerne i et specielt sprog kaldet Backus-Naur Form (BNF). Brug af BNF er en yderst præcis metode til at beskrive et sprog, så der ikke er nogen risiko for fejlfortolkning af nogen.
Du kan se en prøve af BNF for Java-sproget ved Institut for Datalogi - Daimi. Du skal ikke bekymre dig for meget om at kunne læse denne specifikation. De fleste udviklere lærer aldrig at fortolke BNF for de sprog, de bruger - det er domænet for kompilatorudviklere.
Runtime fejl
Java-kompilatoren kan ikke finde alle fejl i din kode. Hvis koden er korrekt (det vil sige, du har ikke lavet fejl ved at skrive de elementer, der skaber programmet), vil kompilatoren ikke finde fejlen.
Hvis du for eksempel initialiserer en numerisk værdi til 5 i stedet for 4, kan kompilatoren ikke finde fejlen for dig, fordi kompilatoren ikke har nogen anelse om, at du virkelig mente at skrive 4. Disse slags fejl skaber runtime fejl - de fejl, der opstår på et eller andet tidspunkt under applikationens udførelse.
Runtime fejl kan forekomme på alle mulige gange. Nogle fejl er mere tilbøjelige til at forekomme på bestemte tidspunkter. Følgende liste giver dig nogle ideer om, hvornår runtimefejl sandsynligvis vil opstå:
-
Initialisering: Når applikationen starter først - inden den præsenterer nogen form for interface til brugeren eller udfører noget nyttigt arbejde - går det igennem en initialiseringsfase. Dette er når du indstiller en variabel til den forkerte type eller forsøger at bruge en variabel, før du initialiserer det, bliver det bemærket. Mange ressourcerelaterede fejl opstår også under initialisering, fordi de fleste applikationer åbner nødvendige ressourcer i løbet af denne tid.
-
Driftstilstand: Når en applikation initialiseres, er den i driftstilstand. Hvis den har en brugergrænseflade, begynder den at interagere med brugeren. Det er det tidspunkt, hvor brugerindgang betyder mest.
Du finder også forkert initialiserede variabler på nuværende tidspunkt, fordi brugeren (eller modtageren af programudgangen, som f.eks. Systemet) vil se, at udgangen er forkert. Brugeranmodninger om ressourcer, såsom en datafil, skaber også fejl i løbet af denne tid.
-
Baggrundsbehandling: De fleste fejl i baggrundsbehandlingen skyldes miljøet (f.eks. Tab af en netværksforbindelse), manglende ressourcer (som en tabt fil), forkert initierede variabler eller fejl i, hvordan du fortalte applikationen at udføre en opgave. Nogle opgaver udføres mere generelt i baggrunden end andre er.
Eksempelvis udskrives et dokument eller downloades ressourcer fra internettet, udføres almindeligvis i baggrunden, mens brugeren fortsætter med at arbejde med programmet i forgrunden.
-
Afslutning: Når brugeren (herunder systemkonti) fortæller programmet, er det ikke længere nødvendigt, går programmet igennem en shutdown-fase. I denne afslutningsfase lukker applikationen filer og udfører andre husholdningsgaver, der sikrer, at applikationen ikke efterlader et rod til operativsystemet.
De mest almindelige fejl, der kan opstå i denne fase, frigiver ikke ressourcer, som din ansøgning har brugt, og ikke gemmer data til disk. Selvfølgelig kan der opstå kodningsfejl til enhver tid, og denne operation er ingen undtagelse. Du kan fortælle applikationen at lukke fem filer, når kun fire af dem rent faktisk er åbne.
JRE vil præsentere de fleste runtime fejl, det opdager til dig som undtagelser. JRE vil dog ikke fange hver fejl i din ansøgning.Du skal også se på udgangen af din ansøgning for at afgøre, om output svarer til forventningerne til en given indgang.
Derudover er det vigtigt at se på de ressourcer, du bruger til at sikre, at de ikke er beskadiget på en eller anden måde. For eksempel skal du sikre dig, at alle data, du skal gemme i en fil, rent faktisk ender i filen, når din ansøgning lukkes.
Java 8 lægger større vægt på sikkerhed, hvilket betyder at du vil se flere SecurityException-tilfælde, mens du arbejder med din ansøgning.
Hvis du ser en stigning i sikkerhedsundtagelser, betyder det ikke, at din kode er defekt, eller at Java 8 er fyldt med fejl - det betyder, at Java 8 automatisk lokaliserer og fortæller dig om problemer, der kan forårsage sikkerhedsproblemer, når folk bruger din applikation.
Dokumentationen SecurityException vises på Java. net. Selvfølgelig vil du gerne vide, hvad hele hubbub handler om.