草庐IT

std-ranges

全部标签

c++ - swig 对基类 'std::string' 一无所知,忽略

我正在尝试使用swig围绕C++库构建ruby​​包装器。其中大部分似乎都有效,但我有一个问题,我很确定与上述警告有关。看起来我正在包装的类之一是从std::string继承的。我在运行swig时看到上面的警告消息。当我在应该返回字符串的ruby​​对象上调用方法时,我看到了这个SWIG::Type_p_std__string:0x.....我在想我需要解决上面的警告,让它起作用,有什么想法吗? 最佳答案 SWIG提示它不知道std::string类,因此无法为其生成代码。SWIG库std_string.i具有用于将C++字符串映射

c++ - 无法从 std::shared_ptr <_Ty> 转换参数 1 (??)

在完成我的游戏原型(prototype)时,我遇到了这个错误,我以前从未见过。我试图将两个.cpp文件链接在一起,这个:#include#include"mage.h"#include"Warrior.h"#include"Rogue.h"#include"CharacterType.h"#include#include#include"Inventory.h"#include"blankEnemy.h"#include"Enemy.h"#include"Boss.h"#include#include#include"DeathMenu.h"#include"GameStart.h"#

c++ - 作为 std::vector 包装器的用户定义容器应该继承还是包含 std::vector?

作为std::vector包装器的用户定义容器应该继承还是包含std::vector?我有一个应该是容器的类。我看到两个选项:1)从vector继承2)有一个私有(private)成员vector并覆盖所有vector函数以使我的容器充当vector我不确定这是否只是风格的问题,还是从根本上来说更好比另一个?我想添加的额外功能很小,这里的数据成员和函数很少在那里。大多数情况下,处理vector中的数据将是方便的功能。 最佳答案 首先,STL容器不应该被继承。他们甚至没有虚拟析构函数。其次,选择组合/聚合而不是继承总是更可取的,因为这

c++ - 使用 MS 编译器的 std::cout 非常慢

我正在打印多次计算迭代的进度,输出实际上是其中最慢的部分,但只有当我使用VisualC++编译器时,MinGW才能在同一系统上正常工作。考虑以下代码:#include#includeusingnamespacestd;#defineTO_SEC(Time)\chrono::duration_cast>(Time).count();constintREPEATS=100000;intmain(){autostart_time=chrono::steady_clock::now();for(inti=1;i现在使用MinGW(“g++source.cpp-std==c++11”)编译时得到

c++ - 如果 T 不可 move ,则 std::vector<T> 是否可 move ?

我在尝试movestd::vector时遇到崩溃其中T显然是不可move的(没有定义move构造函数/赋值运算符,它包含内部指针)但为什么vector的move函数要调用T的move函数??应该没有必要。所以我的问题来自标题:是std::vector如果T可move不可move? 最佳答案 是的,std::vector即使T也是可move的不可move。左侧仅从右侧的vector中获取所有权,不涉及任何元素。(除了一个异常(exception),在#2中列出)vector的move分配只会调用T的move构造函数或move赋值如果和

c++ - 提供给 std::generate 的仿函数可以是有状态的吗?

最近我读到,如果传递的仿函数是有状态的(有内部副作用),一些STL算法会有未定义的行为。我已经将std::generate函数与一个类似于(不太重要)的仿函数一起使用:classGen{public:explicitGen(intstart=0):next(start){}intoperator()(){returnnext++;}private:intnext;};与std::generate一起使用是否安全?生成值的顺序是否有保证?编辑:此处提出声明Statefulfunctors&STL:Undefinedbehaviour 最佳答案

c++ - 使用 std::copy 复制所有元素的地址

我正在尝试获取给定集合的所有元素的地址并将它们复制到std::set。基本上,而不是std::sets1;std::copy(first1,last1,std::inserter(s1,s1.begin()));我想插入他们的地址。像这样的东西:std::set>s1;std::copy(reference_iterator(first1),reference_iterator(last1),std::inserter(s1,s1.begin()));在这里,reference_iterator将是一个迭代器,返回其元素的地址,而不是元素,这与boostindirect_iterato

c++ - "vector iterator + offset out of range"断言有用吗?

这个完美的程序在VisualStudio2013的Debug模式下失败:#include#include#includeusingnamespacestd;voidmain(){vectorv={3,1,4,1,5,9,2,6,5,3};for(autoiFrom=v.cbegin(),iTo=iFrom+5;iFrom!=v.cend();iFrom=iTo,iTo+=5)coutvectoriterator+offsetoutofrange断言失败。它失败是因为iTo>v.cend(),这在这里是无害的。调试器测试没有被取消引用的迭代器的值有什么意义?顺便说一句,我知道我可以将上面

c++ - 如何解析像 std::allocator_traits 这样的可选嵌套类型?

分配器可以选择嵌套类型,如pointer,const_pointer.但是可以始终将这些接口(interface)与std::allocator_traits一起使用,如果这些类型在Allocator中不存在,它将提供这些类型的默认版本.如何std::allocator_traits实现的?模板如何在不存在时选择嵌套类型的默认版本? 最佳答案 解决方法是引用类型T::pointer在不是有效类型时不会导致错误的情况下,它会导致模板参数推导失败。其一般形式称为SFINAE,代表“替换失败不是错误”。有关其工作原理的解释,请参阅我的SF

c++ - 从 std::stringstream 传递 std::string 引用作为参数

我正在使用std::stringstream构造一个字符串,然后尝试将完成的字符串作为对函数的引用传递,该函数将std::string&作为参数。我在GCC上遇到编译错误:../src/so.cpp:22:21:error:invalidinitializationofnon-constreferenceoftype‘std::string&{akastd::basic_string&}’fromanrvalueoftype‘std::basic_stringstream::__string_type{akastd::basic_string}’../src/so.cpp:12:6:e