AGB  ·  Datenschutz  ·  Impressum  







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

DLL Zugriff

Ein Thema von TheMiller · begonnen am 27. Aug 2005 · letzter Beitrag vom 30. Aug 2005
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von sniper_w
sniper_w

Registriert seit: 12. Dez 2004
Ort: Wien, Österriech
893 Beiträge
 
Delphi 6 Enterprise
 
#11

Re: DLL Zugriff

  Alt 27. Aug 2005, 23:04
Zitat:
Täusche ich mich, oder ist ein Windows-Handle nichts anderes als ein Zeiger?
Mag sein, ich denke eher nicht. Sollte es ein zeiger sein, hat man nicht viel davon, wie soll man es dereferenzieren.
Katura Haris
Es (ein gutes Wort) ist wie ein guter Baum, dessen Wurzel fest ist und dessen Zweige in den Himmel reichen.
  Mit Zitat antworten Zitat
Olli
(Gast)

n/a Beiträge
 
#12

Re: DLL Zugriff

  Alt 27. Aug 2005, 23:12
Zitat von sniper_w:
Zitat:
Täusche ich mich, oder ist ein Windows-Handle nichts anderes als ein Zeiger?
Mag sein, ich denke eher nicht. Sollte es ein zeiger sein, hat man nicht viel davon, wie soll man es dereferenzieren.
Nein, es ist kein Zeiger. Handles sind "Indeces" in die Handletabelle - und dort gibt es dann Pointer auf die Objekte und Zugriffsmasken. Lustigerweise habe ich darüber heute einen Artikel geschrieben *g*
So ist es zumindest für Dateien. Ob es für Fenster auch Pointer in der Handletabelle sind, weiß ich leider nicht mit Bestimmtheit. Bei Dateien, Threads, Prozessen und so weiter ist es wie von mir beschrieben.
  Mit Zitat antworten Zitat
tigerman33

Registriert seit: 30. Jul 2005
Ort: München
423 Beiträge
 
Delphi 2005 Professional
 
#13

Re: DLL Zugriff

  Alt 28. Aug 2005, 09:45
Kann man sich das dann so vorstellen, dass ein Handle quasi die Telefonnummer des Zeigers ist.

Windows hat dann ein Telefonbuch und kann rausfinden, wo welches Handle sich im Speicher rumtreibt.(Oder besser gesagt, welches Objekt (jetzt mal nicht im OOP-Sinn) mit einem bestimmten Handle.)

?
Christian
  Mit Zitat antworten Zitat
Olli
(Gast)

n/a Beiträge
 
#14

Re: DLL Zugriff

  Alt 28. Aug 2005, 10:57
Zitat von tigerman33:
Kann man sich das dann so vorstellen, dass ein Handle quasi die Telefonnummer des Zeigers ist.

Windows hat dann ein Telefonbuch und kann rausfinden, wo welches Handle sich im Speicher rumtreibt.(Oder besser gesagt, welches Objekt (jetzt mal nicht im OOP-Sinn) mit einem bestimmten Handle.)
Jupp, so ungefähr ist das. Da der Artikel für ein bekanntes Magazin aus GB ist, hier mal der kurze Auszug, aber eben in Englisch:
Zitat:
All of the handles a process can own – which are a whopping 16 million, starting with Windows 2000 – are basically only indexes into a so-called handle-table. This handle table exists on a per-process basis and is maintained by the object manager. The entry of a handle-table contains the pointer to the object body and the access mask which was used to obtain the handle (e.g. GENERIC_READ, GENERIC_WRITE). This allows the object manager to check the security constraints for any handle upon access and consequently to allow or deny access to the underlying object.

Why are handles needed if they are anyway only pointers to the real objects? Well, first of all any driver writer knows that user-mode code is evil code. That is why security restrictions only apply to user-mode code. Basically any kernel-mode component such as drivers can access objects without such restrictions via their pointer. Taking this into account means that giving user-mode code direct unrestricted access to an object’s pointer would be simply insane from the security perspective. Furthermore the user-mode code may put own restrictions on how it wants to access the object. For example it could open a file in read-only mode. So, giving user-mode code unrestricted access to an object is inappropriate again, because such restrictions apply to the handle of an object but not to the pointer of the object - to which the handle is an index.
(Das ist noch nicht die Endfassung, könnte also dann anders in The Delphi Magazine erscheinen! Dieser Teil stammt aus meiner "Feder" und zwar von gestern, weshalb ich keine urheberrechtlichen Probleme sehe )
  Mit Zitat antworten Zitat
tigerman33

Registriert seit: 30. Jul 2005
Ort: München
423 Beiträge
 
Delphi 2005 Professional
 
#15

Re: DLL Zugriff

  Alt 28. Aug 2005, 19:42
Nicht schlecht, Herr Specht (dumme Sprüche die 257.) Gut erklärt!
Christian
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

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

Re: DLL Zugriff

  Alt 29. Aug 2005, 23:50
So,

habe das jetzt getestet:

Delphi-Quellcode:
DLL:

library filllist;

uses
  SysUtils,
  Classes,
  ComCtrls, dialogs;

{$R *.res}

procedure test; stdcall;
var
  lst:pointer;
begin
  TListView(lst).Hide;
end;

exports
  test;

begin
end.
Delphi-Quellcode:
EXE:

procedure test; stdcall; external 'filllist.dll';

procedure TForm1.Button1Click(Sender: TObject);
var
  lst:TListView;
begin
  lst:=ListView1;
  test;
end;

end.
Wenn ich jetzt in der Exe auf Button1 klicke, wird die MainForm "versteckt". Wie kann ich die ListView(lst) an Form1 "anhängen?
Bisheriger Nutzername "DJ-SPM"
  Mit Zitat antworten Zitat
tigerman33

Registriert seit: 30. Jul 2005
Ort: München
423 Beiträge
 
Delphi 2005 Professional
 
#17

Re: DLL Zugriff

  Alt 30. Aug 2005, 08:45
Ich bin mir zwar nicht ganz sicher was du mit "anhängen" meinst, aber so wie du es da geschrieben hast kann es nicht gehen. Du musst der Prozedur Test schon die Adresse (oder halt das handle) der ListView mitteilen. Denn der von dir deklarierte Zeiger lst in Test ist ja nur eine lokale Variable und zeigt momentan halt irgendwo ins Daten-Nirwana. Zu dem in der Echse deklarierten lst hat er ja überhaupt keine "Verbindung". Übergib das doch (z.B.) als Parameter:

Delphi-Quellcode:
procedure test(Lst: TListView); stdcall;
begin
  lst.Hide;
end;

und dann


procedure TForm1.Button1Click(Sender: TObject);
begin
  test(ListView1);
end;
Christian
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

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

Re: DLL Zugriff

  Alt 30. Aug 2005, 13:00
Schwupps - weg isse!!

Funzt prima!!!

Danke
Bisheriger Nutzername "DJ-SPM"
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 14:21 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