AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi heruasfinden ob zahl Gerade oder ungerade ist
Thema durchsuchen
Ansicht
Themen-Optionen

heruasfinden ob zahl Gerade oder ungerade ist

Ein Thema von ferby · begonnen am 25. Aug 2004 · letzter Beitrag vom 24. Sep 2004
Antwort Antwort
Seite 2 von 3     12 3      
Benutzerbild von Stefan Hueg
Stefan Hueg

Registriert seit: 13. Jun 2004
Ort: Gießen
187 Beiträge
 
Delphi 2006 Professional
 
#11

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:01
Kann ich bestätigen,

Code:
if GanzeZahl and 1 = 1 then //ungerade
else; //gerade
ist wesentlich schneller (doppelt so schnell) wie die Mod-Methode.
Stefan Hueg
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#12

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:04
Kann jemand mal in den Sourcen gucken, wie es Delphi-Referenz durchsuchenOdd macht?
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#13

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:12
if Zahl and 1 <> 0 then ; entspricht dem Odd, und ist auch das schnellste.

if Zahl and 1 = 1 then ; beinhaltet in Assembler einen Vergleich eines Registers mit einer Zahl die im Speicher steht, somit wesentlich ineffizienter.

Nutze ODD() dafür ist es da, und auch optimiert.


if Zahl mod 2 <> 0 then ; ist in fakt identisch wie Odd(), kann also niemals langsammer sein.

Gruß Hagen

PS: Halbwissen ist schlechter als Unwissen.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#14

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:14
@Luckie
das geht wohl nicht ... wenn ich die Deklaration davon suchen laß, dann lande ich in der System.pasund da ist natürlich nicht's zufinden -.-

Aber es wird wohl so aussehn ^^
Delphi-Quellcode:
function Odd(X: Longint): Boolean;
  begin
    Result := Boolean(X and $01);
  end;

[ADD]
@negaH
meines ist schneller (der Vergleich mit 1 ist entfallen)

[EDIT]
sch*** Schreibfehler
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#15

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:18
Wieso? Wenn ich die Sourcen habe (Prof oder höher), dann sollte mnan es auch in der System.pas finden.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von Nothine
Nothine

Registriert seit: 3. Jul 2004
Ort: Mülheim an der Ruhr
198 Beiträge
 
Delphi 5 Enterprise
 
#16

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:21
Zitat von Luckie:
Wieso? Wenn ich die Sourcen habe (Prof oder höher), dann sollte mnan es auch in der System.pas finden.
außer es ist compiler-magic, was in diesem falle wohl zutreffen dürfte...
if ThisPost is senseless then
ThisPost.WasPostedBy := SomeoneElse();
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#17

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:21
nein wird es nicht, Odd() ist ein Compiler-Magic und muß direkt im Source anaylsiert werden. In den meisten Fällen wie eben

if Odd(Zahl) then ; ensteht ein Branch, ein bedingter Sprung in Assembler.

Delphi-Quellcode:
asm
  AND EAX,1
  JZ @NichtOdd


@NichtOdd:
end;
if Zahl and 1 = 1 then ; würde dagegen so aussehen

Delphi-Quellcode:
asm
   AND EAX,1
   CMP EAX,1
   JNE @NichtOdd

@NichtOdd:
end;
Odd() selber wird aber als Magic unterschiedlich nach Assembler umgesetzt, zB.

Result := Odd(Zahl); würde im besten Falle so aussehen

AND EAX,1 könnte aber auch so ausehen

Delphi-Quellcode:
AND EDX, 1
SETNZ AL
je nach Optimierung des Compiliers und den Vorrausetzung der benutzen Register.

Gruß hagen
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#18

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:23
Ui. Schon wieder was gelernt. Danke Hagen.
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Benutzerbild von negaH
negaH

Registriert seit: 25. Jun 2003
Ort: Thüringen
2.950 Beiträge
 
#19

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:25
Zitat:
@negaH
meines ist schneller (der Vergleich mit 1 ist entfallen)
nein ist es nicht,
1.) sagte ich schon das ich niemals bei solchen Boolschen Auswertungen es so schreiben würde

Delphi-Quellcode:
if Flag and 1 = 1 then;
if Flag and $80 = $80 then ;
sondern immer

Delphi-Quellcode:
if Flag and 1 <> 0 then ;
if Flag and $80 <> 0 then ;
weil ich eben weis das das Assemblertechnisch ein großer Unterschied ist, und

2.) vergisst du das du eine externe Funktion nutzt die einen CALL + RET usw. benötigt, Odd() selber benutzt ist ein Compiler-Magic den der Compiler abhängig von den Randbedinungen immer anders in Asssembler umsetzt.Der Compiler wählt dann in jedem Falle den optimlasten und effizientesten Assembler, ganz im Gegensatz zu deiner Funktion. Sie beschränkt in diesem Falle die Wahlfreiheit des Optimierers.

Gruß Hagen
  Mit Zitat antworten Zitat
Benutzerbild von Stefan Hueg
Stefan Hueg

Registriert seit: 13. Jun 2004
Ort: Gießen
187 Beiträge
 
Delphi 2006 Professional
 
#20

Re: heruasfinden ob zahl Gerade oder ungerade ist

  Alt 10. Sep 2004, 00:33
Zitat von negaH:
Zitat:
@negaH
meines ist schneller (der Vergleich mit 1 ist entfallen)
Gruß Hagen
Doch ist es, habe es bei 100.000.000 Vergleichen getestet, die Variante mit "if Zahl and 1 = 1" ist um den Faktor 2 schneller als die Variante "if Zahl mod 2 = 1".
Stefan Hueg
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


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 01:02 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz