当前位置: 首页 > news >正文

如何采集网站文章视频网站应该怎么做

如何采集网站文章,视频网站应该怎么做,凡科建站骗子,网站建设完成阶段性总结报告C类的新功能 一、默认成员函数二、类成员变量初始化三、default关键字四、delete关键字六、final关键字七、override关键字 一、默认成员函数 八个默认成员函数 在C11之前,一个类中有如下六个默认成员函数: 构造函数。析构函数。拷贝构造函数。拷贝赋值…

C++类的新功能

      • 一、默认成员函数
      • 二、类成员变量初始化
      • 三、default关键字
      • 四、delete关键字
      • 六、final关键字
      • 七、override关键字

一、默认成员函数

八个默认成员函数

在C++11之前,一个类中有如下六个默认成员函数:

  1. 构造函数。
  2. 析构函数。
  3. 拷贝构造函数。
  4. 拷贝赋值函数。
  5. 取地址重载函数。
  6. const取地址重载函数。

这里“默认”的意思就是你不写编译器会自动生成,在C++11标准中又增加了两个默认成员函数,分别是移动构造函数移动赋值重载函数

默认移动构造和默认移动赋值的生成条件

C++11中新增的移动构造函数和移动赋值函数的生成条件如下:

  • 移动构造函数的生成条件:没有自己实现移动构造函数,并且没有自己实现析构函数、拷贝构造函数和拷贝赋值函数。
  • 移动赋值重载函数的生成条件:没有自己实现移动赋值重载函数,并且没有自己实现析构函数、拷贝构造函数和拷贝赋值函数。

注意: 如果我们自己实现了移动构造或者移动赋值,就算没有实现拷贝构造和拷贝赋值,编译器也不会生成默认的拷贝构造和拷贝赋值。

默认生成的移动构造和移动赋值会做什么?

  • 默认生成的移动构造函数:对于内置类型的成员会完成值拷贝(浅拷贝),对于自定义类型的成员,如果该成员实现了移动构造就调用它的移动构造,否则就调用它的拷贝构造。
  • 默认生成的移动赋值重载函数:对于内置类型的成员会完成值拷贝(浅拷贝),对于自定义类型的成员,如果该成员实现了移动赋值就调用它的移动赋值,否则就调用它的拷贝赋值。

要想验证默认生成的移动构造和移动赋值确实做了上述工作,这里需要模拟实现一个简化版的string类,类当中只编写了几个我们需要用到的成员函数。

代码如下:

namespace lx
{class Person{public:Person(string name, int age):_name(name),_age(age){}Person(const Person& p){_name = p._name;_age = p._age;}Person& operator=(const Person& p){_name = p._name;_age = p._age;}~Person(){ cout << "~person" << endl;}private:string _name;int _age; }
}

虽然Person类当中没有实现移动构造和移动赋值,但拷贝构造、拷贝赋值和析构函数Person类都实现了,因此Person类中不会生成默认的移动构造和移动赋值,可以通过下面的代码来验证:

int main()
{lx::Person s1("张三", 21);lx::Person s2 = std::move(s1); //想要调用Person默认生成的移动构造return 0;
}

上述代码中用一个右值去构造s2对象,但由于Person类没有生成默认的移动构造函数,因此这里会调用Person的拷贝构造函数(因为使用const修饰,拷贝构造既能接收左值也能接收右值),这时在Person的拷贝构造函数中就会调用string的拷贝构造函数对name成员进行深拷贝。

如果要让Person类生成默认的移动构造函数,就必须将Person类中的拷贝构造、拷贝赋值和析构函数全部注释掉,这时用右值去构造s2对象时就会调用Person默认生成的移动构造函数。

  • Person默认生成的移动构造,对于内置类型成员age会进行值拷贝,而对于自定义类型成员name,因为我们的string类实现了移动构造函数,因此它会调用string的移动构造函数进行资源的转移。
  • 而如果我们将string类当中的移动构造函数注释掉,那么Person默认生成的移动构造函数,就会调用string类中的拷贝构造函数对name成员进行深拷贝。

要验证Person类中默认生成的移动赋值函数可以用下面的代码,验证方式和上面验证移动构造的方式是一样的。

int main()
{lx::Person s1("张三", 21);lx::Person s2;s2 = std::move(s1); //想要调用Person默认生成的移动赋值return 0;
}

说明一下:

  • 我们在模拟实现的string类的拷贝构造、拷贝赋值、移动构造和移动赋值函数中都打印了一条提示语句,因此可以通过控制台输出判断是否调用了对应的函数。
  • 由于VS2013没有完全支持C++11,因此上述代码无法在VS2013当中验证,需要使用更新一点的编译器进行验证,比如VS2019。

二、类成员变量初始化

默认生成的构造函数,对于自定义类型的成员会调用其构造函数进行初始化,但并不会对内置类型的成员进行处理。于是C++11支持非静态成员变量在声明时进行初始化赋值,默认生成的构造函数会使用这些缺省值对成员进行初始化。比如:

class Person
{
public://...
private://非静态成员变量,可以在成员声明时给缺省值string _name = "张三"; //姓名int _age = 20;             //年龄static int _n; //普通静态成员变量不能给缺省值//const static int _n = 10; //使用const修饰的静态成员变量可以给缺省值,但一般不建议
};

注意: 这里不是初始化,而是给声明的成员变量一个缺省值。

三、default关键字

C++11可以让我们更好的控制要使用的默认成员函数,假设在某些情况下我们需要使用某个默认成员函数,但是因为某些原因导致无法生成这个默认成员函数,这时可以使用default关键字强制生成某个默认成员函数。

例如,下面的Person类中实现了拷贝构造函数:

class Person
{
public://拷贝构造函数Person(const Person& p):_name(p._name), _age(p._age){}
private:string _name; int _age;       
};

这时如下代码就无法编译成功了,因为Person类中编写了拷贝构造函数,导致无法生成默认的构造函数,因为默认构造函数生成的条件是没有编写任意类型的构造函数,包括拷贝构造函数。

int main()
{lx::Person s; //没有合适的默认构造函数可用return 0;
}

这时我们就可以使用default关键字强制生成默认的构造函数,如下:

class Person
{
public:Person() = default; //强制生成默认构造函数//拷贝构造函数Person(const Person& p):_name(p._name), _age(p._age){}
private:string _name; int _age;        
};

说明一下: 默认成员函数都可以用default关键字强制生成,包括移动构造和移动赋值。

四、delete关键字

当我们想要限制某些默认函数生成时,可以通过如下两种方式:

  • 在C++98中,可以将该函数设置成私有,并且只用声明不用定义,这样当外部调用该函数时就会报错。
  • 在C++11中,可以在该函数声明后面加上=delete,表示让编译器不生成该函数的默认版本,我们将=delete修饰的函数称为删除函数。

例如,要让一个类不能被拷贝,可以用=delete修饰将该类的拷贝构造和拷贝赋值。

class Person
{
public:Person(){}
private:Person(const Person&) = delete;Person& operator=(const Person&) = delete;
};

说明一下: 被=delete修饰的函数可以设置为公有,也可以设置为私有,效果都一样。

六、final关键字

final修饰类

被final修饰的类叫做最终类,最终类无法被继承。比如:

//被final修饰,该类不能再被继承
class Person final 
{...
};

final修饰虚函数

final修饰虚函数,表示该虚函数不能再被重写,如果子类继承后重写了该虚函数则编译报错。比如:

//父类
class Person
{
public:virtual void Print() final //被final修饰,该虚函数不能再被重写{cout << "hello Person" << endl;}
};
//子类
class child : public Person
{
public:virtual void Print() //重写,编译报错{cout << "hello child" << endl;}
};

七、override关键字

override修饰子类的虚函数,检查子类是否重写了父类的某个虚函数,如果没有没有重写则编译报错。比如:

//父类
class Person
{
public:virtual void Print(){cout << "hello Person" << endl;}
};
//子类
class child : public Person
{
public:virtual void Print() override //检查子类是否重写了父类的某个虚函数{cout << "hello child" << endl;}
};

分享就到这了,如有错误还望指出。

http://www.yayakq.cn/news/899750/

相关文章:

  • 手机h5案例 网站营销型网站建设哪里济南兴田德润优惠吗
  • 网站建设 排名服务器512m内存做网站
  • 雄安专业网站建设哪家好网站怎么做动态图
  • 企业网站设计教程网站源码查看
  • 做设计找素材都有什么网站有没有做定制衣服的网站
  • 周口师范做网站定制产品网站
  • 电子商务网站建设 臧良运 好不好it运维是什么
  • 一流的上海网站建设公司工作总结加强部门网站建设
  • html做电商网站临汾市网站建设
  • 方案解决网站提升网站建设品质信息
  • 建一个网站需要多少时间表制作网页超文本标记语言为
  • 淘宝网站的建设辽宁网站建站系统哪家好
  • 建设一个网站流程常州城投建设招标网站
  • 专业建站是什么wordpress 酒店中文主题
  • 做网站添加本地图片wordpress文章显示数量
  • 上海做网站公司有哪些wordpress 会员组
  • 网页设计板式网站wordpress修改文章浏览次数
  • 网站怎么做支付宝接口室内装修设计图片欣赏
  • 山西手机网站建设邢台做wap网站
  • 网站首页的动态视频怎么做的做网站挂谷歌广告赚钱吗
  • 怎么做国内网站东营网站建设
  • 有帮忙做儿童房设计的网站吗郑州港区建设投资公司网站
  • 专业企业网站搭建服务火车头获取不到wordpress列表
  • 买个人家的网站绑定自己的域名视频网站外链怎么做
  • 网站开发两端对齐底行左对齐管理学试题库及答案
  • 网站备案 公司企业网盘解决方案
  • 建设知道购物网站杭州做网站公司有哪些
  • 贵州华瑞网站建设有限公司云校招企业服务平台
  • 网站搜索引擎拓客孝感网站开发
  • 常州专业网站建设怎样在内网建设一个网站