草庐IT

mb-db-foo-bundle

全部标签

c++ - 在 C++11/14 中说 "foo not in {bar, baz}"的漂亮方式

我正在编写C++,但缺少Python的清晰度。但我知道C++一直在发展,我想知道是否有更好的方法来做这样的事情:if(foo!=bar&&foo!=baz)在Python中我会这样做:iffoonotin{bar,baz}:C++11或C++14中是否有一个奇特的特性允许我做一些类似可读的事情?编辑:很多人想知道为什么我要尝试替换这么短的东西。我不是,但我不想让我的示例像原始代码一样丑陋和不可读。它更像是:if(somelongvariablename.somelongmethodname()!=SomeReallyLongNamespace::AndAnotherSubClassna

c++ - 为什么 C++ 编译器无法将 "if(test) --foo"优化为 "foo -= test"?

我有一个函数可以找到给定整数的下一个2的幂。如果整数是2的幂,则返回幂。非常简单:charnextpow2if(inta){charfoo=char(32-__builtin_clz(a));boolispow2=!(a&a-1);if(ispow2)--foo;returnfoo;}然而,在使用带有-O2的gcc6进行编译之后,在检查生成的程序集之后,我发现这是在计算foo-1之后用看似无用的指令cmovne编译的。更糟糕的是,对于gcc5和更早的版本,我在代码中得到了一个实际的jne分支。编译它的更快方法就像我编写了以下函数:charnextpow2sub(inta){charfo

c++ - 错误 : jump to label 'foo' crosses initialization of 'bar'

以下C++示例无法使用gcc或clang进行编译,但仅使用ICC生成警告,而使用MSVC则完全不生成任何警告:intmain(intargc,char*argv[]){if(argcg++:init.cpp:13:error:jumptolabel‘clean_up’init.cpp:4:error:fromhereinit.cpp:7:error:crossesinitializationof‘inti’clang++:init.cpp:4:9:error:cannotjumpfromthisgotostatementtoitslabelgotoclean_up;^init.cpp:

C++:可以将 "try { foo(); } catch (...) { throw; }"优化为 "foo();"吗?

在C++中,是如下代码try{foo();}catch(...){throw;}在语义上等同于像这样调用foo吗?foo();如果是这样,我是否可以期望最先进的编译器避免第一个版本到第二个版本(在启用优化的情况下编译时)?换句话说,如果我使用NDEBUG编译这段代码并启用优化try{foo();}catch(...){assert(some_check());throw;}我可以假设这个丑陋的版本永远不会慢吗#ifndefNDEBUGtry{#endiffoo();#ifndefNDEBUG}catch(...){assert(some_check());throw;}#endif

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

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

c++ - VisualStudio *.obj 文件大小(513Mb objs 和 534Mb lib)

我是一名C++开发人员,使用的是VisualStudio2008。如何减小*.obj文件的大小?我读过whyaremyvisualstudio.objfilesaremassiveinsizecomparedtotheoutput.exe?但没有找到答案。当我将项目构建为静态库时,所有*.obj文件的总大小为513Mb,生成的库为534Mb。每个obj文件为1-13Mb。调试exe文件为11Mb。链接时代码生成(/Gm)已关闭。提前致谢。 最佳答案 由于将大量重复代码和符号放入多个目标文件中,目标文件往往会变大。这通常是由内联函数和

c++ - 支持 REST 和 JSON 的轻量级 NoSQL DB

只是想找一个像SQLite一样紧凑的NoSQLDB,支持REST和JSON,最好用C/C++实现,并且能够进行全文搜索。你能推荐一下吗? 最佳答案 您可能需要LevelDB,一个由Google编写的快速键值存储库,提供从字符串键到字符串值的有序映射。您可以将其用作独立的基于文件的数据库。支持多种语言(C/C++、Ruby、Java)。另请查看KyotoCabinet,轻量级数据库库,DBM的直接实现,键值存储,独立的基于文件的数据库(也在内存中),支持多种语言(Ruby、Java、C#、PHP等)。

c++ - 无法使用 fixup_bundle() 与 Qt 创建可移植包

我已经在其他帖子上搜索过这个问题,但目前还没有。所以我来了。我想创建一个可移植的包。便携,如“我可以在任何OSX机器上运行它,即使我需要的库(Qt)没有安装”。不幸的是,我不知道如何使用fixup_bundle()(这似乎是正确的工具)来实现这个目标。这是我最小的CMake生成的C++项目:主要.cpp#include#includeintmain(){QStrings("Hello,world!");std::coutCMakeLists.txtcmake_minimum_required(VERSION2.8.11)project(test)#ThatpartbecauseIuse

c++ - 我可以使用 foo<T..., int, U...> 这样的模式部分特化模板吗?

如果可能的话,可以在不递归的情况下索引可变参数模板参数包。但是,GCC是refusingtopickupmypartialspecialization这里:templatestructelement_impl;templatestructelement_impl...,pair,pair...>>{typedefTtype;};prog.cpp:Ininstantiationof'element>':prog.cpp:52:34:instantiatedfromhereprog.cpp:47:79:error:invaliduseofincompletetype'structeleme

c++ - std::vector<Foo> 当 Foo 的一些成员是引用时

只要有可能,我通常更喜欢使用引用而不是指针,在我看来,它使语法更清晰。在这种情况下,我有一个类:classFoo{public:Foo(Bar&bar):bar_(bar){}private:Bar&bar_;};operator=()被编译器隐含地删除了这样一个类,因为一旦设置了引用,它就不能改变(我可以在技术上定义我自己的不改变bar_,但这不是必需的行为,所以我宁愿如果我尝试分配一个foo,编译器会提示)。我需要的是std::vectorv;.这在C++11之前是不可能的,因为模板参数必须是CopyAssignable。事实上,当我调用v.push_back(Foo(bar));