AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Entscheidungen treffen, if then else oder case (schneller)
Thema durchsuchen
Ansicht
Themen-Optionen

Entscheidungen treffen, if then else oder case (schneller)

Ein Thema von Christian18 · begonnen am 8. Jul 2004 · letzter Beitrag vom 9. Jul 2004
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von Steve
Steve

Registriert seit: 2. Mär 2004
Ort: Würzburg
730 Beiträge
 
Delphi 2006 Personal
 
#11

Re: Entscheidungen treffen, if then else oder case (schnelle

  Alt 9. Jul 2004, 00:03
ok, "einmal" falsch, zugegeben, aber Case prüft aber nur solange, bis eine Übereinstimmung gefunden wurde.. case is nevertheless schneller oder so.. ansonsten den anderen link anschauen... wird schon stimmen.. bin nicht so gut in beggründungen, ich weiss es einfach

Stephan
Stephan B.
Wer andern eine Grube gräbt ist Bauarbeiter!
Wer im Glashaus sitzt, sollte sich lieber im Dunkeln ausziehen!
Außerdem dieser Satz kein Verb...
  Mit Zitat antworten Zitat
Christian Seehase
(Co-Admin)

Registriert seit: 29. Mai 2002
Ort: Hamburg
11.119 Beiträge
 
Delphi 11 Alexandria
 
#12

Re: Entscheidungen treffen, if then else oder case (schnelle

  Alt 9. Jul 2004, 01:47
Moin Chewie,

Zitat von Chewie:
Und die Erköärung, warum case schneller ist als if gibt es hier.
Dabei hast Du nur eine Sache vergessen, nämlich die Prüfung, wie eine vergleichbare if/then/else Struktur aussieht.
Hier würde der Compiler zwar nicht mit sub/dec arbeiten, aber mit cmp, und ansonsten sähe der Rest ziemlich gleich aus.
Da die hier verwendeten Versionen von sub, dec und cmp gleichviel Takte benötigen, dürfte man für keine der Beiden Varianten (if/case) einen Zeitvorteil feststellen.
(dec wird bei Case verwendet, wenn die Werte aufeinander folgen).

Was allerdings in jedem Falle für Case spricht ist die Übersichtlich- und Wartbarkeit.
Tschüss Chris
Die drei Feinde des Programmierers: Sonne, Frischluft und dieses unerträgliche Gebrüll der Vögel.
Der Klügere gibt solange nach bis er der Dumme ist
  Mit Zitat antworten Zitat
NicoDE
(Gast)

n/a Beiträge
 
#13

Re: Entscheidungen treffen, if then else oder case (schnelle

  Alt 9. Jul 2004, 03:10
Zitat von Christian Seehase:
Was allerdings in jedem Falle für Case spricht ist die Übersichtlich- und Wartbarkeit.
Zudem werden bei längeren Folgen (x,x+1,x+2,...) von vielen Compilern Jump-Tables generiert (weiß nicht ob, bei welchen Einstellungen und ab welcher Version der Delphi-Compiler diese Optimierung benutzt).

Wenn es nur um die Performance geht, dann sollte man auch die Eingabedaten kennen. Wenn in 95% der Fälle nur ein Wert vorkommt, dann kann es ratsam sein diesen per if-Bedingung zu behandeln und den Rest per case-Konstrukt.


Gruss Nico
  Mit Zitat antworten Zitat
Robert Marquardt
(Gast)

n/a Beiträge
 
#14

Re: Entscheidungen treffen, if then else oder case (schnelle

  Alt 9. Jul 2004, 08:49
Ein case ist schneller, da es im Idealfall wirklich nur einen Test durchfuehrt.
Der Trick besteht darin eine Sprungtabelle zu implementieren, falls die case labels den Wertebereich
des Typs hinreichend fuellen.
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 08:31 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz