草庐IT

array_new

全部标签

c++ - boost::variant for boost::arrays of arbitrary size

我想本着的spirit创建一个boost::varianttypedefboost::variant,boost::array,boost::array,...>any_int_array;泛化为N作为模板的第二个值。换句话说,一个包含任意大小数组的boost::variant。这可能吗?请注意,在上面的示例中,boost::array是我的案例之一,但对于采用单个int的任何类,它都需要是一个可行的解决方案值作为模板参数。 最佳答案 既然你在谈论具有静态已知容量的类型,你就不能用一些模板元编程来解决这个问题吗?LiveonColi

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,因为我们需要这些更快的分配器来管理我们的内存。但要实现这一点,我将不得不设计出最

c++ - 为什么 std::stoi 和 std::array 不能用 g++ c++11 编译?

过去几个月我一直在学习C++和使用终端。我的代码使用g++和C++11编译和运行良好,但在过去的几天里它开始出错,从那以后我在编译时遇到了问题。我唯一可以编译和运行的程序依赖于旧的C++标准。我首先得到的错误与头文件中的#include有关。不知道为什么会这样,但我通过使用boost/array来绕过它。我无法解决的另一个错误是std::stoi。array和stoi都应该在C++11标准库中。我编写了以下简单代码来演示发生了什么:////stoi_test.cpp////Createdbyecg//#include#include//stoishouldbeinhereintmain

c++ - 编译器在初始化大型 std::arrays 时挂起

我需要初始化一个非常大的多维std::array数据:classThing;classWorld{public:World():space{nullptr}{};~World()=default;private:staticunsignedintconstsize=1000;std::array,size>,size>,size>space;};如果您尝试实例化它,G++4.8.2会阻塞:它会消耗所有可用内存并且不会返回。也就是说,编译器挂起,我从来没有得到可执行文件。这是为什么?请注意,clang++没有问题。注意:我完全意识到将这么多数据放在堆栈上可能会溢出。在堆上初始化它的最佳方

如何检查角色是否是Rust中的Unicode New-Line字符(不仅是ASCII)?

每种编程语言都有自己的解释\n和\r。Unicode支持多个字符能够代表一条新线。从生锈的参考:空格逃脱是u+006e(n),u+0072(r)或u+0074(t)的字符之一,表示Unicode值U+000A(LF),U+000D(CR)或U+0009(HT)。基于该陈述,我会说如果它是一个新线角色,则是一个新的字符\n或者\r。在窗户上可能是\r和\n。我不确定。那以下呢?下一行字符(u+0085)线分离器字符(U+2028)段落分隔符(U+2029)我认为,我们缺少像char.is_new_line()。我看了看Unicode字符类别但找不到新线的定义。我是否必须提出自己对Unicode新

C++ 使用 "new"创建静态类数组或创建动态数组的另一种方法

我知道在C++中使用new创建动态数组的常用技术是:int*arr=newint[5];一本书还说:shorttell[10];//tellisanarrayof20bytescout现在我想知道是否有一种方法可以使用new为数组分配内存,这样它就可以分配给指向整个数组的指针。它可能看起来像这样:int(*p)[5]=newint[5];上面的例子是行不通的。左边在我看来是正确的。但是我不知道右边应该是什么。我的意图是了解这是否可能。我知道有std::vector和std::array。更新:这是我真正想检查的内容:int(*p1)[5]=(int(*)[5])newint[5];//

c++ - 我应该如何将 placement new 与自定义分配 API 一起使用?

我正在处理一些具有自定义分配和删除的内存空间,这些内存空间是使用类似malloc的接口(interface)创建的,不受我的控制(即不透明的C风格函数,用于“分配n个字节”或“释放一个字节”分配的指针”)。所以,没有什么比new或delete更好的了。现在,我想构造一个T的数组。我通过autospace_ptr=custom_alloc(n*sizeof(T))获得了空间。现在我想做一些类似array-placement-new的事情来就地构造n元素。我该怎么做?...或者我应该从1循环到n并构建单个T?注意:我在这里忽略对齐问题(或者更确切地说,假设alignof(T)划分sizeo

c++ - 带有 nothrow 选项的 Operator new 仍然抛出异常

有这样的代码:#includeintmain(){for(;;){int*ptr=new(std::nothrow)int;if(ptr==0){std::cout然而,这个程序仍然抛出std::bac_alloc异常,尽管new是用std::nothrow参数调用的。该程序在VisualC++2010中编译,为什么会抛出异常?编辑:在Windows上从mingw使用g++,一切正常。 最佳答案 0必须格式化为"0"。这将占用几个字节;我敢打赌这就是原因。在std::bad_alloc::bad_alloc上放置一个断点,你就会知道

c++ - array[i] = i++ 是否包含在 C++ 标准中?

有人声称C++标准未涵盖这一行:inti(1);array_of_int[i]=i++;有人说它会赋值1但我们不知道它是在array_of_int[1]还是array_of_int[2]尽管visualstudio和大多数编译器都在array_of_int[1]中。他是对的吗? 最佳答案 这是未定义的行为。从字面上看,任何行为都是合法的。禁止该行代码的段落是这样的:Betweenthepreviousandnextsequencepointanobjectshallhaveitsstoredvaluemodifiedatmoston