我在C ++中具有以下类型:
typedef void* keychain_handle;
typedef struct {
const char* keyHolderName;
unsigned int numKeys;
key* keys;
} key_holder;
typedef struct {
const char* keyName;
unsigned int keySize;
} key;
我有以下方法:
int createKeyChain(
int id,
key_holder* keyHolders,
keychain_handle* handle);
我需要C#来创建带有密钥的密钥持有者,将其发送到C ++代码并接收一个句柄。
这是我的C#代码:
/* Structs */
[StructLayout(LayoutKind.Sequential)]
public struct Key
{
public string key;
public uint size;
}
[StructLayout(LayoutKind.Sequential)]
public struct KeyHolder
{
public string name;
public uint keys;
public IntPtr keys;
}
/* Sync API */
[DllImport("keys.dll", CharSet = CharSet.Ansi, CallingConvention = CallingConvention.StdCall)]
public static extern uint createKeyChain(uint id, KeyHolder[] keyHolders, ref IntPtr handle);
Key[] myKeys = new Key[1];
myKeys[0] = new Key { key = "tst", size = 5 };
KeyHolder keyHolder = new DllWrapper.KeyHolder
{
name = "tst123",
items = 1,
keys = Marshal.AllocHGlobal(Marshal.SizeOf(typeof (Key))*myKeys.Length)
};
IntPtr c = new IntPtr(keyHolder.keys.ToInt32());
for (int i = 0; i < myKeys.Length; i++)
{
Marshal.StructureToPtr(myKeys[i], c, false);
c = new IntPtr(c.ToInt32() + Marshal.SizeOf(typeof(Key)));
}
Marshal.StructureToPtr(c, keyHolder.keys, false);
IntPtr handle = IntPtr.Zero;
var ret = createKeyChain(111, new []{keyHolder}, ref handle);
除Key对象内部的内部字符串损坏外,其他所有东西都运行良好。我怀疑是StructureToPtr损坏了它。如何使字符串显示在C ++一侧?
谢谢。
最佳答案
如果不更改非托管代码,则别无选择,只能自己打包。看起来像这样:
[StructLayout(LayoutKind.Sequential)]
public struct _Key
{
public IntPtr keyName;
public uint keySize;
}
[StructLayout(LayoutKind.Sequential)]
public struct _KeyHolder
{
public string name;
public uint numKeys;
public IntPtr keys;
}
public struct Key
{
public string keyName;
public uint keySize;
}
public static _KeyHolder CreateKeyHolder(string name, Key[] keys)
{
_KeyHolder result;
result.name = name;
result.numKeys = (uint)keys.Length;
result.keys = Marshal.AllocHGlobal(keys.Length * Marshal.SizeOf(typeof(_Key)));
IntPtr ptr = result.keys;
for (int i = 0; i < result.numKeys; i++)
{
_Key key;
key.keyName = Marshal.StringToHGlobalAnsi(keys[i].keyName);
key.keySize = keys[i].keySize;
Marshal.StructureToPtr(key, ptr, false);
ptr += Marshal.SizeOf(typeof(_Key));
}
return result;
}
public static void DestroyKeyHolder(_KeyHolder keyHolder)
{
IntPtr ptr = keyHolder.keys;
for (int i = 0; i < keyHolder.numKeys; i++)
{
_Key key = (_Key)Marshal.PtrToStructure(ptr, typeof(_Key));
Marshal.FreeHGlobal(key.keyName);
ptr += Marshal.SizeOf(typeof(_Key));
}
Marshal.FreeHGlobal(keyHolder.keys);
}
关于c# - 从C#到C++编码(marshal)嵌套结构,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/29126836/