Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-10-2006, 13:35   #1
ohmimmo
Junior Member
 
Iscritto dal: Oct 2006
Messaggi: 4
[Dll.... fatta in c++(Builder) richiamata in pascal(Delphi)]

Ciao a tutti, sono uno studente universitario ed ho un piccolo problema nel richiamare le funzioni contenute in una DLL fatta in C++ (CBuilder6) con una applicazione scritta in Pascal (Delphi6).
Di seguito riporto il codice scritto:

#### file StaticLd.h #####################################
#ifndef _STATICLD_H
#define _STATICLD_H

#if defined __DLL__
# define DLL_EXP __declspec(dllexport)
#else
# define DLL_EXP __declspec(dllimport)
#endif

//------------------------------------------------------------------------

extern "C" void DLL_EXP Saluti(HWND);
//------------------------------------------------------------------------

class DLL_EXP NomeClasse
{
public:
NomeClasse(HWND hwnd);
void FaQualcosa(char* text);
void Beep();
private:
HWND hWnd;
};
//------------------------------------------------------------------------
#endif
####################################################
###
###
#### file StaticLd.cpp ####################################
//------------------------------------------------------------------------
#include <condefs.h>
#include <windows.h>
//------------------------------------------------------------------------

#pragma argsused
#include "StaticLd.h"

int WINAPI DllEntryPoint(HINSTANCE hinst, unsigned long reason, void* lpReserved)
{

return 1;
}
//------------------------------------------------------------------------
void DLL_EXP Saluti(HWND hWnd)
{
MessageBox(hWnd, "Saluti da una funzione della DLL!", "Messaggio 1 per Filice",
MB_OK | MB_ICONEXCLAMATION);
}
//------------------------------------------------------------------------
NomeClasse::NomeClasse(HWND hwnd)
{
hWnd=hwnd;
}
//------------------------------------------------------------------------
void NomeClasse::FaQualcosa(char* text)
{
MessageBox(hWnd, text, "Messaggio 2 per Filice",MB_OK);
}
//------------------------------------------------------------------------
void NomeClasse::Beep()
{
MessageBeep(-1);
}
//------------------------------------------------------------------------


Questa libreria chiamata in un'applicazione c++ funziona perfettamente.
Riporto di seguito la Unit chiamante, composta da un Form con due pulsanti:


#### file CallDll_Unit.h ####################################
//------------------------------------------------------------------------
#ifndef CallDll_UnitH
#define CallDll_UnitH
//------------------------------------------------------------------------
#include <Classes.hpp>
#include <Controls.hpp>
#include <StdCtrls.hpp>
#include <Forms.hpp>
//------------------------------------------------------------------------
class TForm1 : public TForm
{
__published: // IDE-managed Components
TButton *Button1;
TButton *Button2;
void __fastcall Button1Click(TObject *Sender);
void __fastcall Button2Click(TObject *Sender);
private: // User declarations
public: // User declarations
__fastcall TForm1(TComponent* Owner);
};
//------------------------------------------------------------------------
extern PACKAGE TForm1 *Form1;
//------------------------------------------------------------------------
#endif
####################################################
###
###
#### file CallDll_Unit.cpp ##################################
//------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop

#include "CallDll_Unit.h"
#include "StaticLd.h"
//------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
: TForm(Owner)
{
}
//------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
Saluti(Handle);
}
//------------------------------------------------------------------------
void __fastcall TForm1::Button2Click(TObject *Sender)
{
NomeClasse mc(Application->Handle);
mc.FaQualcosa("Saluti da una funzione di una Classe della DLL!");
mc.Beep();
}
//------------------------------------------------------------------------
//##################################################

Mentre nel modulo in pascal, il compilatore non da nessun messaggio di errore però quando lo eseguo da il messaggio:

" Impossibile trovare il punto di ingresso Saluti della procedura nella libreria di collegamento dinamico PrjStaticLd.dll."

Riporto di seguito la Unit dell'applicazione chiamante in Pascal
(approposito, mi limito a chiamare solo la funzione Saluti(.......)):

#### file CallDllU.pas ####################################
unit CallDllU;

interface

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

type
TForm1 = class(TForm)
Button1: TButton;
procedure Button1Click(Sender: TObject);

private
{ Private declarations }
public
{ Public declarations }
end;

var

//-- fatta in CBuilder6 -----------------
procedure Saluti(hWnd : HWND ); external 'PrjStaticLd.dll';
//---------------------------------------

implementation {$R *.dfm}
//##################################################
//------------------------------------------------------------------------
procedure TForm1.Button1Click(Sender: TObject);
begin
Saluti(Handle);
end;

//------------------------------------------------------------------------
//##################################################
end.

So dell'esistenza dei modificatori "cdecl, pascal ecc..." per la compatibilità delle librerie ma non trovo materiale per studiarne il significato.
Spero che qualcuno mi risponderà.... aiutooooooooo!!!!!!!!!
ohmimmo è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2006, 13:56   #2
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
un po' ovunque: quelli del compilatore Microsoft per esempio ovviamente sono documentati su MSDN. te ne riassumo brevemente le caratteristiche:

__stdcall - i parametri vengono messi (PUSH) nello stack da destra a sinistra, il cleanup viene fatto dal chiamato

__cdecl - parametri messi da sinistra a destra, cleanup da parte del chiamante; permette di realizzare funzioni "vararg" (ellissi come ultimo "parametro" nel prototipo), al contrario di __stdcall che non lo permette

__fastcall - utilizza i registri general purpose anziché lo stack per passare i primi parametri; se la funzione ha pochi parametri e non usa variabili locali non sarà necessario creare lo stack frame

poi esistono anche __pascal, __fortran e __syscall, ma sono obsolete percui non le usare.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 30-10-2006, 11:28   #3
ohmimmo
Junior Member
 
Iscritto dal: Oct 2006
Messaggi: 4
[Grazie... ma mi servirebbero ulteriori informazioni]

Quote:
Originariamente inviato da 71104
un po' ovunque: quelli del compilatore Microsoft per esempio ovviamente sono documentati su MSDN. te ne riassumo brevemente le caratteristiche:

__stdcall - i parametri vengono messi (PUSH) nello stack da destra a sinistra, il cleanup viene fatto dal chiamato

__cdecl - parametri messi da sinistra a destra, cleanup da parte del chiamante; permette di realizzare funzioni "vararg" (ellissi come ultimo "parametro" nel prototipo), al contrario di __stdcall che non lo permette

__fastcall - utilizza i registri general purpose anziché lo stack per passare i primi parametri; se la funzione ha pochi parametri e non usa variabili locali non sarà necessario creare lo stack frame

poi esistono anche __pascal, __fortran e __syscall, ma sono obsolete percui non le usare.
//-------------------------

Per prima cosa grazie per avermi risposto.
Il problema è che sono nuovo nella creazione delle dll e forse anche una stupidagine mi blocca, non riesco a capire perche durante l'esecuzione l'applicazione non trova il punto di ingresso alla funzione nella dll.
Se ti và, potresti guardare il codice? Non è tanto, è solo un esempietto che ho preparato per l'occasione.
ohmimmo è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 05:59.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v