AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Object-Pascal / Delphi-Language Delphi Funktionsdeklaration: Beste Vorgehensweise

Funktionsdeklaration: Beste Vorgehensweise

Offene Frage von "Luckie"
Ein Thema von Zend · begonnen am 12. Okt 2010 · letzter Beitrag vom 12. Okt 2010
Antwort Antwort
Zend

Registriert seit: 5. Mär 2010
Ort: Braunschweig
17 Beiträge
 
Delphi 7 Professional
 
#1

Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:00
Delphi-Version: 5
Hallo,

ich soll demnächst eine DLL schreiben die von einigen Tools anderer Programmierer aufgerufen wird und Informationen liefern muss.

Beispielsweise habe ich eine Funktion GetProjectPath() die den Namen eines Projektes übergeben bekommt und einen dazugehörigen Pfad ermitteln soll. Bsp:

Path = GetProjectPath("Mein Projekt") // Rückgabe: "C:/Tolle Projekte/Mein Project" Welche Vorgehensweise wäre die bessere:

Möglichkeit 1)

Die Funktion bekommt den Projektnamen als PChar übergeben und liefert den ermittelten Pfad als Rückgabewert.

function GetProjectPath(PrjName: PChar): PChar; Möglichkeit 2)
Die Funktion bekommt den Projektnamen als PChar übergeben und schreibt den Rückgabewert in einen zweiten übergebenen PChar.

procedure GetProjectPath(PrjName: PChar; Path: PChar);
Der Unterschied zwischen den beiden Möglichkeiten liegt meiner Meinung nach in der Speicherverwaltung:

Bei Methode 1 ist die Funktion GetProjectPath für die Speicheranforderung verantwortlich, während bei Methode 2 die aufrufende Funktion Speicher reservieren muss. Allerdings kann diese den Speicher vor dem Aufruf der Funktion gar nicht reservieren, weil diese nicht weiß wie groß der zurückgelieferte sein wird, kann aber vorsorglich mehr Speicher als dann tatsächlich benötigt (MAX_PATH) reservieren?

Habe ich das richtig erkannt? Zu welcher Methode würdet ihr mir raten?

Grüße
Zend
  Mit Zitat antworten Zitat
shmia

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

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:05
ich soll demnächst eine DLL schreiben die von einigen Tools anderer Programmierer aufgerufen wird und Informationen liefern muss
Welche Programmiersprachen?
Ich frage deshalb, weil ich hier eine ActiveX-DLL empfehlen würde.
Die Probleme mit der Übergabe von Strings wären damit erledigt.
Andreas
  Mit Zitat antworten Zitat
Zend

Registriert seit: 5. Mär 2010
Ort: Braunschweig
17 Beiträge
 
Delphi 7 Professional
 
#3

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:17
Hallo,

der Aufruf muss neben C und Delphi auch aus Python heraus erfolgen welches meines Wissens nach nicht mit ActiveX umgehen kann.

Grüße
Zend
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:22
Ansonsten über Interfaces und als Typen den WideString, Integer, Byte, ByteBool/LongBool/Boolean und Co.

in C++:
LongBool = BOOL
ich blaub ByteBol = bool (Boolean wäre nahezu kompatibel dazu, also soloange man nicht auf =True prüft )
Integer = int
Cardinal = uint
...
WideString = MSDN-Library durchsuchenSysAllocStringLen, SysReAllocStringLen, SysFreeString, SysStringLen ...

Somit wäre es zu C++ und Delphi kompatibel.
Garbage Collector ... Delphianer erzeugen keinen Müll, also brauchen sie auch keinen Müllsucher.
my Delphi wish list : BugReports/FeatureRequests
  Mit Zitat antworten Zitat
shmia

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

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:23
Allerdings kann diese den Speicher vor dem Aufruf der Funktion gar nicht reservieren, weil diese nicht weiß wie groß der zurückgelieferte sein wird, kann aber vorsorglich mehr Speicher als dann tatsächlich benötigt (MAX_PATH) reservieren?
Üblicherweise gibt der Aufrufer über einen weiteren Parameter mit, wieviel Speicherplatz er reserviert hat:
Delphi-Quellcode:
function GetProjectPath(PrjName: PChar; Path: PChar; PathSize:Integer):integer;


// so könnte der Aufruf aussehen:
var
  len : integer; // Länge des Ergebnisses
  path : string;
begin
  SetLength(path, 200 {MAX_PATH}); // Speicher reservieren
  len := GetProjectPath('Test', PChar(Path), Length(Path));
  if len < 0 then
    raise Exception.Create('Puffer für GetProjectPath zu klein');
  SetLength(path, len); // "path" auf tatsächliche Länge kürzen
Ziemlich aufwändig für meinen Geschmack; bei einer ActiveX-DLL schreibt man einfach:
path := objectXY.GetProjectPath('Test');
Andreas

Geändert von shmia (12. Okt 2010 um 17:31 Uhr)
  Mit Zitat antworten Zitat
shmia

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

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:28
der Aufruf muss neben C und Delphi auch aus Python heraus erfolgen welches meines Wissens nach nicht mit ActiveX umgehen kann.
Phyton kann als ActiveX Client arbeiten:
http://stackoverflow.com/questions/1...ivex-in-python

Dann käme es nur noch darauf an, einen zeitgemässen C/C++-Compiler zu finden, der ActiveX-DLLs einbinden kann.
Andreas
  Mit Zitat antworten Zitat
Zend

Registriert seit: 5. Mär 2010
Ort: Braunschweig
17 Beiträge
 
Delphi 7 Professional
 
#7

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 17:33
Hallo,

mir gefällt die Vorstellung über ActiveX zu gehen.

Der verwendete C-Compiler wäre der aus Visual Studio 2010. Ich denke wenn es einen gibt der damit umgehen kann, dann ist es gerade dieser oder?

Grüße
Zend
  Mit Zitat antworten Zitat
Benutzerbild von Luckie
Luckie

Registriert seit: 29. Mai 2002
37.621 Beiträge
 
Delphi 2006 Professional
 
#8

AW: Funktionsdeklaration: Beste Vorgehensweise

  Alt 12. Okt 2010, 20:25
Ich würde es so machen: http://www.michael-puff.de/Artikel/StringDLL.shtml
Michael
Ein Teil meines Codes würde euch verunsichern.
  Mit Zitat antworten Zitat
Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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:26 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