Hovedprogramklasser er klasser som aktiveres når programmer starter opp og som initialiserer og kontrollerer/koordinerer de andre objekter i applikasjonen.

Sett utenifra kan en se på hovedprogramklasser som tjenesteorienterte, siden de ofte inneholder spesifikke metoder som kalles på bestemte tidspunkt, f.eks. ved oppstart og avslutning av applikasjonen og ved andre vesentlige hendelser. Akkurat hvilke metoder dette er, er avhengig av typen applikasjon og systemet som applikasjonen er bygget for. Eksempler kan være:

  • Enkle java-programmer: Metoden som kalles er ikke en vanlig instansmetode som trenger et objekt, men en metode med signaturen public static void main(String[] args). Denne instansierer det egentlige hovedprogramobjektet og kaller metoder som init() og run() (se eksempel nedenfor).
  • Applets (Java-app'er integrert i nettsider): Klassen er en Applet og metodene som kalles er init() (én gang ved lasting av siden), start() (ved oppstart) og stop() (ved avslutning).
  • Nettapplikasjoner: Klassen er av typen (arver fra) Servlet og metodene som kalles er init() (én gang ved initialisering), service(...) (kalles for hvert anrop, f.eks. get eller post) og destroy() (én gang ved avslutning). Standard-implementasjonen av service(...) kaller metoder som doGet(...) og doPost(...).
  • Eclipse-panel: Klassen er av typen IViewPart og metodene som kalles er init(...) (ved opprettelse), createPartControl(...) (lager panel-innholdet), setFocus() (når panelet er vist frem) og dispose() (når panelet lukkes).
  • Android-app'er:

Poenget er ikke at en Java-programmerer må lære seg alle varianter, men at en forstår at et hovedprogram inngår i et større system som oppretter en instans av hovedprogramklassen og kaller forhåndsdefinerte metoder på bestemte tidspunkt i applikasjonens livssyklus, typisk oppstart, aktivering og avslutning.

Dersom en lager enkle Java-applikasjoner av den første typen, så har ingen så klare regler som følger dette mønsteret, men det er en god idé fordi det gjør applikasjonen ryddigere og lettere å gjøre om til andre typer senere. Anta f.eks. at en skal lage en enkel kalkulator som skal styres med enkel tekstinput. Kalkulator-logikken håndteres av et tjenesteorientert objekt som brukes av hovedprogrammet på ulike måter avhengig av hva brukeren gjør. Vi velger å la hovedprogrammet ha to metoder, init() har ansvaret for initialisering dvs. å opprette kalkulator-objektet, og run() har ansvaret for hovedløkka som leser inn input fra brukeren og kaller riktig metode på kalkulator-objektet. Koden til CalculatorProgram er vist under til venstre, med et klassediagram til høyre, hvor også Calculator-klassen er med.

public class CalculatorProgram {

	private Calculator calculator;

	void init() {
		calculator = new Calculator();
	}

	void run() {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNextLine()) {
            String line = scanner.nextLine();
            if (line == null || line.trim().length() == 0) {
                System.err.println(calc1);
                break;
            }
			double arg = 0.0, result = 0.0;
			char firstChar = line.charAt(0);
			if (Character.isDigit(firstChar)) {
				arg = Double.valueOf(line);
			else {
				arg = Double.valueOf(line.substring(1)));
			}
			if (Character.isDigit(firstChar)) {
				result = calculator.setValue(arg);
			} else if (firstChar == '+') {
				result = calculator.add(arg);
			} else if (firstChar == '-') {
				result = calculator.subtract(arg);
			} else if (firstChar == '*') {
				result = calculator.multiply(arg);
			} else if (firstChar == '/') {
				result = calculator.divide(arg);
			}
		}
		System.out.println(result);
	}

	public static void main(String[] args) {
		CalculatorProgram calculatorProgram = new CalculatorProgram();
		calculatorProgram.init();
		calculatorProgram.run();
	}
}
CalculatorPrograminit()run()Calculatordouble valuedouble getValue()void setValue(double)double add(double)double subtract(double)double multiply(double)double divide(double)calculator

Som utforming av hovedprogramklasse har koden to viktige poeng:

  • Koden forutsetter at init() kalles før run(), og dette kan sies å være hovedprogramobjektets livssyklus.
  • En trenger strengt tatt ikke en egen init()-metode, men det er ryddig med en tydelig oppdeling i initialisering og utførelse.
ObjekttilstandsdiagramSekvensdiagram

 

 

CalculatorProgramCalculatorProgramCalculatorvalue = 0.0CalculatorProgramCalculatorvalue = 0.0init()calculatorrun()calculator

 

 

mainmainUserUserCalculatorProgramCalculatorProgramCalculatorCalculatorinit()run()"1.0"setValue(1.0)"1.0""+2.0"add(2.0)"3.0""*3.0"multiply(3.0)"9.0"

 

 

 

 

  • No labels