草庐IT

c++ - 如何在转换运算符中使用 std::enable_if?

基本上我希望我的范围类型可以从Range隐式转换至Range.std::enable_if似乎是不可能的,因为该函数不带任何参数并且没有返回值。解决办法是什么?这基本上是我尝试过的:templateclassRange{T*begin_;T*end_;public:Range(T*begin,T*end):begin_{begin},end_{end}{}templateRange(T(&a)[N]):begin_{static_cast(&a[0])},end_{static_cast(&a[N-1])}{}T*Begin(){returnbegin_;}T*End(){return

c++ - 为什么 std::vector 这么快(或者我的实现太慢了)

前几天我在玩游戏,想看看我能优化到什么程度。我决定从一个简单的map开始,它只进行线性搜索以查找元素是否存在,然后尝试优化其中的大部分内容。此外,为了进行比较,我使用std::find对std::map和std::vector执行相同的操作。map的结果是预期的,创建和销毁比我的map慢,但速度快得多(实际上,我一直无法测量它,它总是返回0)。问题在于std::vector。我预计它会比我的实现慢,但事实并非如此,而且我真的不明白它怎么可能相同或更快,因为我的实现跳过了最坏的情况(值不在vector中)并且是使用结果缓存。任何人都可以在这里阐明一些问题吗?我知道STL背后的家伙是半神,

c++ - 流内容与返回字符串 `str()` 的区别?

我正在使用asmallpieceofcode生成我在互联网上找到的PDF文件,并尝试(温和地)优化它,因为创建文件需要很长时间。分析后,我将其缩小为以下代码:std::ostringstreamtmp;tmp发现在一个紧密的循环中,out是一个ostringstream,它在写入文件之前基本上包含整个PDF内容。我发现tmp.str()是该循环中花费最多时间的行,并且在查找C++引用时看到str()会返回一个拷贝流的基础字符串。然后,我认为删除该拷贝并直接使用out会更快。所以我转储了tmp并直接做了:out但是现在,生成的PDF文件被认为是“损坏的”,无法用PDF阅读器打开,而以前的

c++ - 如何使用 std::stoi 作为默认值创建 std::function 作为方法参数?

我想使用std::function作为方法的参数,并将其默认值设置为std::stoi。我尝试了以下代码:voidtest(std::functioninFunc=std::stoi)不幸的是,我收到以下错误:noviableconversionfrom''to'std::function'我设法通过添加创建专用方法进行编译。#include#includeintmy_stoi(conststd::string&s){returnstd::stoi(s);}voidtest(std::functioninFunc=my_stoi);第一个版本有什么问题?难道不能使用std::stoi作

c++ - 如何让 "std::cout << 123456789.12"打印 "123456789.12"?

如何制作std::cout打印这个:123456789.12它总是打印这个:1.23457e+008我知道我必须玩旗帜,但我不太清楚正确的组合。如果我设置固定标志,它会打印123456789.120000 最佳答案 如何......?一种方式:-#include#includeintmain(){doublef=123456789.12;std::cout参见here请寻找合适的引用资料 关于c++-如何让"std::cout https://stackoverflow.c

c++ - 可以使 C++ 枚举大于 64 位吗?

在我的entitycomponentsystem我使用位掩码跟踪和查询每个实体具有哪些组件。//ThankstoShafikYaghmourforthemacrofix#defineBIT(x)(static_cast(1)has_components(mask)){...}我已经达到枚举的64位限制。C++枚举(可移植)是否可以大于64位?更新1:我知道std::bitset,但我无法创建像automask=std::bitset{components::foo,components::baz}这样的掩码因为std::bitset没有采用std::initializer_list的构

c++ - 如何将使用默认参数的函数传递给 std::thread?

所以我有gcc版本4.8.1,g++版本4.6.4,使用标志:-std=c++0x和-pthread。我将我的问题简化为显示的代码,但仍然得到原始错误。我编译了下面的内容,但是当我取消注释线程“two”的两行时,我收到代码下方显示的错误消息#include#includeusingnamespacestd;voidprint_int(intx=7);voidprint_A(){cout我试图解析错误消息,但我仍然不知道发生了什么...Infileincludedfrom/usr/include/c++/4.6/thread:39:0,fromdef_params.cpp:2:/usr/

c++ - 通过通用引用传递的函数的 std::forward?

考虑以下两个:templatevoidapply(Function&&function){std::forward(function)();}和templatevoidapply(Function&&function){function();}在什么情况下有区别,具体有什么区别? 最佳答案 如果Function的operator()具有ref限定符,则存在差异。使用std::forward,传播参数的值类别,没有它,值类别将丢失,函数将始终作为左值调用。LiveExample.#includestructFun{voidoperat

c++ - std::streampos 是否保证为 unsigned long long?

std::streampos是否保证为unsignedlonglong?如果不是这样,std::istream::seekg如何在大于4G的文件上正常工作? 最佳答案 来自http://en.cppreference.com/w/cpp/io/fpos:std::streampos是类模板的特化templateclassfpos;std::streampos类型定义为std::fpos::state_type>类型为fpos的每个对象保存流中的字节位置(通常作为std::streamoff类型的私有(private)成员)。来自ht

c++ - std::make_integer_sequence 究竟是如何实现的?

我正在观看C++11/14元编程演讲,其中描述了常见算法和tmp模式的一些有效替代方案。大部分效率提升来自使用可变参数模板而不是递归遍历,在许多情况下,使用可变参数模板的方法是扩展通过索引技巧或其他std::integer_sequence实例化技巧。由于这种效率来自实例化std::integer_sequence的事实,特别是别名std::make_integer_sequence不是一项昂贵的任务,我想确保当前最先进的C++1y标准库实现效率足以使make_integer_sequence实例化不是一项复杂且耗时/内存的任务。std::make_integer_sequence在C