day09了 加油

浅拷贝 指向同一个地址空间

右边不可取地址 左边一定是到了具体的位置

右值引用std:: move

相信大家默认构造函数都没有问题,所以就不贴例子了

浅拷贝构造函数

只负责复制地址,而不是真的把完整的内存给它

#include <iostream>// 浅拷贝是通过默认的复制构造函数来实现的。默认的复制构造函数会逐个复制对象的所有成员变量,但不会复制动态分配的内存。浅拷贝只是复制指针而不复制指针指向的内容。class Shallow {
public:int* data;// 构造函数Shallow(int d) {data = new int(d);}// 浅拷贝构造函数Shallow(const Shallow& source) : data(source.data) {std::cout << "Shallow copy constructor - shallow copy" << std::endl;}// 析构函数~Shallow() {delete data;std::cout << "Destructor freeing data" << std::endl;}
};int main() {Shallow obj1(42);Shallow obj2 = obj1; // 使用浅拷贝构造函数std::cout << "obj1 data: " << *obj1.data << std::endl;std::cout << "obj2 data: " << *obj2.data << std::endl;return 0;
}

深拷贝构造函数

其实跟深拷贝的意思一样,真正的什么都复制

还要分配新的内存

#include <iostream>class Deep {
public:int* data;// 构造函数Deep(int d) {data = new int(d);}// 深拷贝构造函数Deep(const Deep& source) {data = new int(*source.data);std::cout << "Deep copy constructor - deep copy" << std::endl;}// 析构函数~Deep() {delete data;std::cout << "Destructor freeing data" << std::endl;}
};int main() {Deep obj1(42);Deep obj2 = obj1; // 使用深拷贝构造函数std::cout << "obj1 data: " << *obj1.data << std::endl;std::cout << "obj2 data: " << *obj2.data << std::endl;return 0;
}

浅拷贝构造函数的代码会遇到一个问题,就是出现悬空指针,析构的时候会指向同一个指针

而深拷贝就避免了这个问题

为了提升性能,因此就来了新的概念 

移动语义

用移动构造函数和移动赋值运算符。

移动构造函数(Move Constructor)是C++11引入的一种特殊构造函数,

用于实现对象资源的高效转移,而不是复制。

它的引入是为了避免不必要的深拷贝,提高程序性能,特别是当处理临时对象时。

移动构造函数的概念

  • 移动构造函数允许从一个即将销毁的对象(通常是临时对象)中“窃取”资源,而不是复制资源。
  • 移动构造函数接收一个右值引用参数,即将被移动的对象,并将其资源转移到新对象中。
  • 移动构造函数通常与移动赋值运算符一起使用,以实现全面的移动语义。

这里建议直接看例子

移动构造函数的语法

移动构造函数的声明使用右值引用参数(通常是 Type&&,并在实现中转移资源。

#include <iostream>class Mstring {
public:char* data;// 默认构造函数Mstring() : data(nullptr) {std::cout << "Default constructor called" << std::endl;}// 参数构造函数Mstring(const char* str) {if (str) {data = new char[strlen(str) + 1];strcpy(data, str);} else {data = nullptr;}std::cout << "Parameterized constructor called" << std::endl;}// 拷贝构造函数Mstring(const Mstring& source) {if (source.data) {data = new char[strlen(source.data) + 1];strcpy(data, source.data);} else {data = nullptr;}std::cout << "Copy constructor called" << std::endl;}// 移动构造函数Mstring(Mstring&& source) noexcept : data(source.data) {source.data = nullptr;std::cout << "Move constructor called" << std::endl;}// 拷贝赋值运算符Mstring& operator=(const Mstring& source) {if (this == &source)return *this;delete[] data;if (source.data) {data = new char[strlen(source.data) + 1];strcpy(data, source.data);} else {data = nullptr;}std::cout << "Copy assignment operator called" << std::endl;return *this;}// 移动赋值运算符Mstring& operator=(Mstring&& source) noexcept {if (this == &source)return *this;delete[] data;data = source.data;source.data = nullptr;std::cout << "Move assignment operator called" << std::endl;return *this;}// 析构函数~Mstring() {delete[] data;std::cout << "Destructor called" << std::endl;}
};int main() {Mstring str1("Hello");Mstring str2("World");// 使用移动赋值运算符str2 = std::move(str1);std::cout << "After move assignment, str1: " << (str1.data ? str1.data : "nullptr") << std::endl;std::cout << "After move assignment, str2: " << (str2.data ? str2.data : "nullptr") << std::endl;return 0;
}

参数构造函数

参数构造函数是C++类的一种构造函数,

它接受一个或多个参数,

并使用这些参数来初始化类的成员变量。

与默认构造函数(不接受任何参数)相对,

参数构造函数为类的实例提供了一种灵活的初始化方式。

参数构造函数的定义

参数构造函数是在类的定义中声明的构造函数,

其参数列表可以包含一个或多个参数。

通过这些参数,构造函数可以对类的成员变量进行初始化。上面的例子是有体现的

  • 默认构造函数Mstring(),不接受任何参数,初始化成员变量 datanullptr
  • 参数构造函数Mstring(const char* str),接受一个 const char* 参数,用于初始化成员变量 data。如果参数不为空,则分配足够的内存并复制字符串内容。
  • 拷贝构造函数Mstring(const Mstring& source),用于创建一个现有对象的副本,分配新的内存并复制内容。
  • 移动构造函数Mstring(Mstring&& source) noexcept,用于高效地从另一个即将销毁的对象中移动资源,避免了不必要的内存分配和复制。
  • 拷贝赋值运算符:用于将一个对象的内容赋值给另一个现有对象,确保正确地处理动态分配的内存。
  • 移动赋值运算符:用于将一个即将销毁的对象的内容移动到另一个现有对象,避免不必要的内存分配和复制。
  • 析构函数~Mstring(),释放动态分配的内存,避免内存泄漏。
  • main 函数:演示如何使用参数构造函数创建对象,以及如何使用移动构造函数进行对象移动。

内存提前分配

内存提前分配(Pre-allocation)是指在对象或数据结构初始化时提前分配所需的内存,以减少运行时的分配开销。这在需要处理大量数据或频繁分配和释放内存的场景中特别有用。

参数构造函数中的内存提前分配示例

下面是一个改进的 Mstring 类,展示了如何在参数构造函数中提前分配内存。

#include <iostream>class Array {
private:int* data;size_t size;public:// 参数构造函数:提前分配内存Array(size_t size) : size(size) {data = new int[size]; // 提前分配内存std::cout << "Constructor: Allocated memory for " << size << " integers." << std::endl;}// 析构函数:释放内存~Array() {delete[] data;std::cout << "Destructor: Freed allocated memory." << std::endl;}// 获取数组大小size_t getSize() const {return size;}// 获取数组元素(带边界检查)int getElement(size_t index) const {if (index < size) {return data[index];} else {throw std::out_of_range("Index out of range");}}// 设置数组元素(带边界检查)void setElement(size_t index, int value) {if (index < size) {data[index] = value;} else {throw std::out_of_range("Index out of range");}}
};int main() {// 使用参数构造函数创建一个大小为10的数组Array arr(10);// 设置数组中的元素for (size_t i = 0; i < arr.getSize(); ++i) {arr.setElement(i, i * 2);}// 获取并打印数组中的元素for (size_t i = 0; i < arr.getSize(); ++i) {std::cout << "Element at index " << i << ": " << arr.getElement(i) << std::endl;}// arr对象超出作用域时,会自动调用析构函数释放内存return 0;
}

内存重复利用

1.分配一块内存2构建对象3使用对象4析构对象5销毁内存

1.优先使用dowhile循环

压栈的开销非常大,因此避免重复调用

面向对象和面向过程的区别

面向过程和面向对象的区别-CSDN博客

什么是内联函数

函数移除不必要的多态性 减省空间

性能在面向对象中最顶的

swich 跳转很快

简化表达式+位移算法

IO优化

Vector

list

set/multiset

map/Multiset

选择策略

性能分析工具

Asan

实现原理: 编译的时候。。。方式

Gprof

Valgrind

Perf

能看到函数调用次数

系统资源对性能的影响

进程选取

更新当前任务虚拟时间

异构cpu+多频率带

内存管理

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Nginx主配置文件---Nginx.conf

nginx主配置文件的模块介绍 全局块&#xff1a; 全局块是配置文件从开始到 events 块之间的部分&#xff0c;其中指令的作用域是 Nginx 服务器全局。主要指令包括&#xff1a; user&#xff1a;指定可以运行 Nginx 服务的用户和用户组&#xff0c;只能在全局块配置。例如&…

怎么解决C++不支持字符串枚举?

首先&#xff0c;有两种方法&#xff1a;使用命名空间和字符串常量与使用 enum class 和辅助函数。 表格直观展示 特性使用命名空间和字符串常量使用 enum class 和辅助函数类型安全性低 - 编译器无法检查字符串有效性&#xff0c;运行时发现错误高 - 编译期类型检查&#xf…

基于正点原子FreeRTOS学习笔记——时间片调度实验

目录 一、时间片调度介绍 二、实验演示 1、宏修改 1.1、滴答定时器宏 1.2、调度器宏 2、实验程序 2.1.1、任务1&#xff0c;任务2不加临界区程序 2.1.2 实验现象 2.2.1、任务1&#xff0c;任务2加临界区程序 2.2.2 实验现象 一、时间片调度介绍 时间片&#xff1a;同…

[Cloud Networking] BGP

1. AS (Autonomous System) 由于互联网规模庞大&#xff0c;所以网络会被分为许多 自治系统&#xff08;AS-Autonomous system&#xff09;。 所属类型ASN名称IPv4 数量IPv6数量运营商ISPAS3356LEVEL3 - Level 3 Parent, LLC, US29,798,83273,301,954,048互联网企业AS15169GO…

vue+element-ui简洁完美实现个人博客“​响石潭 ​”

目录 一、项目介绍 二、项目截图 1.项目结构图 2.首页 3.生活 ​编辑 4.文章详情 ​编辑 5.关于我 ​编辑 ​编辑 三、源码实现 1.项目依赖package.json 2.项目启动 3.首页源码 四、总结 一、项目介绍 本项目在线预览&#xff1a;点击访问 参考官网&#xff1…

数据库操作语言(DML)

数据库操作语言&#xff08;DML&#xff09; 文章目录 数据库操作语言&#xff08;DML&#xff09;一、四种操作二、数据的插入&#xff08;增&#xff09;三、数据的删除&#xff08;删&#xff09;四、数据的修改&#xff08;改&#xff09;五、数据的查询&#xff08;查&…

STM32 中断编程入门

目录 一、中断系统 1、中断的原理 2、中断类型 外部中断 定时器中断 DMA中断 3、中断处理函数 中断标志位清除 中断服务程序退出 二、实际应用 中断控制LED 任务要求 代码示例 中断控制串口通信 任务要求1 代码示例 任务要求2 代码示例 总结 学习目标&…

如何理解MySql的MVCC机制

MVCC是什么 MySQL的MVCC机制&#xff0c;全称为多版本并发控制&#xff08;Multi-VersionConcurrency Control&#xff09;&#xff0c;是一种提高数据库并发性能的技术。MVCC的主要目的是在保证数据一致性的同时&#xff0c;提高数据库的并发性能。 它通过为每个读操作创建数…

技术赋能教育:校园3D电子地图与AR导航解决方案

随着高考的落幕&#xff0c;又一批新鲜血液即将注入大学校园。面对陌生的环境&#xff0c;如何快速适应、准确找到目标地点&#xff0c;成为新生们的一大难题。同时&#xff0c;对于学校而言&#xff0c;如何向报考人员直观展示校园环境&#xff0c;提供沉浸式参观体验&#xf…

Vue跨域获取ip和ip位置城市等归属地信息

由于端口设置与查询服务器不一致&#xff0c;所以不能直接从ip138网上抓取&#xff0c;只能跨域查询。实现跨域查询&#xff0c;简单的方法是使用jsonp方式&#xff0c;只支持get请求&#xff0c;同时也需要查询的服务器支持jsonp。这时找到了腾讯位置服务。参考文章&#xff0…

第 27 篇 : 搭建maven私服nexus

官网文档 1. 下载应该很慢, 最好是能翻墙 nexus-3.69.0-02-java8-unix.tar.gz 2. 上传到/usr/local/src, 解压及重命名 tar -zxvf nexus-3.69.0-02-java8-unix.tar.gz rm -rf nexus-3.69.0-02-java8-unix.tar.gz mv nexus-3.69.0-02 nexus ls3. 修改配置 cd /usr/local/sr…

2024最新版Redis常见面试题包含详细讲解

Redis适用于哪些场景&#xff1f; 缓存分布式锁降级限流消息队列延迟消息队 说一说缓存穿透 缓存穿透的概念 用户频繁的发起恶意请求查询缓存中和数据库中都不存在的数据&#xff0c;查询积累到一定量级导致数据库压力过大甚至宕机。 缓存穿透的原因 比如正常情况下用户发…

生命在于学习——Python人工智能原理(3.1.2)

一、概率基本知识 1.3 常见概型 1.3.1 古典概型 定义1 古典概型 若随机事件E满足如下两个条件&#xff1a; &#xff08;1&#xff09;样本空间S中只有有限个样本点。 &#xff08;2&#xff09;样本空间S中每个样本点发生都是等可能的。 这样的随机试验称为古典概型。 P(A)…

暑期大数据人工智能学习-企业项目试岗实训开营

暑期企业项目-试岗实训活动全面开启啦 跟张良均老师学大数据人工智能 不仅可以提供实习证明&#xff0c;有需要话也可以提供实习鉴定报告 √54个热门案例拆解 √40项目实战课程 √27个项目可选 √4个项目方向

企业本地大模型用Ollama+Open WebUI+Stable Diffusion可视化问答及画图

最近在尝试搭建公司内部用户的大模型&#xff0c;可视化回答&#xff0c;并让它能画图出来&#xff0c; 主要包括四块&#xff1a; Ollama 管理和下载各个模型的工具Open WebUI 友好的对话界面Stable Diffusion 绘图工具Docker 部署在容器里&#xff0c;提高效率 以上运行环境…

to_json 出现乱码的解决方案

大家好,我是爱编程的喵喵。双985硕士毕业,现担任全栈工程师一职,热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。喜欢通过博客创作的方式对所学的…

基于MIMO系统的预编码matlab性能仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 最小均方误差&#xff08;MMSE&#xff09;准则 4.2 量化准则 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 MATLAB2022a 3.部分核心程序 …

让围绕数据库构建大模型应用更简单方便--DB-GPT

DB-GPT的目的是构建大模型领域的基础设施&#xff0c;通过开发多模型管理(SMMF)、Text2SQL效果优化、RAG框架以及优化、Multi-Agents框架协作、AWEL(智能体工作流编排)等多种技术能力&#xff0c;让围绕数据库构建大模型应用更简单&#xff0c;更方便。 1 处理流程 DB-GPT系…

使用supportFragmentManager管理多个fragment切换

android studio创建的项目就没有一个简单点的框架&#xff0c;生成的代码都是繁琐而复杂&#xff0c;并且不实用。 国内的页面一般都是TAB页面的比较多&#xff0c;老外更喜欢侧边菜单。 如果我们使用一个activity来创建程序&#xff0c;来用占位符管理多个fragment切换&…

网络连接之队头阻塞!!!

一、什么是队头阻塞 队头阻塞&#xff0c;在网络模型中简单理解就是&#xff0c;对于队列型的请求模型&#xff0c;如HTTP的请求-响应模型、TCP的ACK确认机制&#xff0c;都依赖得到一个具体的响应包&#xff0c;如果收不到这个响应包&#xff0c;那下一个请求就不能发&#x…