AGB  ·  Datenschutz  ·  Impressum  







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

Class in DLL verwenden

Ein Thema von little_budda · begonnen am 16. Aug 2012 · letzter Beitrag vom 17. Aug 2012
Antwort Antwort
Benutzerbild von little_budda
little_budda

Registriert seit: 5. Mai 2006
Ort: Velbert
246 Beiträge
 
Delphi 2006 Professional
 
#1

Class in DLL verwenden

  Alt 16. Aug 2012, 21:04
Delphi-Version: 2007
Hallo.

Ich versuche gerade Code von meiner Anwendung in eine DLL zu verfrachten.
Es ist meine erste DLL.
Ich habe daa Tutorial von Assarbad gelesen und fand die Iddee ganz velockend.

Nun zu meinem Problem.

Ich möchte einen Typ der Klasse TDataModule verwenden.
Meine Deklaration sieht bisher so aus

Delphi-Quellcode:
library wsatools;

uses Windows, ShellAPI, Messages, Classes, SysUtils, Graphics, Controls,
      StdCtrls, ComCtrls, DB, ExtCtrls, XMLDoc, XMLIntf, DBTables, ADODB,
      ...

type
  TDataModule2 = class(TDataModule)
    Table1ZEIT: TStringField;
    Table1QUELLE: TStringField;
    Table1ZsLen: TStringField;
    Table1MNR: TStringField;
    Table1Spez: TStringField;
    Table1ZUSTAND: TStringField;
    Table1ZSINFO: TStringField;
    DataSource1: TDataSource;
    Table1: TTable;
    Table1IDX: TStringField;
    ADOConnectionTexte: TADOConnection;
    ADOQueryTexte: TADOQuery;

    procedure Table1ZEITGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1ZSINFOGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1QUELLEGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1SpezGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1ZUSTANDGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1ZsLenGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1MNRGetText(Sender: TField; var Text: String; DisplayText: Boolean);
    procedure Table1IDXGetText(Sender: TField; var Text: String; DisplayText: Boolean);
end;
Als Variable habe ich angelegt
Delphi-Quellcode:
var
  ...
  DataModule2: TDataModule2;
Wenn ich jetzt darauf zugreifen möchte bekomme ich immer eine Exeption weil "DataModule2" nil ist.
Delphi-Quellcode:
function ExtractArchiveContentToTable (fullArchivePath : string) : integer;
var ...
begin
  DataModule2.Table1.Active := FALSE;
  DataModule2.Table1.Tablename := ExtractFileName(fullArchivePath);
  DataModule2.Table1.DatabaseName := ExtractFileDir(fullArchivePath);
  ...
Muss ich da noch einen Konstruktor oder ähnliches aufrufen?
Warum klappt das in einer WinForms Anwendung?



Vielleicht hat ja jemand einen Tipp für mich.
Gruß Holger.
Holger
Glück findet sich nicht im Code
Gefahren werden ist nur solange schön wie man selbst nicht lenken möchte ...
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Class in DLL verwenden

  Alt 17. Aug 2012, 00:12
Muss ich da noch einen Konstruktor oder ähnliches aufrufen?
Warum klappt das in einer WinForms Anwendung?
Natürlich?

Willst du auf ein Objekt der Klasse zugreifen, dann mußt du erstmal ein instanziertes Objekt dieser Klasse erstellen, was man irdentwo mit Create macht.

Grundsätzlich ist die Vorgehensweise in DLL und EXE (VCL, NonVCL oder Konsole) die Selbe.

PS: Wenn du eine Form oder DataModul erstellst, dann kann man die VCL in einem VCL-Projekt (neuerdings auch FMX statt VCL) dazu bringen diese Instanzen "automatisch" erstellen zu lassen, welches standardmäßig "aktiviert" wird, wenn man diese Units automatisch generieren läßt.
siehe Projekt-Optionen > Formulare

bzw. siehe Projekt-Datei (DPR), denn da werden letztendlich diese Instanten erstellt. Siehe Application.CreateForm(...) , worin das Create aufgerufen wird.


Du mußt also letzendlich deine Instanz des DataModuls irgendwo "selbst" erstellen.
> über eine Initialize-Prozedur, welche deine EXE anfangs erstmal aufrufen muß, bevor sie due Funktionen der DLL nutzen darf
> im Initialization-Abschnitt einer Unit (in Finalization natürlich wieder freigeben)
> in einem Class-Constructor der Klasse (ist das "Gleiche" wie Initialization/Finalization)
> im Begin-End-Bereich des DLL-Projekts (DPR), aber dort fehlt dann die Freigabe-Stelle der Instanz



PS: Das automatische Generieren aller Forms/DataModule ist auch nicht immer das Wahre.
Stell dir mal vor Delphi oder MS Word würde alle Fenster immer gleich bei Programmstart erstellen, dann bräuchten diese ewig zum Starten und würden immer extrem Arbeitsspeicher belegen, was vorallem dann sinnlos ist, wenn etwas selten verwendet wird ... Darum erstellt man da viele Vormulare "manuell" erst dann, wenn sie benötigt werden und gibt sie danach gleich wieder frei.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests

Geändert von himitsu (17. Aug 2012 um 00:15 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von little_budda
little_budda

Registriert seit: 5. Mai 2006
Ort: Velbert
246 Beiträge
 
Delphi 2006 Professional
 
#3

AW: Class in DLL verwenden

  Alt 17. Aug 2012, 08:56
Super, danke dir.
Nachdem ich das Problem mit "CoInitalize" noch gelöst habe,
klappt es hervorragend.

Ich habe in meiner DLL dazu noch eine "InitDLL" und eine "FreeDLL" Procedure angelegt.
Delphi-Quellcode:
uses
...
  ActiveX,
...

procedure InitDLL(window: Cardinal);
begin
  _hwnd := window;
  CoInitialize(nil);
  Application.CreateForm(TDataModule2, DataModule2);
end;


procedure FreeDLL(window: Cardinal);
begin
  CoUnInitialize();
end;
Holger
Glück findet sich nicht im Code
Gefahren werden ist nur solange schön wie man selbst nicht lenken möchte ...
  Mit Zitat antworten Zitat
Benutzerbild von sx2008
sx2008

Registriert seit: 16. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#4

AW: Class in DLL verwenden

  Alt 17. Aug 2012, 11:11
Teile der VCL werden doppelt vorhanden sein: zum Einen im Hauptprogramm und zum Anderen in der DLL.
Die EXE, die keine DLL verwendet wird also kleiner sein als die Summe der neuen EXE + DLL.

Deine EXE + DLL Lösung hat eigentlich nur Nachteile:
* grösser, benötigt mehr Resourcen
* schwieriger zu Debuggen
* meist höhere Ladezeit
* Probleme bei der Verarbeitung von Exceptions, da es die Exception Klassen nun zweimal gibt
* Probleme beim Updaten - es gibt verschiedene Versionen von EXE und DLL;
will man auf Nummer Sicher gehen muss man Beides schicken
* Entwicklungszeit verlängert sich

Unter Delphi sollte man keine DLLs erzeugen, die Teile der VCL benützen um die beschriebenen Probleme zu vermeiden.
Kurzgesagt: DLLs sollten Non-VCL sein!
Delphi Packages vermeiden zwar einige der Probleme, allerdings entstehen neue Probleme.
Du musst nun nämlich die Standard - Packages mitliefern und auf dem Zielrechner installieren.
Dabei besteht immer die Gefahr, dass schon eine andere Anwendung diese Packages installiert hat.
Sollte diese andere Anwendung deinstalliert werden, könnten auch die Packages gelöscht werden und deine Anwendung startet nicht mehr.
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Class in DLL verwenden

  Alt 17. Aug 2012, 11:26
Man muß diese Packages nicht unbedingt installieren.
Einfach ins Programmverzeichnis gelegt, gibt es keine Versionskonflikte mit anderen Programmen, da jeder seine eigenen Dateien/Versionen besitzt.
(OK, dafür kann es vorkommen, daß die RTL/VCL-Dateien eventuell doppelt/mehrfach im System rumschwirren, wenn man mehrere Programme mit Packages dort installiert hat)
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  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 06:45 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