AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Der Varianttyp und der Geschwindigkeitsverlust
Thema durchsuchen
Ansicht
Themen-Optionen

Der Varianttyp und der Geschwindigkeitsverlust

Ein Thema von TheMiller · begonnen am 16. Jan 2010 · letzter Beitrag vom 16. Jan 2010
Antwort Antwort
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#1

Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 16:39
Hallo,

ich habe eine kleine DB-Klasse und möchte jetzt eine Methode "Save" einbauen. Dieser möchte ich dann Objekte verschiedener Art übergeben können. Deswegen sollte die Methode so aussehen:

Delphi-Quellcode:
procedure Save(DataObj: Variant);
function Read(id: Integer): Variant);
Nun lese ich überall, dass Variant "deutlich" langsamer sein soll. Ich würde jetzt gerne von euch wissen, wie "deutlich langsamer" das Lesen und Speichern sein wird? 1-2 Sekunden/ms etc.?

Außerdem hat's den Vorteil, dass ich mir dann eine Menge forward-Deklarationen sparen kann

Ich habe gesehen, dass das DavidInfoCenter (in C++ geschrieben) auch Variant benutzt. Und wenn ich die David API benutze, übergebe ich auch Daten an "Variant-Parameter". So viel langsamer ist es auch nun wieder nicht... Und wenn eben viele Daten in der DB vorhanden sind (2000 Adressen zB), dann dauerts halt eben ein bissl.

Was meint ihr?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 16:47
Zitat von DJ-SPM:
Dieser möchte ich dann Objekte verschiedener Art übergeben können.
Was für "Objekte"?

Nja, hinter dem Variant steckt nunmal ein größerer Record und ein "rießiges" Verwaltungsinsrumantarium,
mir Typumwandundkungen, Speicherverwaltung und Co.

Gegenüber direkter Parameterübergabe ist dieses natürlich aufwändiger und damit auch langsamer.
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#3

Re: Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 16:52
Ich leite mir ein paar Objekte für mein Programm vom Typ "TObject" ab. Ist nix großes. Diese Objekte stellen eigentlich nur Datensätze aus verschiedenen Tabellen dar (TKategorien, TArtikel, etc.)

Aber, da ich eh für jedes Objekt eine eigene Speichermethode erstellen muss, kann ich diese auch als "public" erstellen und sie nach folgendem Schema benennen:

Delphi-Quellcode:
//Writer
procedure SaveKategorie(DataObj: TKategorie);
procedure SaveArtikel(DataObj: TArtikel);
...
//Reader
function ReadKategorie(Id: Integer): TKategorie;
function ReadArtikel(Id: Integer): TArtikel;
Ist vielleicht besser, oder?
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

Re: Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 17:01
dann nimm doch TObject oder definiere dir einen Basisvorfahren für deine Klassen,
dann muß nichts umgewandelt werden ... ein Objektreferenz ist und bleibt so NUR eine Objektreferenz

so oder so wirst du ja intern eh per IS, bzw. AS die genaue Klasse prüfe müssen


Delphi-Quellcode:
procedure Save(DataObj: TObject);
begin
  if DataObj is TKategorie then begin
    ...
  end else if DataObj is TArtikel then begin
    ...

Delphi-Quellcode:
type TBaseObject = class end;
  TKategorie = class(TBaseObject)
    ...
  end;
  TArtikel = class(TBaseObject)
    ...
  end;

procedure Save(DataObj: TBaseObject);
begin
  if DataObj is TKategorie then begin
    ...
  end else if DataObj is TArtikel then begin
    ...
$2B or not $2B
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#5

Re: Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 17:06
Ok, das kann ich machen. Könnte ich nicht auch einfach die "ClassName"-Eigenschaft via "if" prüfen?

Macht das überhaupt so Sinn, was ich vorhabe? Ich wollte ein ähnliches Verhalten wie bei einer echten "Writer"-Klasse nachbauen. Diese Klasse gibt's wohl im Zusammenhang mit einem OOP-Framework.

Roter Kasten:

Danke für den Quelltext, das ist besser, als meine Idee mit dem ClassName.
  Mit Zitat antworten Zitat
alzaimar
(Moderator)

Registriert seit: 6. Mai 2005
Ort: Berlin
4.956 Beiträge
 
Delphi 2007 Enterprise
 
#6

Re: Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 17:12
Zitat von DJ-SPM:
Nun lese ich überall, dass Variant "deutlich" langsamer sein soll. Ich würde jetzt gerne von euch wissen, wie "deutlich langsamer" das Lesen und Speichern sein wird? 1-2 Sekunden/ms etc.?
Probiere es doch einfach mal aus.

Die reine Zuweisung eines Variants ist um den Faktor 5 (bei Double) bzw. 10 (bei Integer) langsamer, da bei jedem Zugriff auf den Variant zunächst der Typ geprüft und dann per case die konkrete Zuweisung bzw. Rechnung durchgeführt wird.

1 Mio Zugriffe dauern bei mir (Integer) 0.0011s, Double (0.0026) und bei einem Variant 0.0119s.

Ich halte in den weitaus meisten Fällen jedoch andere Teile im Code für die wahren Performancebremsen. Die Vorteile von Variants überwiegen die paar Promille Performanceeinbuße, die sich in der Realität ergeben.

Wenn Du natürlich intensive Berechnungen bzw. Iterationen durchführst, solltest Du auf Variants verzichten und native Datentypen verwenden.
"Wenn ist das Nunstruck git und Slotermeyer? Ja! Beiherhund das Oder die Flipperwaldt gersput!"
(Monty Python "Joke Warefare")
  Mit Zitat antworten Zitat
Elvis

Registriert seit: 25. Nov 2005
Ort: München
1.909 Beiträge
 
Delphi 2010 Professional
 
#7

Re: Der Varianttyp und der Geschwindigkeitsverlust

  Alt 16. Jan 2010, 18:44
Was du vorhast ist schon passiert, und auch wesentlich flexibler als das was dir vorschwebte.
Das ganze nennt sich Object-Persistence-Framework und es gibt sogar eins für Delphi: http://tiopf.sourceforge.net/
Robert Giesecke
I’m a great believer in “Occam’s Razor,” the principle which says:
“If you say something complicated, I’ll slit your throat.”
  Mit Zitat antworten Zitat
Antwort Antwort


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 04:11 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