草庐IT

or-Operator

全部标签

c++ - operator<< 重载如何工作?

给定一个类:structemployee{stringname;stringID;stringphone;stringdepartment;};下面的函数是如何工作的?ostream&operatorcout为给定的employeee生成格式化输出.示例输出:AlexJohnsonEmp#:5719Dept:RepairPhone:555-0174我无法理解ostream函数的工作原理。它如何获取参数“ostream&s”?它如何重载“ 最佳答案 这称为重载解析。你写了cout.编译器将其视为operator,其中cout是ostr

c++ - 数组 : Storing Objects or References

作为一名Java开发人员,我有以下C++问题。如果我有类型A的对象并且我想将它们的集合存储在一个数组中,那么我应该只存储指向对象的指针还是存储对象本身更好?在我看来,存储指针更好,因为:1)通过将对象的指针设置为null,可以很容易地删除对象2)节省空间。 最佳答案 指针还是对象?在C++中不能将引用放在数组中。您可以制作一个指针数组,但我仍然更喜欢容器和实际对象而不是指针,因为:没有机会泄漏,异常安全更容易处理。它并没有减少空间——如果你存储一个指针数组,你需要对象的内存加上指针的内存。我唯一提倡将指针(或智能指针会更好)放入容器

c++ - operator new 负数

在C++11中,如果我们尝试使用全局运算符new分配负大小的数组,它会抛出std::bad_array_new_length,但是C++98/C++03呢?是UB还是会抛出std::bad_alloc?intmain(){int*ptr=newint[-1];} 最佳答案 如果大小为C++03标准的负数5.3.4p6,则程序不正确:Everyconstant-expressioninadirect-new-declaratorshallbeanintegralconstantexpression(5.19)andevaluateto

c++ - 在工作中遇到这个 "operator ClassName *"。这是什么意思?

有这段代码的类是ClassName指针的引用类,即:classClassName;classClassRef{ClassName*m_class;...operatorClassName*()const{returnm_class;}...我假设这用于指针有效性检查,例如:ClassRefref(newClassName())if(ref){blablabla}我的想法正确吗? 最佳答案 这是转换运算符的重载。每当需要将ClassRef对象转换为ClassName指针类型时,都会调用此运算符。所以;ClassRefr;ClassNa

c++ - "or"和 "||"之间的区别

有什么区别吗if(aorborc){...和...if(a||b||c){...以及两个运算符之间的一般情况,甚至在优先级方面? 最佳答案 除了让很多经验丰富的程序员认为“哈,有人突然开始写Pascal了吗?”的风格感觉之外,没有功能上的区别。这些替代名称的目的是让居住在瑞典或德国等地的人们使用ASCII的标准本地变体,其中|是ö。自从引入Unicode和扩展ASCII以来,这种需求几乎消失了,因为民族化字符集不必“窃取”不常用的字符来生成其民族“特殊”字符。 关于c++-"or"和"|

c++ - operator const Base&() 是否应该用于不可访问的基类?

我希望有一个类允许访问其基本情况的const接口(interface),但不允许访问其他类。特别是:classB{};classA:privateclassB{public:operatorconstB&(){return*this;}};intmain(){Aa;constB&b=a;//Shouldthislinebeanerror?}g++给出了一个不可访问的基类错误。你们那里的语言专家认为这个错误在C++11/C++14中是正确的吗?是的,我意识到我可以(并且将会)这样做:intmain(){Aa;constB&b=a.operatorconstB&();}对这个构造的另一种方

c++ - std::vector 保留后 operator[] 上 msvc 和 gcc 之间的行为差​​异,哪个是对的?

Thissnippetofcode使用msvc(越界错误)惨遭失败,但似乎在gcc和clang上都能正常工作。什么是正确的行为?#include#includeintmain(){std::vectorv;v.reserve(10);for(inti=0;i 最佳答案 行为未定义。reserve只保留内存,不影响容器的大小。也许您想使用resize?std::vectorv;v.resize(10);for(inti=0;i虽然在这种情况下你可以写std::vectorv(10);for(inti=0;i或者,您可以将reserve

c++ - 仅在与类的其他对象进行比较时,是否有任何理由不将 operator== 作为成员重载?

我一直在互联网上寻找答案,但我找不到任何答案。给出的唯一原因似乎与比较不同类型的对象有关(例如MyClass==int)。但最常见的用例是将一个类实例与同一类的另一个实例进行比较,而不是与任何不相关的类型进行比较。换句话说,我确实理解以下方面的问题:structA{booloperator==(intb);};但是我找不到任何好的理由在最明显的用例中不使用成员函数:structA{booloperator==(constA&);};最规范的重复Whatarethebasicrulesandidiomsforoperatoroverloading?作为经验法则说“将二元运算符重载为非成员

c++ - operator new 如何调用类的构造函数?

我知道,new操作符会调用类的构造函数。但是它是如何发生的,用于此的底层技术是什么。 最佳答案 这是我想象的样子:T*the_new_operator(args){void*memory=operatornew(sizeof(T));T*object;try{object=new(memory)T(args);//(*)}catch(...){operatordelete(memory);throw;}returnobject;}(*)从技术上讲,它并不是真正调用placement-new,但只要你不重载它,心智模型就可以正常工作:

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和一个流修饰符,而不必用单独的行将它们分开,这使得阅读和明白了。