Jak: Marshal struktur pomocí C++ Interop
Toto téma ukazuje na jeden aspekt vzájemné funkční spolupráce jazyka Visual C++.Další informace naleznete v tématu Použití interoperability C++ (implicitní PInvoke).
Následující příklady kódu používají managed, unmanaged direktivy # pragma k implementaci spravované a nespravované funkce ve stejném souboru, ale tyto funkce spolupracují stejným způsobem, pokud jsou definovány v samostatných souborech. Soubory, obsahující pouze nespravované funkce, nemusí být kompilovány s /CLR (kompilace společné Language Runtime).
Příklad
Následující příklad demonstruje předávání struktury ze spravované do nespravované funkce, jak hodnotou tak odkazem. Protože struktura v tomto příkladu obsahuje pouze jednoduché, vlastní datové typy (viz Přímo přenositelná a nepřenositelná typů), není speciální zařazování požadováno. Chcete-li zařadit non-blittable struktury , jako jsou ty, které obsahují ukazatele, podívejte se na téma Jak: vložené Marshal ukazatele pomocí C++ Interop.
// PassStruct1.cpp
// compile with: /clr
#include <stdio.h>
#include <math.h>
using namespace System;
using namespace System::Runtime::InteropServices;
#pragma unmanaged
struct Location {
int x;
int y;
};
double GetDistance(Location loc1, Location loc2) {
printf_s("[unmanaged] loc1(%d,%d)", loc1.x, loc1.y);
printf_s(" loc2(%d,%d)\n", loc2.x, loc2.y);
double h = loc1.x - loc2.x;
double v = loc1.y = loc2.y;
double dist = sqrt( pow(h,2) + pow(v,2) );
return dist;
}
void InitLocation(Location* lp) {
printf_s("[unmanaged] Initializing location...\n");
lp->x = 50;
lp->y = 50;
}
#pragma managed
int main() {
Location loc1;
loc1.x = 0;
loc1.y = 0;
Location loc2;
loc2.x = 100;
loc2.y = 100;
double dist = GetDistance(loc1, loc2);
Console::WriteLine("[managed] distance = {0}", dist);
Location loc3;
InitLocation(&loc3);
Console::WriteLine("[managed] x={0} y={1}", loc3.x, loc3.y);
}
Následující příklad demonstruje předávání struktury z nespravované do spravované funkce, jak hodnotou tak odkazem. Protože struktura v tomto příkladu obsahuje pouze jednoduché, vlastní datové typy (viz Přímo přenositelná a nepřenositelná typů), není speciální zařazování požadováno. Chcete-li zařadit non-blittable struktury , jako jsou ty, které obsahují ukazatele, podívejte se na téma Jak: vložené Marshal ukazatele pomocí C++ Interop.
// PassStruct2.cpp
// compile with: /clr
#include <stdio.h>
#include <math.h>
using namespace System;
// native structure definition
struct Location {
int x;
int y;
};
#pragma managed
double GetDistance(Location loc1, Location loc2) {
Console::Write("[managed] got loc1({0},{1})", loc1.x, loc1.y);
Console::WriteLine(" loc2({0},{1})", loc2.x, loc2.y);
double h = loc1.x - loc2.x;
double v = loc1.y = loc2.y;
double dist = sqrt( pow(h,2) + pow(v,2) );
return dist;
}
void InitLocation(Location* lp) {
Console::WriteLine("[managed] Initializing location...");
lp->x = 50;
lp->y = 50;
}
#pragma unmanaged
int UnmanagedFunc() {
Location loc1;
loc1.x = 0;
loc1.y = 0;
Location loc2;
loc2.x = 100;
loc2.y = 100;
printf_s("(unmanaged) loc1=(%d,%d)", loc1.x, loc1.y);
printf_s(" loc2=(%d,%d)\n", loc2.x, loc2.y);
double dist = GetDistance(loc1, loc2);
printf_s("[unmanaged] distance = %f\n", dist);
Location loc3;
InitLocation(&loc3);
printf_s("[unmanaged] got x=%d y=%d\n", loc3.x, loc3.y);
return 0;
}
#pragma managed
int main() {
UnmanagedFunc();
}