草庐IT

c++ - std::function 绑定(bind)到成员函数

以下代码在VS2012中无法编译classZot{public:intA(){return123;}};int_tmain(intargc,_TCHAR*argv[]){std::functionfn=&Zot::A;return0;}但是,将分配更改为std::functionfn=std::bind(&Zot::A,std::placeholders::_1);有效。有很多在线示例显示了原始语法。C++11规范是否更改了某些内容以禁止使用此语法?作业是否有有效的缩写形式?编辑:编译器错误(针对可恢复性略微编辑)是:1>vc\include\functional(515):error

c++ - std::string::max_size() 作为静态成员

为什么max_size不是std::string的静态成员?这可以编译,但我觉得奇怪的是所有字符串共有的属性只能通过字符串的实例访问:std::size_tmax_size=std::string().max_size();为什么会这样实现? 最佳答案 Whyisn'tmax_sizeastaticmemberofstd::string?因为max_size返回值取决于字符串实例内部使用的分配器实例。 关于c++-std::string::max_size()作为静态成员,我们在Stac

c++ - QtCreator 调试器不显示 std::string 的值

我试图调试我的小词法分析器并遇到了这个问题:QtCreator-Debugger不显示我的std::string-variable的任何内容。我尝试在控制台中对其进行调试,但得到了相同的结果,只是简单的结构信息。我前几天用的那个版本的QtCreator确实显示了字符串的内容。所有其他STL元素,如std::vector、std::map、std::multimap等显示正确的数据,只是std::string类不正确。经过几个小时的谷歌搜索后,我发现了很多描述pretty-print创建的网页,我解决这个问题的非常笨拙的方法并没有帮助。我有什么想法可以摆脱这个错误吗?注意:字符串变量的“

c++ - 等价于 C++ std::set 在 Matlab 中

如何在Matlab中定义具有这些属性的set:独特的元素高效搜索已订购也许没有内置的容器,那么我怎样才能像C++中的std::set一样组合一些东西来获得以上东西呢? 最佳答案 您可以像这样使用Java的HashSet:>>x=java.util.HashSet;>>x.add(1);>>x.add(2);>>x.contains(1)ans=1>>x.contains(3)ans=0>>xx=[2.0,1.0]在评论中有人指出HashSet是无序的。这是完全正确的。我的错!您可以改用TreeSet,它是有序的:>>x=java.u

c++ - 查找抛出 std::out_of_range 的对象

我的一个程序抛出一个std::out_of_range。我知道这样做的原因,我正在某处访问索引为-1的vector。我不知道的是vector的名称(变量名称)和代码中的位置。我的程序产生的错误消息如下所示:terminatecalledafterthrowinganinstanceof'std::out_of_range'what():vector::_M_range_checkzsh:abort(coredumped)./main.xconfig.cfg而由其他人(他也使用g++)的代码生成的错误消息发布在问题C++accessingvector中看起来像这样:Errorforvec

c++ - std::vector 推速?

我正在使用vector来管理我的大型结构数据。但是突然间,当发现vector源代码时,我很惊讶地看到下面的一些代码:inlinevoidpush_back(const_Ty&_X){insert(end(),_X);}//...voidinsert(iterator_P,size_type_M,const_Ty&_X){//////////////////////////////////////////////////////////////iterator_S=allocator.allocate(_N,(void*)0);iterator_Q=_Ucopy(_First,_P,_S

c++ - 哪种数据结构支持高效删除和随机访问?

我正在寻找一种数据结构,我可以在其中有效地删除项目并支持随机访问。我还需要有效的插入,但由于元素的顺序并不重要,我认为我可以为它可能必须存储的最大元素数预分配内存,然后始终将新元素放在末尾,这样就不会重新分配或移动其他元素是必要的。据我所知,链表非常适合删除,但访问其元素可能需要O(n)时间。另一方面,一个简单的数组(例如C++中的vector)具有随机访问属性,但从这样的结构中删除一个元素的复杂度为O(n)。实际上,随机访问要求比我真正需要的要强。我只需要能够随机均匀地选择结构的一个元素。显然高效的访问属性意味着我需要的操作效率,但我不确定这两者是否等同。提前致谢!

c++ - 从 std::call_once 抛出异常

C++标准对使用抛出异常的函数执行std::call_once(§30.4.4.2/2)作了如下说明:2/Effects:Anexecutionofcall_oncethatdoesnotcallitsfuncisapassiveexecution.Anexecutionofcall_oncethatcallsitsfuncisanactiveexecution.AnactiveexecutionshallcallINVOKE(DECAY_-COPY(std::forward(func)),DECAY_COPY(std::forward(args))...).Ifsuchacallto

c++ - std::string 的 type_traits 段错误

从UsingSFINAEtocheckforglobaloperator收集信息和templates,decltypeandnon-classtypes,我得到了以下代码:http://ideone.com/sEQc87基本上,我将两个问题的代码结合起来,如果它有ostream声明,则调用print函数,否则调用to_string方法。摘自问题1namespacehas_insertion_operator_impl{typedefcharno;typedefcharyes[2];structany_t{templateany_t(Tconst&);};nooperatorstruct

c++ - 切片 std::array

有没有一种简单的方法可以在C++中获取数组的一部分?也就是说,我有arrayarr10;并希望获得由arr10的前五个元素组成的数组:arrayarr5=arr10.???(除了通过遍历第一个数组来填充它之外) 最佳答案 std::array的构造函数是隐式定义的,因此您无法使用另一个容器或迭代器的范围对其进行初始化。您可以获得的最接近的是创建一个辅助函数来处理构造期间的复制。这允许进行单阶段初始化,我相信您正在努力实现这一目标。templateXCopyArray(constY&src,constsize_tsize){Xdst;