C++中二进制数据序列化和反序列化详解

 更新时间:2023年11月29日 09:42:15   作者:川谷_  
这篇文章主要为大家详细介绍了C++中二进制数据序列化和反序列化的相关知识,文中的示例代码讲解详细,具有一定的学习价值,感兴趣的小伙伴可以了解下

一、基础知识

1、memcpy:内存拷贝函数

函数原型:void *memcpy(void *dest, const void *src, size_t count);

2、代码编写(采用循环的方式将字节内容逐一拷贝)

void* my_memcpy(void* dest, const void* src, size_t count)
{
	assert(dest);  //防止函数接受空指针进行操作
	assert(src);
 
	void* ret = dest;
	while (count--)
	{
		*(char*)dest = *(char*)src;
		dest = (char*)dest + 1;
		src = (char*)src + 1;
	}
	return ret;
}

3、c_str()函数:可以将const string* 类型 转换为 const char* 类型

二、什么是数据序列化和数据反序列化

数据序列化:将对象变成字节流的形式传出去

数据反序列化:从字节流恢复成原来的对象

三、为什么需要读数据进行序列化和反序列化处理

1、序列号可以将数据转换为一种格式,使其容易通过网络进行传输和存储。反序列化则可以将序列化后的数据还原为原始形式,以便后续进行处理

2、内存中对象转换为二进制数据:当需要将对象的状态传输到远程机器,或将其存储在磁盘上时,就需要将对象转换为二进制数据。

3、二进制数据转换为内存中的对象:当需要从远程机器或磁盘中读取对象状态时,需要将已序列化的二进制数据转换为原始对象。

四、数据序列化处理

struct Student
{
	string name;
	string grade;
	int age;
	double scale;
};
//数据序列化
char* serialization(Student* student)
{
	int size = sizeof(Student);
	char* pBuf = new char[size];
 
	//记录指针的位置
	int num = 0;
 
	memcpy((pBuf + num), student->name.c_str(), 8);
	num += 8;
 
	memcpy((pBuf + num), student->grade.c_str(), 8);
	num += 8;
 
	*(int *)(pBuf + num) = student->age;
	num += 4;
 
	*(double*)(pBuf + num) = student->scale;
 
	return pBuf;
}

五、数据反序列化处理

void deserialization(char* data)
{
	string name;
	string garde;
	int age;
	double scale;
 
	//记录指针的位置
	int num = 0; 
 
	name = (data + num);
	num += 8;
 
	garde = (data + num);
	num += 8;
 
	age = *(int*)(data + num);
	num += 4;
 
	scale = *(double*)(data + num);
 
	cout << "name:" << name << endl;
	cout << "garde:" << garde << endl;
	cout << "age:" << age << endl;
	cout << "scale:" << scale << endl;
}

六、运行处理

int main()
{
	Student student;
	student.name = "Jim";
	student.grade = "ten";
	student.age = 12;
	student.scale = 88;
 
	char* data = serialization(&student);
 
	deserialization(data);
 
	return 0;
}

以上就是C++中二进制数据序列化和反序列化详解的详细内容,更多关于C++二进制数据序列化和反序列化的资料请关注脚本之家其它相关文章!

相关文章

  • C++中strtok()函数的用法介绍

    C++中strtok()函数的用法介绍

    以下是对C++中strtok()函数的使用方法进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-09-09
  • C++实现坦克大战小游戏EGE图形界面

    C++实现坦克大战小游戏EGE图形界面

    这篇文章主要为大家详细介绍了C++实现坦克大战小游戏EGE图形界面,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-03-03
  • C/C++仿华容道小游戏

    C/C++仿华容道小游戏

    这篇文章主要介绍了C/C++仿华容道小游戏的相关资料,模仿实现华容道游戏,感兴趣的朋友可以参考一下
    2016-02-02
  • vc中使用SendMessage自定义消息函数

    vc中使用SendMessage自定义消息函数

    这篇文章主要介绍了vc中使用SendMessage自定义消息函数的相关资料,需要的朋友可以参考下
    2015-06-06
  • 如何使用递归和非递归方式反转单向链表

    如何使用递归和非递归方式反转单向链表

    以下是对使用递归和非递归方式反转单向链表的示例进行了详细的分析介绍,需要的朋友可以过来参考下
    2013-07-07
  • C语言链表案例学习之通讯录的实现

    C语言链表案例学习之通讯录的实现

    为了将所学到的链表的知识进行巩固学习,做到学以致用,本文将利用链表制作一个简单的通讯录。文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下
    2022-10-10
  • java 中ArrayList与LinkedList性能比较

    java 中ArrayList与LinkedList性能比较

    这篇文章主要介绍了java 中ArrayList与LinkedList性能比较的相关资料,需要的朋友可以参考下
    2017-03-03
  • C++实现LeetCode(64.最小路径和)

    C++实现LeetCode(64.最小路径和)

    这篇文章主要介绍了C++实现LeetCode(64.最小路径和),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++语法详解之封装、构造函数、析构函数

    C++语法详解之封装、构造函数、析构函数

    这篇文章主要介绍了C++语法详解之封装、构造函数、析构函数的相关知识,通过实例代码给大家详细介绍,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • C语言的递归思想实例分析

    C语言的递归思想实例分析

    这篇文章主要介绍了C语言的递归思想,以一个实例的形式针对数据变化规律分析了递归思想的本质,需要的朋友可以参考下
    2014-09-09

最新评论