草庐IT

c++ - 使用 c++ 11 constexpr 进行 std::map 初始化

我想用constexpr键初始化一个std::map。考虑以下C++11MWE:#includeusingstd::map;constexprunsignedintstr2int(constchar*str,constinth=0){return!str[h]?5381:(str2int(str,h+1)*33)^str[h];}constmapvalues={{str2int("foo"),"bar"},{str2int("hello"),"world"}};intmain(){return0;}当代码编译最近的clang和gcc时,生成的二进制文件将包含key类型的字符串:为什么k

c++ - CMake,选择Xcode编译器

我知道直到最近还无法为CMake生成的xcode项目选择任何特定的编译器(它总是选择xcodes默认编译器)。无论如何这篇文章:http://cmake.3232098.n2.nabble.com/CMake-2-8-1-available-for-download-td4752230.html让我相信现在应该可以使用特定的CMAKE_XCODE_ATTRIBUTE_标志。-不幸的是,我既找不到应该更改xcodes编译器的标志,也找不到CMake支持的所有xcode标志的列表。我正在使用Xcode4.2和CMake2.8.6,我希望能够在CMake中在LLVM3.0和LLVMGCC4.

c++ - 无法使用 std=c++11 设置 Eclipse Juno C++

我有EclipseJunoC++(内部版本号:20120614-1722)。我正在尝试使用指令-std=c++11或-std=c++0x设置编译器调用参数,但在编译下面的代码时。EclipseJuno中没有“工具设置”(至少对于Mac是这样),所以我无法转到“C/C++构建->设置->工具设置”。我的编译器是GCC4.8.0#include#include#includeusingnamespacestd;intmain(void){vectorv={"a","b","c"};for(strings:v){cout我得到了:HelloWorld.cpp:16:33:error:coul

C++11(或 Boost)system_error 策略

我正在开发一个系统,该系统旨在使用名为error_code、error_condition和error_category的类——一个新的方案std:在C++11中,尽管目前我实际上正在使用Boost实现。我读过ChrisKholkoff的seriesofarticles,现在三遍了,我想我了解了如何创建这些类。我的问题是这个系统需要处理存在于单个DLL中的插件,而插件可能会出错。我最初的设计是计划一个特定于系统的错误类别,该类别将包含所有各种错误代码和未真正映射到errno值的特定错误条件的候选列表。这里的问题是,要使DLL能够使用这些错误代码之一,它需要访问应用程序中error_ca

c++ - Phoenix::bind for C++11 lambdas in boost::spirit::qi 语义 Action

我的目标是创建一个解决方法,以便我可以在BoostSpiritQi语义操作中使用C++11lambda,同时仍然可以访问更多扩展的qi占位符集,例如qi::_pass或qi::_r1,而无需从上下文对象中手动提取它们。我希望避免为一些重要的解析逻辑编写Phoenixlambda,而更喜欢C++11lambda中可用的更直接的C++语法和语义。下面的代码代表了我对解决方法的想法。我的想法是使用phoenix::bind绑定(bind)到lambda并将我需要的特定占位符传递给它。但是,我遇到了一个非常长的模板化编译器错误(gcc4.7.0,Boost1.54),我没有解释的专业知识。我选

使用默认默认构造函数的 C++11 值初始化

在下面的例子中:#includestructA{intz;A(std::string){}A()=default;};intmain(){charbuf[1000];std::fill(buf,buf+1000,'x');autoa=new(buf)A{};std::cerrz使用GCC4.8编译outputszero(与Clang3.4的行为相同)。这似乎表明a在调用默认构造函数之前被零初始化。但根据value-initializationrulesoncppreference.com,对象不应在默认构造函数调用之前初始化。A类符合C++11下的要点#1:1)IfTisaclasst

c++ - 使用 C++11 智能指针时,你能忘记 Checked-Delete 吗?

我读过unique_ptrwithincompletetypes关于CheckedDelete.但是,在使用智能指针或至少是C++11智能指针的一个子集时,checked-delete是否过时了?采用以下代码:classA;classB{public:std::auto_ptrautoPtr;std::unique_ptruniquePtr;std::shared_ptrsharedPtr;A*rawPtr;B();~B(){deleterawPtr;}};classA{public:~A(){std::cout(newA());uniquePtr=std::unique_ptr(ne

c++ - Xcode 无法停止正在运行的任务

当我在Xcode中运行C++程序时出现问题。总是有一个session说Debugxxx,但这无法停止。代码没有问题。这里是一些截图: 最佳答案 我也遇到过这个问题,我有几件事可能会奏效。请注意,这些不是错误修复,而是解决方法-它们可能不适用于您的情况。但是,我希望他们这样做...按顺序尝试...点击(上栏)->产品->停止,尽管您可能已经尝试过。单击(上栏)->产品->清洁。这可能会停止错误的任务。退出Xcode并重新打开。根据我的经验,这几乎总是会停止“正在运行”的任务。虽然我不需要走到这一步,但强制退出XCode(command

c# - C++ 中的 DirectX11 引擎和 C# 中的接口(interface)

我有一个用C++编写的DirectX11引擎,一个用C++编写的带有CLR的包装器,以及一个用C#编写的接口(interface)。1)我很好奇这种结构的瓶颈在哪里,我想知道是否有更有效的方法让我在WinForms控件中托管DirectX11渲染。2)有没有办法在WinForms控件所有者以外的线程上呈现?我对此表示怀疑,但我想我会问。3)有没有办法在不通过每个帧上的包装层的情况下渲染多个帧,但保持应用程序响应?我已经将此设置与SlimDX进行了比较,实际上在简单地清除屏幕而不进行任何其他API调用时,FPS会稍微变慢。SlimDX~3000FPS,我的引擎~2000FPS。这没什么大

C++11 实验,为什么我不能使用某些功能?

我目前正在概述C++11的新特性,由于目前不明原因,其中一些特性无法编译。我使用gccversion4.6.020100703(experimental)(GCC)所以根据GNUGCCFAQ,我尝试的所有功能都是supported.我尝试使用std=c++0x和std=gnu++0x标志进行编译。非成员begin()&end()例如,我不想在如下代码中使用非成员begin()和end():#include#include#include#includeusingnamespacestd;intmain(){mapalias;alias.insert(pair("ll","ls-al")