草庐IT

c++ - Placement-new 与 gcc 4.4.3 严格别名规则

我有一些代码,多年来我一直在成功使用这些代码来实现“变体类型对象”;也就是说,一个C++对象可以保存各种类型的值,但只使用(大约)尽可能多的内存作为最大的可能类型。该代码在本质上类似于标记union,只是它也支持非POD数据类型。它通过使用char缓冲区、放置新/删除和reinterpret_cast来实现这一魔力。我最近尝试在gcc4.4.3(使用-O3和-Wall)下编译这段代码,并收到很多这样的警告:warning:dereferencingtype-punnedpointerwillbreakstrict-aliasingrules根据我的阅读,这表明gcc的新优化器可能会生成

c++ - 在派生类中重写运算符 new/delete

我有一个无状态的抽象基类,各种具体类都从中继承。其中一些派生类也是无状态的。因为它们中的许多是在运行期间创建的,所以我想通过覆盖运算符new()/delete()让所有无状态派生类模拟单例来节省内存和开销。一个简化的例子看起来像这样:#includestructBase{virtual~Base(){}protected:Base(){}//preventconcreteBaseobjects};structD1:publicBase{//statefulobject--defaultbehaviorintdummy;};structD2:publicBase{//statelesso

c++ - 使用 C++、Openssl 和 aes 加密和解密字符串

我正在尝试使用C++openssl和aescbc加密和解密字符串。奇怪的是,在一台电脑上它可以工作,而在另一台电脑上却不能。我只有原始字符串的3/4,所以结尾是错误的。另一个奇怪的事情是,当我在第二台电脑上的exe文件目录中添加一个名为“libeay32.dll”的dll时,它可以工作,但在第一台电脑上不行。总而言之,第一台电脑只在没有dll的情况下工作,第二台电脑只在有dll的情况下工作。我的问题是,这段代码可以改进吗,为什么一台电脑需要这个dll,另一台电脑不需要。这是我已经写的:KEY和Iv定义:#defineKEY"abc"#defineIv"abc"加密函数:stringae

AES算法:数据传输的安全保障

在当今数字化时代,数据安全成为了一个非常重要的问题。随着互联网的普及和信息技术的发展,我们需要一种可靠的加密算法来保护我们的敏感数据。AdvancedEncryptionStandard(AES)算法应运而生。本文将介绍AES算法的优缺点、解决了什么问题以及在哪些方面可以应用。AES(Rijndael)加密解密|一个覆盖广泛主题工具的高效在线平台(amd794.com)https://amd794.com/aesencordec一、AES算法的优点:高安全性:AES算法采用了128位、192位和256位的密钥长度,使得破解变得非常困难。这使得AES算法成为当前最安全的对称加密算法之一。高效率:

c++ - Constexpr 替代 placement new 能够使内存中的对象保持未初始化状态?

我正在尝试创建一个静态容器,它具有基于堆栈的内存并且可以容纳T的N个实例。非常类似于std::vector我希望当前未使用的内存不包含T的初始化项。这通常可以通过placementnew来解决,但不可能在constexpr中使用。使用union我发现了一个技巧,您可以为此使用union,如下所示:templateunioncontainer_storage_type{structempty{};constexprcontainer_storage_type():uninitialized{}{}constexprcontainer_storage_type(value_typev):v

c++ - 使用 WinAPI 的简单 AES 加密

我需要在我的Qt/C++应用程序中进行简单的单blockAES加密/解密。这是一个“让诚实的人保持诚实”的实现,所以只需要一个基本的encrypt(key,data)——我不担心初始化vector等。我的输入和key将始终正好是16个字节。我真的想避免另一个依赖项来编译/链接/发布我的应用程序,所以我尝试使用每个平台上可用的东西。在Mac上,这是CCCrypt的一行代码。在Windows上,我迷失在WinCrypt.h的API中。他们加密文件的例子几乎有600行长。认真的吗?我正在查看CryptEncrypt,但我掉进了你必须在调用它之前创建的依赖关系的兔子洞。谁能提供一个使用Wind

c++ new运算符通过libstdc++占用大量内存(67MB)

我对libstdc++中的new运算符有一些疑问。我用C++编写了一个程序,但在内存管理方面遇到了一些问题。在用gdb调试以确定是什么在消耗我的ram之后,我得到了以下infoprocmappingsMappedaddressspaces:StartAddrEndAddrSizeOffsetobjfile0x4000000x4040000x40000/home/sebastian/Developement/powerserverplus-svn/psp-job-distributor/Release/psp-job-distributor0x6040000x6050000x10000x

c++ - 在 'this' 指针上使用 placement new 是否安全

当前实现我有一个包含unique_ptr字段的类,这些字段相互依赖:classResourceManager{ResourceManager(){}ResourceManager(A*a_ptr):b_ptr(newB(a)),c_ptr(newC(b_ptr.get())){}ResourceManager&operator=(ResourceManager&&that){//Calldestructor,thenconstructanewinstanceontop~ResourceManager();ResourceManager*new_this=new(this)Resourc

c++ - 在没有 Malloc/New 或 Free/Delete 的情况下管理连续的内存块

如果没有C++中其他内存管理器(例如Malloc/New)的帮助,如何创建自定义MemoryManager来管理给定的连续内存块?这里有更多的上下文:MemManager::MemManager(void*memory,unsignedchartotalsize){Memory=memory;MemSize=totalsize;}我需要能够使用MemManager分配和释放此连续内存块。构造函数被赋予block的总大小(以字节为单位)。分配函数应以字节为单位获取所需的内存量,并返回指向该内存块开头的指针。如果没有内存剩余,则返回NULL指针。Deallocate函数应接收指向必须释放的

c++ - 如何在函数调用后初始化变量,就像 new 表达式提供的那样?

目前我正在研究自定义内存分配,其中一个缺点是我必须编写多行代码才能获得与new-expression相同的结果。仅提供一个简单的调用。简单的初始化:MyClass*obj=newMyClass(3.14);不太简单的初始化:void*obj_mem=alloc->Allocate(sizeofMyClass,alignof(MyClass));MyClass*obj=new(obj_mem)MyClass(3.14);我将向我的项目组提供分配器,例如那个分配器,并希望他们实际使用它们,而不是返回调用new,因为我们需要这些更快的分配器来管理我们的内存。但要实现这一点,我将不得不设计出最