草庐IT

conversion-operator

全部标签

C++ 重载歧义 : conversion versus promotion with primitive types

在这段代码中:voidf(floatf,longinti){cout有一个歧义。Checkitout!.但是,第二个参数是有符号整数。将int绑定(bind)到longint参数需要提升,但对于float,则需要转换。由于第一个参数是关于两个重载的完全匹配,所以它不算数。但是关于第二个参数,它在第一次过载(提升)上的排名优于在第二个(转化)上的排名。为什么会出现解析歧义,而不是选择第一个重载? 最佳答案 int到long是一个转换。short到int是一种提升。(有关积分促销的完整列表,请参阅[conv.prom]。)同理,floa

c++ - 为 std::unordered_map 中的 const std::reference_wrapper 重载 operator==

我不知道如何使用std::reference_wrapper将std::string引用获取到std::unordered_map中>。根据以下链接,我知道我需要重载operator==。Whycantemplateinstancesnotbededucedin`std::reference_wrapper`s?但是,我不知道如何编写operator==以使其采用conststd::reference_wrapper。如果包装器不是const,那将不是问题。使用char而不是std::string效果很好(不需要重载operator==)。代码:#include#include#inc

c++ - 错误 : invalid conversion from 'const int*' to 'int*'

我想创建一个简单的3x3矩阵类并能够通过下标运算符访问其内容。这是代码://Matrix.hclassMatrix{private:intmatrix[3][3];public:int*operator[](constintindex)const;};//Matrix.cppint*Matrix::operator[](constintindex)const{returnthis->matrix[index];}无论Matrix的对象是常量还是非常量,我都希望能够访问数组的元素。但是我从编译器中得到以下错误:错误:从“constint*”到“int*”的无效转换[-fpermissiv

c++ - 在 std::array 中重载 operator[]

我想优化我的代码,重载std::array中的方括号[]运算符,我在任何地方都使用它减一。代码编译但从不调用重载函数,谁能告诉我为什么?#include#includeclassA{std::arrayvar{0,1,2,3,4};std::array::value_type&operator[](std::size_tp_index);};std::array::value_type&A::operator[](std::size_tp_index){returnvar[p_index-1];}intmain(){Aa;std::cout代码返回“1”,但我希望返回“0”。提前致谢!

c++ - array::operator[] 实际上是 noexcept 吗?

根据cppref,当前未指定重载noexcept。但我认为它们实际上是noexcept,对吧?由于不执行边界检查。所以没有像array::at这样的out_of_range异常.如果输入超出范围,就会发生低级段错误或访问冲突,这超出了C++异常范围(我猜)。 最佳答案 operator[]没有标记为noexcept的原因是它有一个“窄契约”,即要求索引值在范围内0...N-1。如果传递的值不在该范围内,则行为未定义,并且(谁知道?)函数可能会抛出异常。关于不将具有“狭义契约”的事物标记为noexcept,该标准非常一致。这被非正式地

Linux 删除文件提示:rm: cannot remove ‘XXXX‘: Operation not permitted 解决方案

       今天遇到一个很恼火的问题,就是在维护TP6项目时,无法在Linux中删除原有的vendor文件夹,更新进去新的内容,因为composer新require的必要的内容,本想着讲原有的删掉,直接讲压缩包放上去,解压,简单暴力,万万没想到。。。root@saas:/mnt/sites/saas#rm-rfvendorrm:cannotremove'xxxx':Operationnotpermittedrm:cannotremove'xxxx':Operationnotpermittedrm:cannotremove'xxxx':Operationnotpermittedrm:canno

c++ - 与运算符(operator)混淆

当我试图理解下面的代码时,我感到很困惑。任何人都可以解释这个黑客:a.*b或者如果a是一个指向类的指针:a->*b 最佳答案 这两个运算符都用于取消引用指向成员的指针。与常规指针不同,指向成员的指针本身不能取消引用,但必须应用于该类型的实际对象。这些二元运算符选择左侧的对象(或指针)并将指向成员的指针应用于它。structtest{inta,b,c;};intmain(){inttest::*ptr;ptr=&test::a;testt;t.*ptr=5;//sett.ato5ptr=&test::b;test*p=&t;p->*p

c++ - 我应该在我的 C++ WIn32 应用程序中重写 operators new/delete

我知道Microsoft自己曾经建议通过调用HeapCreate()和HeapAlloc()来覆盖operatornew,但那是不久前的事了。有关详细信息,请参阅KB139638。在Win32上重写new/delete是否仍然有益?推荐的实现方式是什么?TIA。 最佳答案 这篇文章说你可以做,而不是说你应该。其中的代码写得很糟糕,一点也不有趣,而且它不是线程安全的。通常,提供的new和delete实现可以很好地满足所有一般编程需求。只有当您确定了重新实现可以解决的特定问题时,您才应该考虑重新实现它们。

c++ - operator<< 用于嵌套类

我正在尝试为嵌套类ArticleIterator重载//...classArticleContainer{public:classArticleIterator{//...friendostream&operator如果我像往常一样定义运算符friendostream&operator错误是在类外使用了'friend'。我该如何解决这个问题? 最佳答案 定义函数时不要放置friend关键字,仅在声明时放置。structA{structB{friendstd::ostream&operator

c++ - 标准转换 : Array-to-pointer conversion

这是来自ISO的要点:标准转换:数组到指针的转换:$4.2.1Anlvalueorrvalueoftype“arrayofNT”or“arrayofunknownboundofT”canbeconvertedtoanrvalueoftype“pointertoT.”Theresultisapointertothefirstelementofthearray.谁能解释一下,如果可能的话,用一个示例程序。我已经看过这些链接,但我无法理解:ArrayandRvalueIthinkImayhavecomeupwithanexampleofrvalueofarraytype