草庐IT

c++ - C++ 迭代器是否应该在传递最后一项后递减?

我一直在修改我的容器以兼容STL。我修改了我的迭代器以具有必要的功能。它们都是随机访问迭代器。目前它们可以很好地与所有适用的STL算法一起使用。但是我的一个迭代器一旦变得无效(越界)就不会起作用。有必要拥有这个属性吗?具体来说,我害怕不能递减的end()迭代器。请注意,它可以与其他有效迭代器进行比较,甚至可以计算距离。目前迭代器的大小是4个字节,如果不是真的需要,我真的不想再添加4个字节。提前致谢,杰姆 最佳答案 对于random_access_iterator这是必需的。你将不得不实现它。具体来说,根据24.1.4.1对于bidi

c++ - 给定字符串 vector (按长度排序),用于查找等长字符串范围的惯用 C++

给定一个std::vector,vector按字符串长度排序,如何找到等长强度的范围?我期待C++中的惯用解决方案。我找到了这个解决方案://anyideaforabettername?(Englishisnotmymothertongue)boolless_length(conststd::string&lhs,conststd::string&rhs){returnlhs.length()words;words.push_back("ape");words.push_back("cat");words.push_back("dog");words.push_back("camel"

c++ - 如何在 C++ 中使用 remove 命令删除句子中的空格?

我得到一个文件作为输入,我这样读第一行(引号标记开始和结束,但不在文件中):"1,2.0,3.0,4.0"当我像这样使用删除命令时:astring=line;cout我得到的输出是:1,2.0,3.0,4.02.0,3.0,4.0我只需要1,2.0,3.0,4.0的输出。这里有什么问题? 最佳答案 std::remove只是将序列中所有未移除的元素向前移动;然后您需要使用erase截断底层容器:s.erase(std::remove(s.begin(),s.end(),''),s.end());这称为删除-删除习语。remove无法

c++ - 未初始化的类字段和 STL 容器

在将对象放入其中之前,STL默认分配器是否将原始内存清零?请参阅此代码。评论反射(reflect)了我平台上的行为。#include#includestructFoo{Foo(){}//nisn'tinitializedintn;};intmain(){std::vectorv(2);//zeroedstd::cout是否可以禁用清零原始内存?注意,它与初始化POD的值不同。 最佳答案 它可能会清零内存。它可能不会。它可能会从您最喜欢的已经清零的操作系统中恢复它——我知道Windows有清零内存的习惯。有一件事是肯定的-它没有定义,

c++ - solaris (x86) 上std::basic_string 的一些疑惑

solaris(x86)上std::basic_string的一些困惑#include#includeintmain(){constwchar_t*s=L"abcdef";std::wstringws(s,s+6);for(inti=0;i运行结果为:9799101000为什么不是979899100101102代码#include#includeintmain(){constwchar_t*s=L"abcdef";std::wstringws;ws.resize(6);for(inti=0;i可以得到预期的结果。我使用gcc3.4.6,构建命令是g++-fshort-wcharstri

c++ - 我如何为 tr1::unordered_map 定义一个不绑定(bind)模板参数的宏/typedef/etc?

这可能是个有点傻的问题,但我不得不问。我正在尝试在C++中使用unordered_map类,但不是每次都将其作为tr1::unordered_map引用,我只想使用关键字hashMap。我知道typedeftr1::unordered_maphashMap有效,但这种修复了键的数据类型和对应于hashMap的值,而我希望有更多类似以下内容:#definehashMaptr1::unordered_map我可以根据需要定义键和值的数据类型,但这不起作用。以前有人遇到过这个问题吗?谢谢 最佳答案 这是C++11之前的C++所缺少的东西。

c++ - 以两种数据类型作为参数的堆栈 STL

本程序取自cplusplus.com#include#include#include#includeusingnamespacestd;intmain(){dequemydeque(3,100);//dequewith3elementsvectormyvector(2,200);//vectorwith2elementsstackfirst;//emptystackstacksecond(mydeque);//stackinitializedtocopyofdequestack>third;//emptystackusingvectorstack>fourth(myvector);co

c++ - STL 容器要求

标准是否要求some_container::value_type是T?我问这个问题是因为我正在考虑采用不同的方法来实现符合STL标准的二维动态数组。其中之一是拥有2Darray::value_type是2Darray_row或类似的东西,其中数组将迭代为行的集合(有点简化。我的实际实现允许在3个方向上迭代) 最佳答案 容器要求有点古怪,因为它们实际上没有被任何通用算法使用。从这个意义上说,这并不重要。也就是说,要求是针对容器的接口(interface),而不是容器的实际实例化方式。即使是非模板类也可以符合各种要求,事实上也确实如此。

c++ - 迭代器声明 : "does not contain a type"

我很难理解为什么会收到此错误。我指的是Josuttis的STL书和其他资源,看来我在下面声明我的迭代器的方式应该有效:#ifndefLRU_H#defineLRU_H#include#includeclassLRU{public:LRU();//defaultconstructorLRU(int);//constructorwithargument~LRU();//destructor//Methods//voidenqueue(int);//adddatumtothequeuevoiddequeue();//removedatumfromthequeuevoidreplace();/

c++ - C++中c_str()的线程安全

我创建了一个类SettingsClass,它包含静态字符串,这些静态字符串包含MySQLC++连接器库要使用的数据库连接字符串(例如主机名、数据库名、用户名、密码)。每当函数需要连接到数据库时,它都会对这些静态字符串调用.c_str()函数。例如:ClassSettingsClass{public:staticstringhostname;...}SettingsClass;stringSettingsClass::hostname;//AfunctionthatneedstoconnecttotheDBuses:driver=get_griver_instance();driver-