AGB  ·  Datenschutz  ·  Impressum  







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

COM-Objekt und Pointer-Type

Ein Thema von ralfiii · begonnen am 22. Apr 2008 · letzter Beitrag vom 22. Apr 2008
Antwort Antwort
Benutzerbild von ralfiii
ralfiii

Registriert seit: 30. Mai 2007
489 Beiträge
 
Delphi 2010 Professional
 
#1

COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 13:59
Hallo!

Ich muss an ein Com-Objekt einen Pointer auf Daten übergeben.
Delphi macht aus der Definition aber immer einen var-Pointer, in der TLB scheint es richtig zu sein.

Wenn ich ein Com-Interface definiere und einen Parameter mit "void *" angeben und die erzeugte DLL mit einem TLB-Viewer anschau sehe ich:
Delphi-Quellcode:
HRESULT WriteData(
                [in] long SampleNum,
                [in] void* PData);
Das scheint also zu passen. Wenn ich in den Delphi-Settings von IDL auf Pascal umschalte, sehe ich "Pointer" - passt also. (Aber eintippen kann ich "Pointer" so nicht, das verweigert der TypeLib-Editor).

In der ..._TLB.pas Datei steht an solchen Stellen dann aber immer
  var PData: Pointer Das "var" ist da falsch. Das ist ja ein Pointer auf einen Pointer, ist dann aber nicht in der Variable drin.
Da müsste korrekterweise stehen:
    procedure WriteData(MyNumber: Integer; MyPointer: Pointer); safecall; Wie krieg ich das am besten hin? Einen anderen Datentypen wie z.B. integer nehmen und casten find ich unintuitiv (wenn man die Interface-Definition liest und ich sehe "PData : integer" wüsste ich nicht auf Anhieb was da zu tun ist).

Gibt's vernünftig unterstützte COM-Pointertypen?

Danke.
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 16:35
Bei COM müssen ja Daten teilweise über Prozessgrenzen hinweg transportiert werden.
Und da wird es bei einem Zeiger ja sehr problematisch, da dieser Zeiger in einem anderen Prozess auf etwas völlig anderes zeigt.
Man kann deshalb nur Datenblöcke über Prozessgrenzen tranportieren.
Wenn das COM-System weiss, dass die Daten bei Adresse XY beginnen und sagen wir 500 Bytes lang sind, dann kann man ja diesen Speicherblock kopieren und/oder im Zielprozess einblenden.
Bei DCOM werden die Daten übers Netzwerk verschickt.

Deshalb verpackt man binäre Daten häufig in einem Variant-Array vom Typ varByte.
Delphi-Quellcode:
function VarByteArrayCreate(const Data; len:Integer):Variant;
var
   vdata : Pointer;
begin
   if len > 0 then
   begin
      Result := VarArrayCreate([0, len-1], varByte);
      vdata := VarArrayLock(Result);
      try
         Move(Data, vdata^, len);
      finally
         VarArrayUnlock(Result);
      end;
   end
   else
      Result := Null;
end;
Man erkennt an deinem Sourcecode nicht genau, was du tun möchtest; irgendetwas mit Samples.
Wenn du jedes einzelne Sample über eine COM Funktion schicken möchtest, dann musst du etwas umdenken
und stattdessen den gesamten Samplebuffer in einem OleVariant verpackt versenden.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von ralfiii
ralfiii

Registriert seit: 30. Mai 2007
489 Beiträge
 
Delphi 2010 Professional
 
#3

Re: COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 16:44
Zitat von shmia:
Bei COM müssen ja Daten teilweise über Prozessgrenzen hinweg transportiert werden.
Stimmt schon, aber in meinem Fall sind es ausschliesslich In-Process Com-Objekte, und dafür wirklich riesige Datenmengen die ich auf keinen Fall umkopieren möchte.
Daher meine Frage nach einem einfachen Pointer-Typen.

Wenn ich PChar nehme, macht da Delphi irgendeinen Compiler-Magic der mir Probleme bereiten könnte, wenn da gar kein PChar daherkommt, sondern ich das einfach als normalen Pointer missbrauche?

Sprich, in der Methode:

Delphi-Quellcode:
procedure WriteData(MyNumber: Integer; PData_ : PChar); safecall;
var PData : Pointer;
begin
     PDate:=PData_;
     ... und hier dann normal weiterarbeiten...
Würde das gehen?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.207 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 16:53
Zitat von ralfiii:
Zitat von shmia:
Bei COM müssen ja Daten teilweise über Prozessgrenzen hinweg transportiert werden.
Stimmt schon, aber in meinem Fall sind es ausschliesslich In-Process Com-Objekte, und dafür wirklich riesige Datenmengen die ich auf keinen Fall umkopieren möchte.
Daher meine Frage nach einem einfachen Pointer-Typen.
Wieso verwendest du überhaupt COM?
Bei Delphi ist man mit COM etwas eingeschränkt auf den Standard-Marshaller von Windows. Und wenn dieser das entsprechende nicht kann, kann es Delphi auch. Hierzu müßtest du z.B. Visual C++ nehmen da du hier "einfach" deinen eigenen Marshaler schreiben kannst.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von ralfiii
ralfiii

Registriert seit: 30. Mai 2007
489 Beiträge
 
Delphi 2010 Professional
 
#5

Re: COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 18:25
Zitat von Bernhard Geyer:
Wieso verwendest du überhaupt COM?
Schien mir eine gute Idee, weil man die Anwendung so gut Script-steuern kann und auch in anderen Sprachen recht gemütlich Plugins für unsere Anwendung schreiben kann.
Es funktioniert ja auch prächtig, nur konvertiert Delphi die TLBs falsch. Wie gesagt, statt "Pointer" steht da "var Pointer". Wenn man das händisch korrigiert läuft alles prima. Nur blöderweise verhunzt Delphi die _TLB.pas - Files dann immer sobald man was mit dem Typelib-Editor macht.
  Mit Zitat antworten Zitat
Dezipaitor

Registriert seit: 14. Apr 2003
Ort: Stuttgart
1.701 Beiträge
 
Delphi 7 Professional
 
#6

Re: COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 20:24
Du kannst ohne Probleme PChar verwenden. Es ist einfach nur ein typisierter Pointer. Natürlich solltest du kommentieren, um was es sich wirklich bei den Daten handelt.
Meist sollte man zum Pointer auch noch eine Größenangabe ansetzen, falls die Daten dynamisch sind. Alles andere könnte auch Bufferoverflows ergeben.

Für OutOfProcess gibt es die Möglichkeit von IStream. Hier kann man ganz einfach beliebige Daten marshallen lassen.
Christian
Windows, Tokens, Access Control List, Dateisicherheit, Desktop, Vista Elevation?
Goto: JEDI API LIB & Windows Security Code Library (JWSCL)
  Mit Zitat antworten Zitat
Benutzerbild von ralfiii
ralfiii

Registriert seit: 30. Mai 2007
489 Beiträge
 
Delphi 2010 Professional
 
#7

Re: COM-Objekt und Pointer-Type

  Alt 22. Apr 2008, 21:38
Zitat von Dezipaitor:
Du kannst ohne Probleme PChar verwenden. Es ist einfach nur ein typisierter Pointer. Natürlich solltest du kommentieren, um was es sich wirklich bei den Daten handelt.
Meist sollte man zum Pointer auch noch eine Größenangabe ansetzen, falls die Daten dynamisch sind. Alles andere könnte auch Bufferoverflows ergeben.
Super, danke!
Werd' ich gleich machen, dann hat die Quälerei endlich ein Ende...
P.S.: Das mit der Grössenangabe mach ich sowieso, da die Plugins manchmal den Speicher wieder freigeben müssen.
  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 08:08 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