C++对象的初始化和处理

生活中我们买的电子产品都基本会有出厂设置!在某一天我们不用时候也会删除一些自己信息数据保证安全。
C++中的面向对象来源于生活,每个对象也都会有初始设置以及对象销毁前的清理数据的设置。

构造函数和析构函数

对象的初始化和清理也是两个非常重要的安全问题

一个对象或者变量没有初始状态,对其使用后果是未知
同样的使用完一个对象或变量,没有及时清理,也会造成一定的安全问题。

c++利用了构造函数和析构函数解决上述问题,这两个函数将会被编译器自动调用,完成对象初始化和清理工作,对象的初始化和清理工作是编译器强制要我们做的事情,因此如果我们不提供构造和析构,编译器会提供编译器提供的构造函数和析构函数是空实现。

构造函数: 主要作用在于创建对象时为对象的成员属性赋值,构造函数由编译器自动调用,无须手动调用。
析构函数: 主要作用在于对象销毁前系统自动调用,执行一些清理工作。

构造函数语法: 类名 () {}
1.构造函数,没有返回值也不写void
2.函数名称与类名相同
3.构造函数可以有参数,因此可以发生重载
4.程序在调用对象时候会自动调用构造,无须手动调用,而且只会调用一次
示例:

#include <iostream>
using namespace std;

class person
{
    public:
    person()//构造函数调用
    {
        cout<<"hello world"<<endl;
    }
};

void test()
{
    person p;
}

int main()
{
    test();
    return 0;
}

析构函数语法: ~类名(){}
1.析构函数,没有返回值也不写void
2.函数名称与类名相同,在名称前加上符号~
3.析构函数不可以有参数,因此不可以发生重载
4.程序在对象销毁前会自动调用析构,无须手动调用,而且只会调用一次

#include <iostream>
using namespace std;

class person
{
    public:
    ~person()//析构函数调用
    {
        cout<<"hello world"<<endl;
    }
};

void test()
{
    person p;//在栈上的数据,该函数执行完后会释放掉
}

int main()
{
    test();
    return 0;
}

构造函数的分类及调用:

两种分类方式
按参数分为: 有参构造和无参构造
按类型分为: 普通构造和拷贝构造

三种调用方式:
括号法
显示法
隐式转换法

示例:

#include <iostream>
using namespace std;

class person
{
public:
    person()//无参构造函数调用
    {
        cout<<"无参构造函数调用"<<endl;
    }
    person(int a)//有参构造函数调用
    {
        age=a;
        cout<<"有参构造函数调用"<<endl;
    }
    person(const person &p)//拷贝函数,除了括号里面这样写的都是普通函数
    {
        age=p.age;
        cout<<"拷贝函数构造调用"<<endl;
    }
    int age;

    ~person()
    {
        cout<<"析构函数调用"<<endl;
    }
};

//调用
void test()
{
    //1.括号法
    person p1;//默认构造函数,注意不要加()
    person p2(10);//有参构造函数
    person p3(p2);//拷贝构造函数

    //2.显示法
    person p4;
    person p5=person(10);
    person p6=person(p5);

    //person(10);//匿名对象 特点:当前行执行结束时,系统会立即回收掉匿名对象
    //person(p5);//错误的,不能利用拷贝构造函数来初始化匿名对象,编译器会认为这是对象的声明
                 //编译器会认为person(p5)==person p5;

    //3.隐式转换法
    person p7=10;//相当于写了person p7(10)
    person p8=p7;//相当于写了person p8=person(p7)
}

int main()
{
    test();
    return 0;
}

拷贝构造函数调用时机

C++中拷贝构造函数调用时机通常有三种情况:

使用一个已经创建完毕的对象来初始化一个新对象;
值传递的方式给函数参数传值;
以值方式返回局部对象。

构造函数调用规则

默认情况下,c++编译器至少给一个类添加3个函数:
1.默认构造函数(无参,函数体为空)
2.默认析构函数(无参,函数体为空)
3.默认拷贝构造函数,对属性进行值拷贝

构造函数调用规则如下:
如果用户定义有参构造函数,C++不在提供默认无参构造,但是会提供默认拷贝构造;
如果用户定义拷贝构造函数,C++不会再提供其他构造函数

深拷贝和浅拷贝

深浅拷贝是面试经典问题,也是常见的一个坑
浅拷贝: 简单的赋值拷贝操作
深拷贝: 在堆区重新申请空间,进行拷贝操作

浅拷贝带来的问题就是堆区的内存重复释放

示例:

#include <iostream>
using namespace std;

class person
{
public:
    person()
    {
        cout<<"无参构造函数调用"<<endl;
    }
    person(int a,int shengao)
    {
        age=a;
        height=new int(shengao);
        cout<<"有参构造函数调用"<<endl;
    }
    person(const person &p1)
    {
        cout<<"拷贝函数构造调用"<<endl;
        age=p1.age;
        height=new int(*p1.height);
    }
    int age;
    int* height;

    ~person()
    {
        cout<<"析构函数调用"<<endl;
    }
};

//调用
void test()
{
    person p1(10,170);
    cout<<"p1年龄为"<<p1.age<<endl;
    cout<<"p1身高为"<<*p1.height<<endl;
    person p2(p1);
    cout<<"p2年龄为"<<p2.age<<endl;
    cout<<"p2身高为"<<*p2.height<<endl;
}

int main()
{
    test();
    return 0;
}

在这里插入图片描述

深拷贝对于指针的属性会重新拷贝一块空间最后释放掉,否则对于同一块空间也拷贝过来就只能释放一次(栈区先进后出,所以先释放掉p2,再释放p1会报错)

在这里插入图片描述

初始化列表

作用:
C++提供了初始化列表语法,用来初始化属性
语法: 构造函数( ): 属性1(值1),属性2(值2)…{ }

示例:

#include <iostream>
using namespace std;

class person
{
public:
/*    person():A(10),B(20)//这种写法会写死A和B,只能是A10,B20
    {

    }
*/
    person(int a,int b):A(a),B(b)//这种写法更加灵活,可以改值
    {

    }
    int A;
    int B;
};

//调用
void test()
{
    person p(55,14);
    cout<<p.A<<endl;
    cout<<p.B<<endl;
}

int main()
{
    test();
    return 0;
}

类对象作为类成员

C++类中的成员可以是另一个类的对象,我们称该成员为对象成员

当其他类对象作为本类成员,构造时候先构造类对象,再构造自身,注意析构的顺序与构造相反

示例:

#include <iostream>
#include <string>
using namespace std;

//手机类
class phone
{
public:
    phone(string pin)
    {
        ping=pin;
    }
    //手机品牌
    string ping;
};

//人类
class person
{
public:
    person(string ming,string pin):name(ming),myphone(pin)
    {

    }
    //姓名
    string name;
    //手机
    phone myphone;

};

//调用
void test()
{
    person p("张三","诺基亚");
    cout<<p.name<<endl;
    cout<<p.myphone.ping<<endl;
}

int main()
{
    test();
    return 0;
}

静态成员

静态成员变量:
所有对象共享同一份数据
在编译阶段分配内存
类内声明,类外初始化

静态成员函数:
所有对象共享同一个函数
静态成员函数只能访问静态成员变量

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/577517.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据分析:扩增子-16s rRNA分析snakemake流程

介绍 扩增子测序是分析环境微生物的常见手段&#xff0c;通常使用的是16s rRNA片段。16srRNA分析主要有质控、去冗余、聚类OTU、去嵌合体、生成OTU表和物种注释等步骤。更多知识分享请到 https://zouhua.top/。 先看看前期数据处理的可视化图。 数据 18份来自宏基因组公众号…

go 测试和文件

go 测试和文件 需求传统测试单元测试牛刀小试总结练习文件介绍打开关闭文件读文件一次性读取文件写文件文件或文件夹是否存在文件拷贝 需求 有一个函数&#xff0c;怎样确认他运行结果是正确的&#xff1f; func addUpper(n int)int {res : 0for i : 1; i < n; i {res1}r…

设计模式学习笔记 - 开源实战五(下):总结Mybatis中用到的10种设计模式

概述 本章再对 Mybatis 用到的设计模式做一个总结。它用到的设计模式也不少。有些前面章节已经经过了&#xff0c;有些则比较简单。 SqlSessionFactoryBuilder&#xff1a;为什么要用建造者模式来创建 SqlSessionFactory&#xff1f; 在《Mybatis如何权衡易用性、性能和灵活性…

【算法基础实验】图论-UnionFind连通性检测之quick-find

Union-Find连通性检测之quick-find 理论基础 在图论和计算机科学中&#xff0c;Union-Find 或并查集是一种用于处理一组元素分成的多个不相交集合&#xff08;即连通分量&#xff09;的情况&#xff0c;并能快速回答这组元素中任意两个元素是否在同一集合中的问题。Union-Fin…

编译支持播放H265的cef控件

接着在上次编译的基础上增加h265支持编译支持视频播放的cef控件&#xff08;h264&#xff09; 测试页面&#xff0c;直接使用cef_enhancement,里边带着的那个html即可&#xff0c;h265视频去这个网站下载elecard,我修改的这个版本参考了里边的修改方式&#xff0c;不过我的这个…

用友政务财务系统FileDownload接口存在任意文件读取漏洞

声明&#xff1a; 本文仅用于技术交流&#xff0c;请勿用于非法用途 由于传播、利用此文所提供的信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;文章作者不为此承担任何责任。 简介 用友政务财务系统是由用友软件开发的一款针对政府机…

maven-idea新建和导入项目

全局配置 新建项目 需要新建的文件夹 src/testsrc/test/javasrc/main/java 注&#xff1a;1、新建Java-class&#xff0c;输入.com.hello.hellomaven 2、快捷键psvm显示 public static void main(String[] args) {.... } package com.hello;public class hellomaven {publ…

初学python记录:力扣1146. 快照数组

题目&#xff1a; 实现支持下列接口的「快照数组」- SnapshotArray&#xff1a; SnapshotArray(int length) - 初始化一个与指定长度相等的 类数组 的数据结构。初始时&#xff0c;每个元素都等于 0。void set(index, val) - 会将指定索引 index 处的元素设置为 val。int sna…

Git泄露和hg泄露原理理解和题目实操

一.Git泄露 1.简介 Git是一个开源的分布式版本控制系统&#xff0c;它可以实现有效控制应用版本&#xff0c;但是在一旦在代码发布的时候&#xff0c;存在不规范的操作及配置&#xff0c;就很可能将源代码泄露出去。那么&#xff0c;一旦攻击者发现这个问题之后&#xff0c;就…

【算法基础实验】图论-基于DFS的连通性检测

基于DFS的连通性检测 理论基础 在图论中&#xff0c;连通分量是无向图的一个重要概念&#xff0c;特别是在处理图的结构和解析图的组成时。连通分组件表示图中的一个子图&#xff0c;在这个子图中任意两个顶点都是连通的&#xff0c;即存在一条路径可以从一个顶点到达另一个顶…

如何消除浏览器SmartScreen对网站“不安全”提示?

面对互联网时代用户对网站安全性和可信度的严苛要求&#xff0c;网站运营者时常遭遇Microsoft Defender SmartScreen&#xff08;SmartScreen&#xff09;提示网站不安全的困扰。本文将剖析SmartScreen判定网站不安全的原因&#xff0c;并为运营者提供应对策略&#xff0c;以恢…

codeforce#933 题解

E. Rudolf and k Bridges 题意不讲了&#xff0c;不如去题干看图。 传统dp&#xff0c;每个点有两个选择&#xff0c;那么建桥要么不建。需要注意的是在状态转移的时候&#xff0c;桥是有长度的&#xff0c;如果不建需要前d格中建桥花费最少的位置作为状态转移的初态。 #incl…

发那科FANUC机器人R-2000iB平衡缸维修攻略

在发那科机器人中&#xff0c;平衡缸扮演着稳定机械臂运动的关键角色。它通过内部的压力调节来平衡负载&#xff0c;保证机器人的精准定位和平稳操作。一旦出现法兰克机械手平衡缸故障或损坏&#xff0c;机器人的性能可能会大打折扣&#xff0c;因此及时且正确的FANUC机械手平衡…

uniapp获取当前位置及检测授权状态

uniapp获取当前位置及检测授权定位权限 文章目录 uniapp获取当前位置及检测授权定位权限效果图创建js文件permission.jslocation.js 使用 效果图 Android设备 点击 “设置”&#xff0c;跳转应用信息&#xff0c;打开“权限即可”&#xff1b; 创建js文件 permission.js 新建…

HTTP基础知识

1. HTTP常见的状态码有哪些&#xff1f; 常见状态码&#xff1a; 200&#xff1a;服务器已成功处理了请求。 通常&#xff0c;这表示服务器提供了请求的网页。 301 &#xff1a; (永久移动) 请求的网页已永久移动到新位置。 服务器返回此响应(对 GET 或 HEAD 请求的响应)时&a…

Java使用SpringBoot和EasyExcel 实现动态数据导出实战

Java使用SpringBoot和EasyExcel 实现动态数据导出实战 1、前言2、【资源地址】3、代码示例(demo)4、目前Java实现数据导出为Excel方式5、依赖6、总结 1、前言 工作中有用到将数据导出为Excel的场景&#xff0c;在此记录下。在日常开发中&#xff0c;Excel文件处理是一项常见的…

LeetCode 面试题 08.02——迷路的机器人

阅读目录 1. 题目2. 解题思路3. 代码实现 1. 题目 2. 解题思路 此题就是一个典型的图搜索题&#xff0c;一种就是广度优先搜索&#xff0c;一种就是深度优先搜索。 3. 代码实现 class Solution { public:vector<vector<int>> pathWithObstacles(vector<vecto…

软件需求管理规程(Word原件2024)

软件开发人员及用户往往容易忽略信息沟通&#xff0c;这导致软件开发出来后不能很好地满足用户的需要&#xff0c;从而造成返工。而返工不仅在技术上给开发人员带来巨大的麻烦&#xff0c;造成人力、物力的浪费&#xff0c;而且软件的性能也深受影响。所以在软件项目开发周期的…

Bellman Ford算法:解决负权边图的最短路径问题

Bellman Ford算法的介绍 在计算机科学的世界中&#xff0c;Bellman Ford算法是一种解决单源最短路径问题的算法&#xff0c;它可以处理有负权边的图。这个算法的名字来源于两位科学家Richard Bellman和Lester Randolph Ford&#xff0c;他们是这个算法的发明者。 这个算法的主…

hive启动beeline报错

问题一在zpark启动集群报错 出现上面的问题执行以下代码 chmod 777 /opt/apps/hadoop-3.2.1/logs 问题二启动beeline报错 执行 cd /opt/apps/hadoop-3.2.1 bin/hadoop dfsadmin -safemode leave 问题三执行查询语句报错 执行 set hive.exec.mode.local.autotrue;