概述
核心思想
- 指定一段内存空间存储结构体数据,然后使用一个指针强制类型转化为结构体类型的,就可以使用这个指针操作结构体相关的成员函数和变量
- 结构体内存只会为定义的变量进行分配内存空间,函数只进行调用,不占据空间
结构体
void fill_md5(const std::string &md5_digest) {
assert(md5_digest.length() == sizeof(md5));
std::memcpy(md5, md5_digest.c_str(), sizeof(md5));
}
bool check_md5(const std::string &md5_digest) {
assert(md5_digest.length() == sizeof(md5));
return std::memcmp(md5, md5_digest.c_str(), sizeof(md5)) == 0;
}
void fill_current_version_info() {
mgmt_max_key_storage_rsa = MGMT_MAX_KEY_STORAGE_RSA;
mgmt_max_key_storage_ecc = MGMT_MAX_KEY_STORAGE_ECC;
mgmt_max_key_storage_symmetric = MGMT_MAX_KEY_STORAGE_Symmetric;
version = MGMT_BACKUP_VERSION;
time = std::time(nullptr);
}
bool check_version_info() const {
return mgmt_max_key_storage_rsa == MGMT_MAX_KEY_STORAGE_RSA &&
mgmt_max_key_storage_ecc == MGMT_MAX_KEY_STORAGE_ECC &&
mgmt_max_key_storage_symmetric == MGMT_MAX_KEY_STORAGE_Symmetric &&
version == MGMT_BACKUP_VERSION;
}
};
给结构体分配空间
bool backup(const std::string &password,
const std::string &backup_file) override {
MGMT_TRY_BEGIN
//调用KeyStorage的backup接口,得到原始备份文件的字节流
auto backup_data = key_storage->backup();
//计算md5
std::string md5_data = common::get_md5_digest(backup_data);
//在其尾部填充备份参数数据
backup_data.resize(backup_data.length() + sizeof(util::BackupFileHeader));
auto backup_params = reinterpret_cast<util::BackupFileHeader *>(
&backup_data[backup_data.length() - sizeof(util::BackupFileHeader)]);
backup_params->fill_md5(md5_data);
backup_params->fill_current_version_info();
//对处理后的数据进行加密,加密密钥由入参指定,将备份文件写入指定的文件夹
util::aes_encrypt_to_file(backup_file, password, backup_data);
MGMT_TRY_END
}
- 将结构体数据追加到先前的string类型的md5_string字符串的后面,需要指定一个指针找到结构体要存储的位置
- 具体是这一行的代码 auto backup_params = reinterpret_cast<util::BackupFileHeader *>(&backup_data[backup_data.length() - sizeof(util::BackupFileHeader)]);
最后
以上就是自信小鸽子为你收集整理的将结构体数据存储到一段字符串string中核心思想的全部内容,希望文章能够帮你解决将结构体数据存储到一段字符串string中核心思想所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复