草庐IT

new_list

全部标签

c++ - 使用 'new' 时未初始化的 std::complex 构造函数

在分析我的程序时,我意识到10%的代码花在了一个愚蠢的std::complex()上。构造函数,使用newstd::complex[size_of_array].我在网上搜索了std::complex的默认构造函数似乎将值double()作为实部和虚部。由于C++不初始化double,我想知道为什么g++费心初始化std::complex零,以及我是否可以通过某种方式在整个程序中解决这个问题(*)(*)现在我必须对创建复数数组的函数进行特殊处理,以分配未初始化的double组并将它们重铸为复数。编辑:如下所示,这是我的疏忽。默认构造函数的实部和虚部构造函数为空(http://en.cp

c++ - 为什么 g++5 在自动类型推导中推导对象而不是 initializer_list

我最近发现了这段代码:structFoo{};intmain(){Fooa;//clang++deducesstd::initializer_list//g++5.1deducesFooautob{a};a=b;}它在g++5.1中编译良好,但在clang++中失败(同时使用-std=c++11和-std=c++14,结果相同)。原因是clang++deducesthetypeofbasstd::initializer_list,而g++5.1deducesasFoo.AFAIK,类型确实应该是(确实违反直觉)std::initializer_list这里。为什么g++5将类型推断为F

c++ - VS2015 : Error List doesn't get cleared on new build

一个解决方案中有多个C++项目。让我们编译A,它会失败,并且会在错误列表View中报告错误。现在编译B(假设A依赖于B),这将成功。但是,编译A时出现的错误并没有消失。有人遇到过这样的问题吗?如何启用清除每个构建的错误ListView(多年来它的工作方式)。但是,Output窗口在每次新构建时都是干净的。 最佳答案 您是否在组合框中选择了“仅构建”或“构建+Intellisense”?我的许多此类错误实际上都来自Intellisense(而且往往是伪造的)。 关于c++-VS2015:E

c++ - SSL_CTX_new 返回 NULL 后获取错误描述的问题

我对SSL很陌生,实际上我会说我对此一无所知。我正在使用“SSL_CTX_new”方法创建一个SSL_CTX对象。该方法返回null。文档说我可以检查错误堆栈以找出原因。所以我有函数“intSSL_get_error(SSL*s,intret_code)”(据我所知)我必须使用它来获取错误消息。该方法的文档对函数的第一个参数只字不提。它只是说第二个(“ret”)参数应该等于失败操作的返回码,可以是以下任何一个:SSL_connect()、SSL_accept()、SSL_do_handshake()、SSL_read()、SSL_peek()或SSL_write()所以现在我有两个问题

c++ - 如何将已排序的 std::list of std::pair 转换为 std::map

我有一个std::list>,我知道这是根据std::stringelement排序的.因为我想做很多std::find_if基于std::string元素,我相信一个std::map与lower_bound和upper_bound会更合适。事实是我想insertstd::map中的元素以一种有效的方式。所以我想使用一个额外的迭代器来制作insert更快。我相信最简单的方法是使用const_reverse_iterator通过std::list并使用begin()的std::map.你会这样做吗,还是一个坏主意?谢谢! 最佳答案 如

c++ - 如何有效地从 forward_list 中删除一个元素?

好吧,我认为这个问题已经很概括了。我有一个独特项目的forward_list,并想从中删除单个项目:std::forward_listmylist;//fillwithstuffmylist.remove_if([](Tconst&value){returnvalue==condition;});我的意思是,这种方法工作正常,但效率低下,因为一旦找到并删除项目,它就会继续搜索。有更好的方法还是我需要手动完成? 最佳答案 如果只想删除第一个匹配项,可以使用std::adjacent_find后跟成员erase_after#includ

c++ - 通过覆盖 'new' 运算符,您获得了哪些有用的功能?

您发现重写新运算符对哪些新功能(用于调试或非调试)有帮助? 最佳答案 我不得不重载new的主要原因是为了性能。一个例子是分配大量小对象,使用通用分配器通常会相当慢,但使用自定义分配器通常可以很多改进。 关于c++-通过覆盖'new'运算符,您获得了哪些有用的功能?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1821799/

c++ - 为什么 vector(size) 比 new[] 慢?

我正在对一些STL算法进行基准测试,我对以下代码所花费的时间感到惊讶:(我用time命令测量了g++编译代码[没有优化])#includestructvec2{intx,y;vec2():x(0),y(0){}};intmain(intargc,char*argv[]){constintsize=200000000;std::vectortab(size);//2.26s//vec2*tab=newvec2[size];//1.29s//tab[0].x=0;//delete[]tab;return0;}vector初始化花费的时间是2.26秒,而new(和delete)花费的时间是1

c++ - 当用于 "new"初始化时, () 和 {} 是否总是等价的?

有一个帖子处理parenthesesornotafterthetypename使用新的时候。但是这个呢:如果'Test'是一个普通类,有什么区别:Test*test=newTest();//andTest*test=newTest{};此外,假设Test2有一个Value类型参数的构造函数,它是否总是等同于写:Valuev;Test2*test2=newTest(v);//andTest2*test2=newTest{v}; 最佳答案 在涉及std::initializer_list的上下文中可能存在差异,例如:案例1-()和{}#

c++ - 在 C/C++ 中存储 va_list 供以后使用的最佳方法

我正在使用va_list构建一个呈现的字符串。voidText2D::SetText(constchar*szText,...)一切都很好,但现在用户可以在应用程序运行时更改语言。我需要重新生成所有文本字符串并在初始化后重新缓存文本位图。我想存储va_list并在需要生成文本时使用它。为了提供更多背景信息,这需要在我正在翻译的key字符串中包含动态数据的情况下发生。"PlayerScore:%d"那是我需要翻译的关键字符串。我想保留va_list中提供的数字供以后使用(在初始化文本的函数范围之外),以防在初始化后需要重新翻译。我最好保留一份va_list的拷贝,以便与vsnprintf