AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Algorithmen, Datenstrukturen und Klassendesign Klasse implementiert ein Interface weniger, höherer Speicherverbrauch
Thema durchsuchen
Ansicht
Themen-Optionen

Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

Ein Thema von freimatz · begonnen am 20. Dez 2023 · letzter Beitrag vom 3. Jan 2024
Antwort Antwort
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
10.054 Beiträge
 
Delphi 12 Athens
 
#1

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 20. Dez 2023, 13:56
Hast du wirklich nur in der Klassendefinition das Interface entfernt? Und wenn du es wieder hinzufügt, ist der Speicherverbrauch wieder normal?

Um welche Werte reden wir denn hier? Wie oft liegt die Klasse im Speicher und wie hoch sind dabei die Unterschiede im Verbrauch in absoluten Werten?
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
freimatz

Registriert seit: 20. Mai 2010
1.513 Beiträge
 
Delphi 11 Alexandria
 
#2

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 22. Dez 2023, 06:43
Hallo,
ja ich habe nur diese id und das Komma entfernt. Die Werte sind so bei 3%. Das ist nicht recht viel. Dafür dass diese Klasse eine von 24 ist und nur dieses interface weg bekommt recht viel. Wie oft das tatsächlich ist und wie die absoluten Werte sind kann ich nicht sagen. Das genauer zu untersuchen war mir bislang zuviel Aufwand.
Ein Fall ist mir noch eingefallen: if not Supports(Klasse, IBla4) then ProduziereSpeicherLeck();
Solche "if not Supports" kommen tatsächlich vor. Sie dürften jedoch nie aufgerufen werden und führen nach then zu einem raise einer Exception.
Nun denn, mal schauen wie ich da weiter mache. Auf jeden Fall nicht mehr dieses Jahr
Danke für Eure Denkanstösse.
  Mit Zitat antworten Zitat
Blup

Registriert seit: 7. Aug 2008
Ort: Brandenburg
1.493 Beiträge
 
Delphi 12 Athens
 
#3

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 22. Dez 2023, 11:41
Mehr Speicherverbrauch 3% von was? Der gesamten Anwendung, der Klasse oder ...?
Unterstützt TVorfahr bereits IBla4?
Unterstützt ein Nachfahre von TBla IBLa4?

Jeder Nachfahren von TBLa der zusätzlich IBLa4 unterstützen, braucht eine eigene Liste von Interfaces.
Stimmt die Liste mit der von TBLa überein, wird vieleicht die selbe Liste verwendet.
Das könnte zumindest einen kleinen Unterschied im Speicherbedarf für die Klassen erklären.
  Mit Zitat antworten Zitat
Benutzerbild von jaenicke
jaenicke

Registriert seit: 10. Jun 2003
Ort: Berlin
10.054 Beiträge
 
Delphi 12 Athens
 
#4

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 22. Dez 2023, 14:51
Jeder Nachfahren von TBLa der zusätzlich IBLa4 unterstützen, braucht eine eigene Liste von Interfaces.
Stimmt die Liste mit der von TBLa überein, wird vieleicht die selbe Liste verwendet.
Ja, an so etwas habe ich auch gedacht. Allerdings fällt das normalerweise kaum ins Gewicht, weshalb ich nach genaueren Daten zum Speicherverbrauch gefragt hatte. Es wäre schon wichtig diesen Speichermehrverbrauch auf die einzelne Instanz umrechnen zu können.

Wenn es z.B. 100.000 Nachfahr-Objekte gibt, macht das einiges aus. Ist es nur eine einzelne Instanz, würde das nicht passen.
Sebastian Jänicke
AppCentral
  Mit Zitat antworten Zitat
rabatscher

Registriert seit: 13. Dez 2007
Ort: Bruck an der Mur
77 Beiträge
 
#5

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 27. Dez 2023, 14:24
Also... soweit ich das sehe (bitte korrigieren, falls ich falsch liege.., wird für jedes Interface ein zusätzliches Feld im
Ojekt angelegt. (siehe TObject.InitInstance in system.pas) . D.h. Wenn das Interface
hinzugefügt wird, erhöht sich der Speicher dementsprechend um 4Byte pro angelegtes Ojekt.

Man kann sich den Speicherverbrauch einer Klasse/Objekt auch per "InstanceSize" anschauen....


Delphi-Quellcode:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  IIntf1 = interface
   ['{6AB3BE8C-8605-4ED6-97DA-CEED84E5B9F4}']
   procedure Test1;
  end;

  IIntf2 = interface
   ['{A2614303-1914-4BBE-9D38-D306EF36B14B}']
   procedure Test2;
  end;

type
  TObj1 = class(TInterfacedObject, IIntf1)
  public
    procedure Test1;
    procedure Test2;
  end;

type
  TObj2 = class(TInterfacedObject, IIntf1, IIntf2)
  public
    procedure Test1;
    procedure Test2;
  end;

type
  TForm1 = class(TForm)
    Button1: TButton;
    procedure Button1Click(Sender: TObject);
  private
    { Private-Deklarationen }
  public
    { Public-Deklarationen }
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

procedure TForm1.Button1Click(Sender: TObject);
var obj1 : TObj1;
    obj2 : TObj2;
begin
     obj1 := TObj1.Create;
     obj1.Test1;
     obj1.Free;

     obj2 := TObj2.Create;
     obj2.Test1;
     obj2.Free;
end;

{ TObj1 }

procedure TObj1.Test1;
begin
     ShowMessage('Obj1 size:' + IntToStr(InstanceSize));
end;

procedure TObj1.Test2;
begin
     ShowMessage('obj1 test2');
end;

{ TObj2 }

procedure TObj2.Test1;
begin
     ShowMessage('Obj2 size: ' + intToStr(InstanceSize));
end;

procedure TObj2.Test2;
begin
     ShowMessage('test2');
end;

end.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 27. Dez 2023, 14:32
Ein Interface zeigt auf eine Interfacetabelle, welche in der RTTI neben dem Objekt abgelegt wird, also ja, es kommt ein "Pointer" hinzu.
Ein Therapeut entspricht 1024 Gigapeut.
  Mit Zitat antworten Zitat
Benutzerbild von Mavarik
Mavarik

Registriert seit: 9. Feb 2006
Ort: Stolberg (Rhld)
4.164 Beiträge
 
Delphi 10.3 Rio
 
#7

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 31. Dez 2023, 10:37
Delphi-Quellcode:

procedure TForm1.Button1Click(Sender: TObject);
var obj1 : TObj1;
    obj2 : TObj2;
begin
     obj1 := TObj1.Create;
     obj1.Test1;
     obj1.Free;

     obj2 := TObj2.Create;
     obj2.Test1;
     obj2.Free;
end;
Ich hoffe das ist nur ein schnell runter getipptes Demo und nicht so wie Du TinterfacedObjects in Deinem Programm verwendest…

Obj1 und Obj2 müssen vom Interface type sein und natürlich nicht mit free freigegeben werden.

Mavarik
  Mit Zitat antworten Zitat
rabatscher

Registriert seit: 13. Dez 2007
Ort: Bruck an der Mur
77 Beiträge
 
#8

AW: Klasse implementiert ein Interface weniger, höherer Speicherverbrauch

  Alt 2. Jan 2024, 08:14
Natürlich ist das nur ein schnell runter getipptes Ding - und natürlich würde ich interfaces so nicht verwenden...
Die Mixtur kann schnell in die Hose gehen
Aber da ich hier ja nur in der "Objektwelt" bin muss ich ja das Ojbekt brav freigeben (solange ich die Interfaces nicht anrühre und
das RefCounting initiere ).
  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 07:37 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-2025 by Thomas Breitkreuz