C#中的反序列化和序列化

之前用了比较大的篇幅专门讲了java中的序列化和反序列化
java踩雷系列3-通过反射实现 序列化,反序列化
然后这一篇看看C#中是怎么做的,对比一下:
直接贴代码:

        /// <summary>
        /// 将结构转换为字节数组
        /// </summary>
        /// <param name="obj">结构对象</param>
        /// <returns>字节数组</returns>
        public static byte[] StructToBytes(object obj)
        {
            //得到结构体的大小
            int size = Marshal.SizeOf(obj);
            //创建byte数组
            byte[] bytes = new byte[size];
            //分配结构体大小的内存空间
            IntPtr structPtr = Marshal.AllocHGlobal(size);
            //将结构体拷到分配好的内存空间
            Marshal.StructureToPtr(obj, structPtr, false);
            //从内存空间拷到byte数组
            Marshal.Copy(structPtr, bytes, 0, size);
            //释放内存空间
            Marshal.FreeHGlobal(structPtr);
            //返回byte数组
            return bytes;
        }

        //byte[]转换为struct
        public static T BytesToStruct<T>(byte[] bytes) //请求的范围扩展超过了数组的结尾。alert_1
        {
            
            Type tp = typeof(T);
            int size = Marshal.SizeOf(tp);
            IntPtr con_buffer = Marshal.AllocHGlobal(size);
            object retv;
            try
            {
                Marshal.Copy(bytes, 0, con_buffer, size);
                //  return (T)Marshal.PtrToStructure(con_buffer, tp);
                retv = Marshal.PtrToStructure(con_buffer, tp);
            }
            finally
            {
                Marshal.FreeHGlobal(con_buffer);
            }
            return (T)retv;
        }

和上一篇对比感觉太简单了。。很多东西都不用考虑,都给你封装好了直接用就行。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值