C赋值运算符 – 编译器生成还是自定义?

栏目: 服务器 · 编程工具 · 发布时间: 5年前

内容简介:如果您编写了自己的析构函数或复制构造函数,通常只需要编写自己的赋值运算符.如果您不需要那些,那么您也不需要赋值运算符.翻译自:https://stackoverflow.com/questions/3571975/c-assignment-operator-compiler-generated-or-custom

我有一个中等复杂的C类,它拥有从光盘读取的一组数据.它包含浮动,整体和结构的折衷混合,现在通常使用.在主要代码审查期间,询问我们是否有自定义赋值运算符,或者我们依赖于编译器生成的版本,如果是,我们如何知道它是否正常工作?好吧,我们没有编写自定义任务,因此添加了一个单元测试来检查我们是否这样做:

CalibDataSet datasetA = getDataSet();
CalibDataSet dataSetB = datasetA;

那么datasetB就像datasetA一样.几百行左右.现在,客户坚持认为我们不能依赖编译器(gcc)对未来的版本是正确的,我们应该编写自己的版本.他们坚持这个是正确的吗?

附加信息:

我对已发布的答案/评论和响应时间印象深刻.另一种提出这个问题的方法可能是:

POD结构/类何时成为’非’POD结构/类?

如果您编写了自己的析构函数或复制构造函数,通常只需要编写自己的赋值运算符.如果您不需要那些,那么您也不需要赋值运算符.

翻译自:https://stackoverflow.com/questions/3571975/c-assignment-operator-compiler-generated-or-custom


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

CSS3实用指南

CSS3实用指南

吉伦瓦特 / 屈超、周志超 / 人民邮电出版社 / 2012-3 / 49.00元

CSS3为Web的视觉样式语言注入了强大的新功能,让设计人员更加轻松自如地设计优美而引人入胜的内容。借助CSS3,不使用图片就可以创建半透明背 景、渐变、阴影等夺人眼球的视觉效果;还可以使用漂亮、独特、非Web安全的字体显示文本;不用Flash就可以创建动画;不用JavaScript就可 以定制适应用户的设备和屏幕尺寸的设计。 本书通过一系列实用且新颖的范例,向读者展示如何实现以上功能和更多......一起来看看 《CSS3实用指南》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

在线进制转换器
在线进制转换器

各进制数互转换器

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具