刚才,我以为那stackalloc
是正确的方法,但它失败了。最重要的是,我现在知道它注定要失败。没有办法做我想做的事。
这可以通过重申问题来看出:
如何围绕“不安全”数组创建托管数组?
由于托管数组具有标头信息(因为它是一个围绕内存的类),因此它需要比数组本身更多的内存空间。所以,答案是:
在数组本身之前(和/或之后?取决于托管数组在内存中的存储方式)分配空间,并将托管信息(长度,(等等))放在“不安全”数组周围。
这并不容易,因为保证阵列周围有足够的数据充其量是不稳定的。在我的特定示例中,它可能有足够的空间,因为传递了托管 byte[] 意味着数组周围有数据,但是断言相同的数据适用于托管 double[] 充其量是可疑的,但大多数可能是错误的,并且更改数据以使其适合托管 double[] 是邪恶的。
[编辑]
看起来Marshal.Copy
是去这里的路。创建一个新数组并让 Marshal 复制它们(希望他会比我快,或者也许在以后的某个时间,他会更快):
var ret = new double[_raw_data.Length / sizeof(double)];
System.Runtime.InteropServices.Marshal.Copy(new System.IntPtr(_pret), ret, 0, ret.Length);