草庐IT

c++ - 从 "foo<T>"转换为 "const foo<const T>"- C++

我有一个类似的函数(请不要关心通过引用返回临时值。这只是一个解释问题的例子),constfoo&get_const(){foof;returnf;}这显然无法编译。我正在寻找一种方法来确保调用者不会更改T的foo.我怎样才能确保这一点?我已经看到boost::shared_ptr的类似行为.shared_ptr可转换为constshared_ptr.我不知道它是怎么做到的。任何帮助都会很棒。 最佳答案 编译器看到foo和foo作为两种完全不同且不相关的类型,所以foo与任何其他转换一样,类需要明确支持这一点。如果您可以控制foo类,

c++ - isalpha(<mychar>) == true 计算结果为 false?

stringtemp等于来self的调试器的“ZERO:\t.WORD\t1”。(我文件的第一行)stringtemp=RemoveWhiteSpace(data);inti=0;if(temp.length()>0&&isalpha(temp[0]))cout0&&isalpha(temp[0])==true)cout这是我的代码,用于检查temp的第一个字符是否为a-z、A-Z。第一个if语句将评估为true,第二个if语句将评估为false。为什么?!?!?!即使没有“temp.length()>0&&”,我也试过了,它仍然评估为false。它只是讨厌“==true”。我唯一能想

C++ <map> vs <unordered_map> vs <tr1/unordered_map> vs <ext/unordered_map>

我目前正在寻找std::map的更好替代方案,并且遇到了帖子标题中提到的类。有人可以阐明它们之间的区别,不是在性能/API方面,而是在它们与当前和future的通信标准相关的地方。 最佳答案 std::map:当前的C++标准关联容器(键/值),作为后面的树;std::unordered_map:下一个标准(C++0x——或在技术报告1中)散列映射容器,用作...散列映射。std::tr1::unordered_map:与前一个相同,但在tr1命名空间中,通常出现在希望提供TR1扩展但在不同于std的另一个命名空间中的编译器中。ex

cout <<自动的C++格式

如果我有一个包含两个变量x和y的简单类,以及一个返回带有数据的格式化字符串的函数ToString()。当我打电话时cout有人知道我可以自动调用simpleClass.ToString以返回格式正确的字符串的方法吗?我猜想有一种方法可以使用运算符函数来执行此操作,但我不知道该怎么做。 最佳答案 如果你问如何定义这样的运算符,templatestd::basic_ostream&operator&os,SimpleClassconst&sc){returnos 关于cout

c++ - std::priority_queue<> 什么时候进行 self 排序?

我想知道什么时候C++STLpriority_queue自行排序。我的意思是它insert当你push中的项目,或者当你peek时,它会自行排序并给你最高优先级的项目吗?或pop出来?我问这个是因为我的priority_queue将包含一个可能有值更新的数组的索引,我希望它在我执行pq.top();时更新.#include#include#includeusingnamespacestd;intmain(){priority_queuepq;pq.push(2);pq.push(5);//isthefirstelement5now?orwillitupdateagainwhenItop

c++ - is_lock_free 未在 gcc 4.7.2 的 std::atomic<T> 中定义?

我遇到这个编译器错误functionstd::atomic::is_lock_free()const:error:undefinedreferenceto'__atomic_is_lock_free'whencompilingcodelikebelowusinggcc4.7.2onlinux.structS{inta;intb;};std::atomics;cout 最佳答案 AtomicAPIisn'tcompleteinGCC4.7:Whenlockfreeinstructionsarenotavailable(eitherth

c++ - 如何理解函数ostream& operator<< (ostream& os, const unsigned char* s)

对于像这样的函数声明ostream&operator我想知道返回了什么。CPP引用说它返回ostream对象。但为什么它是ostream&而不是简单的ostream?谢谢 最佳答案 运算符返回ostream&(即对ostream对象的可修改引用)而不是拷贝或void的原因是它允许链接,因为实例,以std::cout作为ostream对象的常见示例:unsignedinti=2;std::cout这里我们链接了两个constchar*,一个unsignedint和一个流修饰符,而不必用单独的行将它们分开,这使得阅读和明白了。

c++ - 让 std::complex<double> 通过 std::is_floating_point 测试

我想要类型double,float,complex和complex通过static_assert健康)状况。我想static_assert(std::is_floating::value,"somemessage")可以解决问题,但是复杂类型没有通过这个测试(至少在gcc-4.10下是这样)。我应该添加什么谓词来确保这四种类型(可能还有longdoubles)被允许作为模板实例化,但没有别的? 最佳答案 为标准库类型特征类添加特化通常是非法的,即使是用户定义的类型也是如此。§20.10.2[meta.type.synop]/p1:T

c++ - 尽管未定义 <new> header ,但 New 会抛出 bad_alloc?

new是怎么回事?程序中的表达式可以抛出bad_alloc尽管没有#include还是出错(因为这个错误isdefinedintheheader)?来自3.7.4。N3337的:Thelibraryprovidesdefaultdefinitionsfortheglobalallocationanddeallocationfunctions.Someglobalallocationanddeallocationfunctionsarereplaceable(18.6.1).AC++programshallprovideatmostonedefinitionofareplaceablea

c++ - #define for(int z=0;z<2;++z)for(int z=0;z<2;++z)for 中的第三个 'for' 是什么意思

我在一个C++程序中找到了一段代码,好像每隔for()循环两次。在这个程序中循环,但为什么在这样的预处理器定义中需要第三个for呢?#defineforfor(intz=0;z 最佳答案 它取代了for与for(intz=0;z.显然,那会变成for(inti=0;i进入for(intz=0;z因此创建了两个嵌套循环。没有那个额外的for会是for(intz=0;z这显然是不正确的。请注意,即使您在问题中提供的形式是“正确的”,但这并不意味着它是“良好做法”。这是过度滥用宏的示例,必须避免。这是它可能出错的众多示例之一:for(in