AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Geschwindigkeit von Schleifen

Ein Thema von Dennis07 · begonnen am 10. Dez 2014 · letzter Beitrag vom 11. Dez 2014
Antwort Antwort
Seite 3 von 3     123   
Benutzerbild von himitsu
himitsu

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

AW: Geschwindigkeit von Schleifen

  Alt 10. Dez 2014, 15:57
Bei Schleifen mit sehr vielen Durchläufen und mit sehr wenig Code darin, fällt das schon auf, aber sonst sollte man sich bei Schleifen einfach auf deren Funktion/Verwendung beziehen.
$2B or not $2B

Geändert von himitsu (10. Dez 2014 um 16:30 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von p80286
p80286

Registriert seit: 28. Apr 2008
Ort: Stolberg (Rhl)
6.659 Beiträge
 
FreePascal / Lazarus
 
#22

AW: Geschwindigkeit von Schleifen

  Alt 10. Dez 2014, 16:21
War da nicht mal was, dass der Vergleich auf 0 schneller ist, als der Vergleich auf '<Variable>'?
Jain, beim Vergleich auf null kannst Du das Register gleich mit 0 vorbelegen und mußt Dir nicht erst einen Wert aus dem Speicher angeln.

Aber wenn mann nicht Zeitkritisch arbeitet ist das zu vernachlässigen.

Gruß
K-H
Programme gehorchen nicht Deinen Absichten sondern Deinen Anweisungen
R.E.D retired error detector
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.034 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#23

AW: Geschwindigkeit von Schleifen

  Alt 10. Dez 2014, 16:58
Interessant wirds eh erst dann, wenn man betrachtet, was innerhalb der Schleife geschieht.
Denn das entscheidet darüber wie ein Compiler entsprechende Optimierungen (z.B. loop unrolling) durchführen kann.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Insider2004
(Gast)

n/a Beiträge
 
#24

AW: Geschwindigkeit von Schleifen

  Alt 10. Dez 2014, 17:44
Verfalle nicht in den Optimierungswahn. Du verlierst Zeit ganz woanders. Z.B. in schwachsinnigen Programmstrukturen.
  Mit Zitat antworten Zitat
WM_CLOSE

Registriert seit: 12. Mai 2010
Ort: königsbronn
398 Beiträge
 
RAD-Studio 2009 Pro
 
#25

AW: Geschwindigkeit von Schleifen

  Alt 11. Dez 2014, 10:26
Man sollte auch nicht ganz vergessen, dass der Prozessor selbst auch noch eine Rolle spielt. Eine Assembleranweisung hat ja bei modernen Mikroprozessoren nicht immer die selbe Ausführungsgeschwindigkeit. Stichworte sind Pipelining, Out-of-order execution, Branch Prediction und Caching.
Der Vergleich mit 0 ist üblicherweise deshalb schneller, weil man keine Variable zusätzlich ins Register laden muss.

Einige Schlüsse kann man auch aus diesem Wikipedia Eintrag ziehen.

Insgesamt kann man aber sagen, dass eine Optimierung auf Assemblerebene oder die Auswahl der "schnellsten" Schleife heute kaum noch nenneswerte Vorteile bringt.
Für rechenintensive Dinge ist heute eher Multithreading oder GPU processing angesagt. Für andere Dinge vielleicht ein intelligentes Caching oder ganz allgemeine Ablauf-Optimierungen.

PS: Solltet ihr neben den Intel Prozessoren auch andere targets haben, müsstet ihr die Optimierung sowieso für jeden Prozessortyp einzeln planen.
Delphi programming
  Mit Zitat antworten Zitat
OlafSt

Registriert seit: 2. Mär 2007
Ort: Hamburg
284 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#26

AW: Geschwindigkeit von Schleifen

  Alt 11. Dez 2014, 10:49
Das betrifft nicht nur den Unterschied zwischen Intel- und AMD-CPU. Bereits innerhalb der CPUs gibt es gravierende Unterschiede. So war damals z.B. der Aufschrei riesengroß, als die etablierte Pipelining-Technik des 80486 durch die veränderte Out-of-Order- und BP-Technik des Pentium ersetzt wurde.

Konsequenz daraus war, das manche Programme auf dem Pentium - trotz höherer Taktrate - langsamer liefen als auf einem 486. Die 486-Optimierung lief dem Design des Pentium schlicht "gegen den Strich".
  Mit Zitat antworten Zitat
Benutzerbild von TRomano
TRomano

Registriert seit: 24. Nov 2004
Ort: Düsseldorf
193 Beiträge
 
Delphi 11 Alexandria
 
#27

AW: Geschwindigkeit von Schleifen

  Alt 11. Dez 2014, 15:45
In hochoptimierten Routinen (purer Assembler in mathematischen Berechnungen mit millionenfacher Wiederholung z.B. Videokomprimierung o.ä.) macht das vielleicht Unterschiede, auch hier spielen unterschiedliche Implementierungen der Prozessorbefehle eine Rolle, aber auch nur, wenn man die einzelnen Takte zählt ... In einem Standard-Programm hat das nicht zu suchen, denn entscheidend ist was und wieviel in der Schleife passiert. Da ist (immer) Optimierungspotential vorhanden, vielleicht nicht bei zwei Additionen in einer Zeile ...
Thomas Forget
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 3 von 3     123   


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:03 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