c++笔记理解

news2024/11/13 11:30:08

1.封装

(1)构造函数不是必须在的

可以通过行为修改属性

(2)private和protected区别在于继承那里要学

(3)类默认是私有,struct是共有

私有的好处:控制数据的有效性,意思是在外面给函数的方式写,可以设置多少多少就不能写那种

(4)cube例子不会的点

类内写:
bool equal2(cube& c2)
{
	if (h == c2.h && w == c2.w && l == c2.l)return true;
	return false;
}
类外写:
	cout << cu.equal2(cu2);

(5)点和圆的关系

#include<iostream>
#include<stdio.h>
#include<math.h>
using namespace std;
class point
{
    int x, y;//点所在的位置
public:
    point(int x, int y)
    {
        this->x = x; this->y = y;
    }
    int getx()
    {
        return x;
    }
    int gety()
    {
        return y;
    }
};
class circle
{
    //int o,r;//分别是圆心所在的位置和半径,不行,得要二维数组
    int x, y, r;
public:
    circle(int x, int y, int r)
    {
        this->r = r; this->x = x; this->y = y;
    }
    /*int geto()//一个坐标一个坐标访问
    {
            //return o;不需要呀,因为你有构造函数了,可是无法访问呀?
    }*/
    int getx()
    {
        return x;
    }
    int gety()
    {
        return y;
    }
    int getr()
    {
        return r;
    }
    //把判断变成成员函数,传进来x,y
    void relation(point& p)
    {
        //先求出两点之间的距离,开根号sqrt()
        int d = sqrt((p.getx() - x) * (p.getx() - x) + (p.gety() - y) * (p.gety() - y));
        if (d < r)cout << "点在圆内" << endl;
        else if (d == r)cout << "点在圆上" << endl;
        else cout << "点在圆外" << endl;
    }
};

int main()
{
    circle c(2, 5, 3);
    point p(4, 4);
    //求点和圆的位置关系
    //点在圆内点在圆上点在员外
    //只需要将半径和这俩点之间的关系比较即可
    c.relation(p);
}

全局函数yyds

#include<iostream>
#include<stdio.h>
#include<math.h>
//class point;
using namespace std;
class circle
{
	//int o,r;//分别是圆心所在的位置和半径,不行,得要二维数组
	int x, y, r;
public:
	//class point;
	circle(int x,int y, int r)
	{
		this->r = r; this->x = x; this->y = y;
	}
	/*int geto()//一个坐标一个坐标访问
	{
		//return o;不需要呀,因为你有构造函数了,可是无法访问呀?
	}*/
	int getx()
	{
		return x;
	}
	int gety()
	{
		return y;
	}
	int getr()
	{
		return r;
	}
	//把判断变成成员函数,传进来x,y
	/*void relation(point& p)
	{
		//先求出两点之间的距离,开根号sqrt()
		int d = sqrt((p.getx() - x) * (p.getx() - x) + (p.gety() - y) * (p.gety() - y));
		if (d < r)cout << "点在圆内" << endl;
		else if (d == r)cout << "点在圆上" << endl;
		else cout << "点在圆外"<<endl;
	}*/
};
class point
{
	int x,y;//点所在的位置
public:
	point(int x,int y)
	{
		this->x = x; this->y = y;
	}
	int getx()
	{
		return x;
	}
	int gety()
	{
		return y;
	}
};
//全局函数还是好
void relation(circle c, point p)
{
	int d = sqrt((p.getx() - c.getx()) * (p.getx() - c.getx()) + (p.gety() - c.gety()) * (p.gety() - c.gety()));
	if (d < c.getr())cout << "点在圆内" << endl;
	else if (d == c.getr())cout << "点在圆上" << endl;
	else cout << "点在圆外" << endl;
}
int main()
{
	circle c(2, 5, 3);
	point p(4, 4);
	//求点和圆的位置关系
	//点在圆内点在圆上点在员外
	//只需要将半径和这俩点之间的关系比较即可
	relation(c,p);
}

咋说呢,你要想用哪个类,你就把这个类写到前面

可以把一个类型为某类的变量定义为另一个类的变量

圆心就是一个点,因此可以将园中的圆心定义为点的类型

(6)我就要把这个类放在不同文件里的知识单独拎出来

把类的声明放在头文件中使用.h文件;类中文件的实现放在cpp中重新起一个cpp文件,这个文件要用声明的头文件;在main函数里面想要使用类,就在前面加上声明的头文件

分别如何书写呢?

例如circle文件:

在头文件里写一个.h文件,然后把类复制进去,去掉函数实现,留下成员变量和成员函数的声明;

然后再源文件里另写一个cpp文件,这个文件写下来类内各个函数的具体实现就好了

这下:函数的声明函数的实现就都分得很清了

2.函数的初始化和销毁

1.构造函数和析构函数都是只要创建了对象,这个函数就会被自动调用,就算你不写,系统会自动给你写一个空的构造函数然后一调用,但是你要是写了就用你的,即便你不调用这个函数,他也会自动调用你写的

2.你要是在函数体内(不是main),那么就会放在栈上,这个函数用完就要析构销毁

main中,只有当main执行完了以后才能执行析构函数

3.匿名构造?三种方法

拷贝构造函数part:
#include<iostream>
#include<stdio.h>
#include<math.h>
using namespace std;
class person
{
public:
	int age;
	person(int age)
	{
		this->age = age;
	}
	//拷贝构造函数 
	//因为你不能修改你传入的p的属性,因此要用静态引用
	person(const person& p)
	{
		//将传入的人身上的所有属性拷贝到我身上,我现在的age=传入的p的age
		age = p.age;
		cout << "输出拷贝构造函数" << endl;
	}

};
int main()
{
	person p1(10);
	cout << p1.age << endl;
	person p2(p1);
	cout << p2.age << endl;//输出也是10

}

匿名构造函数

	person(10);//没有给这个构造函数一个对象名,就是匿名构造函数
	//特点:当前行执行结束,就会被释放,就会析构函数
    Person(p3)
    //这是不对的
	//注意:不要利用拷贝函数初始化匿名对象-编译器会认为Person(p3) == Person p3 编译器会认为是对象的声明

隐式转换法的意思是你写一个person p3=10;系统会自动给你转换成显式法

4.

//值传递的方式给函数参数传值
//※拷贝构造函数为什么可以值传递哪里体现了?都没见拷贝构造函数;
解密时刻:!!!!!!!!!!!!!!!!!!!!!
因为当你值传递的时候就会调用拷贝构造函数,值传递相当于给了一个副本嘛
void dowork(Person p)
{
	
}
void test02()
{
	Person p;
	dowork(p);
}
//值方式返回局部对象
//输出那个是引用的解引用吗?,局部对象是p1?拷贝构造函数在哪?好吧,test03第一句就是p=p1;
//现在p有p2的所有属性,因此出来的对象是谁呢?p1本身?也就是想用p来输出p1,那为啥不直接输出dowork2()呢?
解密:p和p1的不是一个了,地址都不一样,相当于值传递,返回一个p1,就拷贝了一个p1
Person dowork2()
{
	Person p1;
	cout << (int*)&p1 << endl;
	return p1;
}
void test03()
{
	Person p = dowork2();
	cout << (int*)&p << endl;
}

5.深拷贝和浅拷贝

//再复习一下new的代码
int* p=new int(*p.height)//意思就是为p开辟一个空间,里面的内容是int括号里的内容,左边要是一个指针,指向这段空间

如果你的成员变量在堆区,那么就容易出现重复释放空间的问题,因为浅拷贝就相当于别人的值赋给你,同时你的位置也会和他一样,那你俩运行完就都会释放它就释放了两次,所以原因就在于你俩堆的位置在一块呢,所以把他俩放两个位置不就好了,用new开辟一个新空间

Person(const Person& p)
{
	cout << "Person的拷贝构造函数调用" << endl;
	m_Age = p.m_Age;
	//m_Height = p.m_Height;编译器默认实现的就是这行代码
	//深拷贝操作
	m_Height = new int(*p.m_Height);
}

6.当其他类对象作为本类的类成员时,先构造其他类,然后再构造本类,

析构的顺序与构造相反

3.友元

1.用途:private成员外面不能被访问,但有时候你想让外面某些特殊函数去访问,就采用友元

2.三种:全局函数;成员函数;类;

(1)全局函数:就是给类中前面加上函数的声明,并且给函数声明的前面加上friend

class friend
{
    friend void get();
}

(2)类:A想用B的,你就给A前面加上B的声明

class A//A里用B了,所以要声明friend
{
    friend class B;
  private:
    B b1;
}
class B
{

}
你放在B里面,就是要给B说别人能访问你

(3)成员函数

整明白了
就是你A类里一个函数想访问另一个类B,你就要在B里声明这个函数
不是想全局函数那样直接前面加一个friend,而是要在函数名字前面加上所属的类
例如下面
friend void GoodGay::visit();

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何快速提升Lazada和Shopee店铺订单量:自养号测评补单策略详解

Lazada和Shopee&#xff0c;作为东南亚地区领先的电商平台&#xff0c;汇聚了无数卖家和消费者。然而&#xff0c;随着市场竞争的日益激烈&#xff0c;如何有效地推广自己的店铺&#xff0c;成为卖家们亟待解决的问题。本文将深入探讨店铺推广的策略&#xff0c;并分享如何迅速…

百度百科词条在网络推广中的六大作用

也许很多网友都发现了&#xff0c;在网上查资料&#xff0c;百科词条往往是优先展示的。一方面因为百科是搜索引擎自身的平台&#xff0c;另一方面就是因为百科信息权威&#xff0c;网友认可度高。所以企业开展网络营销&#xff0c;百科营销是一块重要阵地。 也有的企业认为百科…

Feign远程调用(学习笔记)

先来看我们以前利用RestTemplate发起远程调用的代码&#xff1a; 存在下面的问题&#xff1a; ●代码可读性差&#xff0c;编程体验不统一 ●参数复杂URL难以维护 Feign是一个声明式的http客户端&#xff0c;官方地址&#xff1a;https://github.com/OpenFeign/feign 其作用…

代理IP为什么会有延迟?

在当今信息高速发展的时代&#xff0c;随着代理IP在数据采集、网络安全和匿名浏览等领域的应用&#xff0c;已成为网络技术中不可或缺的一环。然而&#xff0c;用户在使用代理IP时经常会遇到一个问题——延迟。 那我们要如何解决这个问题呢&#xff1f; 这需要从代理IP的原理说…

【MATLAB源码-第143期】基于matlab的蝴蝶优化算法(BOA)机器人栅格路径规划,输出做短路径图和适应度曲线。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 蝴蝶优化算法&#xff08;Butterfly Optimization Algorithm, BOA&#xff09;是基于蝴蝶觅食行为的一种新颖的群体智能算法。它通过模拟蝴蝶个体在寻找食物过程中的嗅觉导向行为以及随机飞行行为&#xff0c;来探索解空间&a…

R语言数据分析(五)

R语言数据分析&#xff08;五&#xff09; 文章目录 R语言数据分析&#xff08;五&#xff09;前言一、什么是整洁的数据二、延长数据2.1 列名中的数据值2.2 pivot_longer()的处理原理2.3 列名中包含许多变量的情况2.4 列名同时包含数据和变量 三、扩宽数据3.1 pivot_wider的处…

uniapp微信小程序解决上方刘海屏遮挡

问题 在有刘海屏的手机上&#xff0c;我们的文字和按钮等可能会被遮挡 应该避免这种情况 解决 const SYSTEM_INFO uni.getSystemInfoSync();export const getStatusBarHeight ()> SYSTEM_INFO.statusBarHeight || 15;export const getTitleBarHeight ()>{if(uni.get…

k8s(2)

目录 一.二进制部署k8s 常见的K8S安装部署方式&#xff1a; k8s部署 二进制与高可用的区别 二.部署k8s 初始化操作&#xff1a; 每台node安装docker&#xff1a; 在 master01 节点上操作; 准备cfssl证书生成工具:&#xff1a; 执行脚本文件&#xff1a; 拉入etcd压缩包…

Spring Boot应用集成Actuator端点自定义Filter解决未授权访问的漏洞

一、前言 我们知道想要实时监控我们的应用程序的运行状态&#xff0c;比如实时显示一些指标数据&#xff0c;观察每时每刻访问的流量&#xff0c;或者是我们数据库的访问状态等等&#xff0c;需要使用到Actuator组件&#xff0c;但是Actuator有一个访问未授权问题&#xff0c;…

2023全新UI千月影视APP源码 | 前后端完美匹配、后端基于ThinkPHP框架

应用介绍 本文来自&#xff1a;2023全新UI千月影视APP源码 | 前后端完美匹配、后端基于ThinkPHP框架 - 源码1688 简介&#xff1a; 2023全新UI千月影视APP源码 | 前后端完美匹配、后端基于thinkphp框架 图片&#xff1a;

索引大战:探秘InnoDB数据库中B树和Hash索引的优劣

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 索引大战&#xff1a;探秘InnoDB数据库中B树和Hash索引的优劣 前言B树索引的深度解析Hash索引的奥秘揭晓性能对比分析 前言 在当今软件开发的世界中&#xff0c;数据库扮演着至关重要的角色。而InnoD…

怎么用sora赚第一桶金?

&#x1f31f;解锁文字变视频的强大功能&#xff01;&#x1f31f; ✨欢迎来到 Sora Cand&#xff0c;一个革命性的网站&#xff0c;利用 OpenAI 的 Sora 模型帮你把文字变成酷炫的视频&#xff01;✨ 想象一下&#xff0c;你的文字从纸上跳出来&#xff0c;变成引人入胜的视觉…

如何用IP地址找到实际位置?

在互联网世界中&#xff0c;每个设备都有一个独特的标识&#xff0c;那就是IP地址。它不仅是设备在网络中的“身份证”&#xff0c;还承载着设备在网络中的位置信息。那么&#xff0c;我们是否可以通过IP地址来找到设备的实际位置呢&#xff1f;本文将深入探讨这一问题。 一、I…

#11vue3中使用el-dialog展示与关闭交由父组件控制的写法

目录 1、法一&#xff1a;通过defineEmits调用父组件方法 1.1、父组件 1.2、子组件&#xff08;CONTENT&#xff09; 2、法二&#xff1a;通过difineExpose暴露子组件属性 2.1、父组件 2.2、子组件&#xff08;Child&#xff09; 1、法一&#xff1a;通过defineEmits调用…

【C语言】注释

&#x1f388;个人主页&#xff1a;豌豆射手^ &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;C语言 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出指正&#xff0c;让我们共同学习、交流进步&…

vue3 toRefs之后的变量修改方法

上效果 修改值需要带上解构之前的对象名obj&#xff0c; changeName:()>{ // toRefs 解决后变量修改值方法&#xff1a; 解构前变量.字段新值 obj.name FEIFEI; } } 案例源码 <!DOCTYPE html> <html> <head><me…

算法——模拟

1. 什么是模拟算法&#xff1f; 官方一点来说 模拟算法&#xff08;Simulation Algorithm&#xff09;是一种通过模拟现实或抽象系统的运行过程来研究、分析或解决问题的方法。它通常涉及创建一个模型&#xff0c;模拟系统中的各种事件和过程&#xff0c;以便观察系统的行为&a…

从单体服务到微服务:多模式 Web 应用开发记录<一>背景全局变量优化

背景 最近在做一个事&#xff1a;下线一个超级大单体服务。单一统计代码行数其实不够全面&#xff0c;反正项目 git clone 下来文件就有这么大&#xff1a; 这是一个已经存在了十年以上的服务&#xff0c;随着业务的发展&#xff0c;这个服务已经无法满足我们的需求。 我们统…

胡夏爱意满满,浪漫尽显,心动不止。

♥ 为方便您进行讨论和分享&#xff0c;同时也为能带给您不一样的参与感。请您在阅读本文之前&#xff0c;点击一下“关注”&#xff0c;非常感谢您的支持&#xff01; 文 |猴哥聊娱乐 编 辑|徐 婷 校 对|侯欢庭 全网热议的胡夏暗恋文学&#xff0c;浪漫指数爆表&#xff01…

力扣382.链表随机节点

Problem: 382. 链表随机节点 文章目录 题目描述思路复杂度Code 题目描述 思路 由水塘抽样易得&#xff0c;当遇到i个元素&#xff0c;有 1 / i 1/i 1/i的概率选择该元素&#xff1b;则在实际操作中我们定义一个下标i从1开始遍历每次判断rand() % i 0&#xff08;该操作就是判断…