c – 编译器是否在析构函数中优化memset?

c – 编译器是否在析构函数中优化memset?,第1张

概述给定一个结构: struct CryptoKey { std::vector<unsigned char> key; ~CryptoKey() { memset(key.data(),0,key.size()); }}; 编译器有权消除对memset的调用,因为这将节省时间,并且没有定义行为的程序可以区分. (假设析构函数返回后变量键将不复存在.) 然而,像这样的代码在加密应用程 给定一个结构:

struct CryptoKey {    std::vector<unsigned char> key;    ~CryptoKey() { memset(key.data(),key.size()); }};

编译器有权消除对memset的调用,因为这将节省时间,并且没有定义行为的程序可以区分. (假设析构函数返回后变量键将不复存在.)

然而,像这样的代码在加密应用程序中很有用,因为秘密存储在内存中的时间越少,攻击者提取它的机会就越少. (memset不提供安全性,但确实提供了“纵深防御”.)

我的问题是,哪些真正的编译器确实消除了这种memset调用(显然,优化开启)?

解决方法 这里的优化器的问题是你的memset根本没有写入成员.是的,密钥将不复存在,但不是key.data.该内存将返回到std :: allocator.并且std :: allocator很可能会读取相邻内存以确定key.data所来自的内存块.典型的实现将这样的数据存储在分配的块的头部中,即在负的偏移处.标题不会更新以反映块是空闲的,或者将空闲块与其他空闲块合并.

这甚至可以内联,因此优化器会看到一个函数执行memset然后执行标头访问.期望优化器能够确定memset是无害的是不合理的.尽管如此,分配器可能会保留一组归零块.

总结

以上是内存溢出为你收集整理的c – 编译器是否在析构函数中优化memset?全部内容,希望文章能够帮你解决c – 编译器是否在析构函数中优化memset?所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/langs/1217549.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-06-05
下一篇2022-06-05

发表评论

登录后才能评论

评论列表(0条)

    保存