C#中byte[] 转 double[] 或 int[] 或 struct结构体

方法:使用C#调用C++ memcpy实现各种参数类型的内存拷贝

using System.Runtime.InteropServices;

 public class GlbWSGridDataset

{

   [DllImport("msvcrt.dll", EntryPoint = "memcpy", CallingConvention = CallingConvention.Cdecl, SetLastError = false)]
        public static extern void MemCopy(int[] dest, byte[] src, int count);//字节数组到整形数组的拷贝

        [DllImport("msvcrt.dll", EntryPoint = "memcpy", CallingConvention = CallingConvention.Cdecl, SetLastError = false)]
        public static extern void MemCopy(double[] dest, byte[] src, int count);//字节数组到double数组的拷贝

        [DllImport("msvcrt.dll", EntryPoint = "memcpy", CallingConvention = CallingConvention.Cdecl, SetLastError = false)]
        public unsafe static extern void MemCopy(ref GlbcwSGridFacet dest, byte[] src, int count);//注意只有结构体能这么做,class不可以

  public void test()

  {    

    string filepath = @"c:\ddd.sgr";
              FileStream fs = new FileStream(filepath, FileMode.Open);//初始化文件流
              BinaryReader binReader = new BinaryReader(fs);

    {///byte[] 转 double[]

      int zcount = (grid.ni) * (grid.nj) * (grid.nk + 1);
      double[] zArray = new double[zcount * 4];
      System.Diagnostics.Trace.Assert(zArray != null);
      int zlen = zcount * 4 * sizeof(double);
      byte[] zdata = new byte[zlen];
      zdata = binReader.ReadBytes(zlen);

      // 调用c++的memcopy实现拷贝
      MemCopy(zArray, zdata, zlen);

    }

    {///byte[] 转 int[]

      int clrcount = (NI) * (NJ) * (NK);
                clrArray = new int[clrcount];
                System.Diagnostics.Trace.Assert(clrArray != null);
                int len = clrcount * sizeof(int);
                byte[] clrdata = new byte[len];
                clrdata = binReader.ReadBytes(len);
                // 拷贝整型数组
                MemCopy(clrArray, clrdata, len);

    }

    

    {///byte[] 转struct

      GlbcwSGridFacet bounderCellIndexs = new GlbcwSGridFacet();

      // 使用Marshal.SizeOf来计算struct的大小

      int len = System.Runtime.InteropServices.Marshal.SizeOf(typeof(GlbcwSGridFacet))

      byte[] data= new byte[len];
                System.Diagnostics.Trace.Assert(data!= null);
                data= binReader.ReadBytes(len);
                // 用不安全的拷贝方式memcpy  效率最快
                MemCopy(ref bounderCellIndexs, data, len);   

    }

       // 关闭文件   

              binReader.Close();
              fs.Close();

 

  }

}

参考 https://www.cnblogs.com/timeObjserver/p/7040966.html?utm_source=itdadao&utm_medium=referral  C#调用C++ memcpy实现各种参数类型的内存拷贝 VS marshal.copy的实现 效率对比

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值