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

【C++】中的赋值初始化和直接初始化的区别

在C++中,赋值初始化(也称为拷贝初始化)和直接初始化(也称为构造初始化)虽然常常产生相同的结果,但在某些情况下它们有不同的含义和行为。

赋值初始化(Copy Initialization)

使用等号 = 进行初始化的方式。这种形式看起来像是将右边的值“赋值”给左边的变量。

int a = 10; // 基础类型
std::string str = "Hello"; // 类类型

对于基础数据类型,这种方式仅仅是将值赋给变量。但对于类类型,编译器可能会调用一个隐式的类型转换构造函数来完成初始化过程,然后再进行一次拷贝构造(尽管现代编译器通常会优化掉不必要的拷贝)。

直接初始化(Direct Initialization)

使用圆括号 () 或者大括号 {} 进行初始化的方式。这种方式更明确地指示了要调用哪个构造函数。

int b(20); // 基础类型
std::string str("Hello"); // 类类型

或者使用C++11引入的列表初始化: 

int c{30}; // 列表初始化,适用于基础类型和类类型
std::string str{"Hello"}; // 列表初始化

直接初始化可以避免一些隐式类型转换带来的问题,并且对于某些情况是必要的,比如当有多个构造函数时,选择特定的构造函数进行初始化。

区别举例

考虑以下示例:

#include <iostream>
#include <string>class MyClass {
public:MyClass(int) { std::cout << "Constructor from int\n"; }MyClass(const MyClass&) { std::cout << "Copy constructor\n"; }
};int main() {// 赋值初始化MyClass obj1 = 1; // 先隐式转换为MyClass, 然后拷贝构造// 输出: Constructor from int//       Copy constructor (可能被优化掉)// 直接初始化MyClass obj2(1); // 直接调用int构造函数// 输出: Constructor from intreturn 0;
}

在这个例子中:

  • 对于 obj1 使用赋值初始化,首先需要通过隐式类型转换从 int 转换为 MyClass,然后可能会调用拷贝构造函数创建最终对象(如果未被编译器优化掉)。
  • 对于 obj2 使用直接初始化,则直接调用了从 int 到 MyClass 的构造函数,避免了额外的拷贝构造步骤。

因此,在涉及类类型时,直接初始化通常更为高效,并能更好地控制初始化过程。而对于基础数据类型,两种初始化方式的效果基本一致,主要区别在于代码风格和可读性。

需要注意

1.隐式类型转换

  • 赋值初始化可能会触发隐式类型转换,这可能导致意外的结果或性能开销。例如,如果存在从一种类型到另一种类型的隐式转换构造函数,编译器会尝试进行这种转换,然后再进行拷贝构造(尽管现代编译器通常会优化掉不必要的拷贝)。
  • 直接初始化可以更明确地指定你想要调用哪个构造函数,从而避免不必要的隐式转换。

2. 列表初始化(C++11及以上)

  • 使用大括号 {} 进行列表初始化可以有效防止窄化转换(narrowing conversions),即从较大的数值范围向较小的数值范围转换时可能丢失精度的情况。例如:
    int x{10.5}; // 编译错误:无法将浮点数隐式转换为整数

3. 拷贝构造和移动语义(C++11及以上)

  • 在C++11及以后版本中,引入了移动语义(move semantics)。如果你的对象支持移动构造函数,直接初始化有时可以更好地利用这一特性来提高性能,特别是在处理临时对象时。

4. 复杂类型与自定义类

  • 对于复杂类型或自定义类,直接初始化通常更为推荐,因为它提供了对构造过程更精确的控制。此外,某些情况下只有直接初始化才能完成特定的构造操作,比如使用多个参数构造对象。

5. 可读性和一致性

  • 尽管两种初始化方式在很多情况下效果相同,保持一致的初始化风格有助于提高代码的可读性和可维护性。选择一种初始化风格并在整个项目中统一使用它是一个好的实践。

 

 

相关文章:

【C++】中的赋值初始化和直接初始化的区别

在C中&#xff0c;赋值初始化&#xff08;也称为拷贝初始化&#xff09;和直接初始化&#xff08;也称为构造初始化&#xff09;虽然常常产生相同的结果&#xff0c;但在某些情况下它们有不同的含义和行为。 赋值初始化&#xff08;Copy Initialization&#xff09; 使用等号…...

Python ❀ Unix时间戳转日期或日期转时间戳工具分享

设计一款Unix时间戳和日期转换工具&#xff0c;其代码如下&#xff1a; from datetime import datetimeclass Change_Date_Time(object):def __init__(self, date_strNone, date_numNone):self.date_str date_strself.date_num date_num# 转时间戳def datetime2timestamp(s…...

本地部署Dify及避坑指南

Dify作为开源的大模型应用开发平台&#xff0c;支持本地私有化部署&#xff0c;既能保障数据安全&#xff0c;又能实现灵活定制。但对于新手而言&#xff0c;从环境配置到服务启动可能面临诸多挑战。本文结合实战经验&#xff0c;手把手教你从零部署Dify&#xff0c;并总结高频…...

大白话CSS 优先级计算规则的详细推导与示例

大白话CSS 优先级计算规则的详细推导与示例 答题思路 引入概念&#xff1a;先通俗地解释什么是 CSS 优先级&#xff0c;让读者明白为什么要有优先级规则&#xff0c;即当多个 CSS 样式规则作用于同一个元素时&#xff0c;需要确定哪个规则起作用。介绍优先级的分类&#xff1…...

OpenCV计算摄影学(19)非真实感渲染(Non-Photorealistic Rendering, NPR)

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 非真实感渲染&#xff08;Non-Photorealistic Rendering, NPR&#xff09;是一种计算机图形学技术&#xff0c;旨在生成具有艺术风格或其他非现实…...

深度学习(斋藤)学习笔记(五)-反向传播2

上一篇关于反向传播的代码仅支持单变量的梯度计算&#xff0c;下面我们将扩展代码使其支持多个输入/输出。增加了对多输入函数&#xff08;如 Add&#xff09;&#xff0c;以实现的计算。 1.关于前向传播可变长参数的改进-修改Function类 修改方法&#xff1a; Function用于对…...

数据库基础练习1

目录 1.创建数据库和表 2.插入数据 创建一个数据库&#xff0c;在数据库种创建一张叫heros的表&#xff0c;在表中插入几个四大名著的角色&#xff1a; 1.创建数据库和表 #创建表 CREATE DATABASE db_test;#查看创建的数据库 show databases; #使用db_test数据库 USE db_te…...

TypeError: Cannot create property ‘xxx‘ on string ‘xxx‘

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》、《前端求职突破计划》 &#x1f35a; 蓝桥云课签约作者、…...

极狐GitLab 17.9 正式发布,40+ DevSecOps 重点功能解读【三】

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署极狐GitLab。 学习极狐GitLab 的相关资料&#xff1a; 极狐GitLab 官网极狐…...

lsblk命令linux查询设备信息

lsblk命令是Linux中用于列出所有可用块设备信息的工具&#xff0c;它能够显示设备之间的依赖关系&#xff0c;但不会列出RAM盘的信息。块设备包括硬盘、闪存盘、CD-ROM等。lsblk命令包含在util-linux包中&#xff0c;该命令的常用参数包括&#xff1a; -d&#xff1a;仅列出磁盘…...

【智能体架构:Agent】LangChain智能体类型ReAct、Self-ASK的区别

1. 什么是智能体 将大语言模型作为一个推理引擎。给定一个任务&#xff0c; 智能体自动生成完成任务所需步骤&#xff0c; 执行相应动作&#xff08;例如选择并调用工具&#xff09;&#xff0c; 直到任务完成。 2. 先定义工具&#xff1a;Tools 可以是一个函数或三方 API也…...

鸿蒙开发:弹性布局Flex

前言 代码案例基于Api13。 正在开发一个搜索组件&#xff0c;其中一个功能是针对历史搜索的内容进行展示&#xff0c;由于搜索的内容长度不一&#xff0c;需要进行流式布局展示&#xff0c;效果如下&#xff1a; 以上的效果&#xff0c;相信大家在很多的应用里或多或少都见到过…...

【DeepSeek】5分钟快速实现本地化部署教程

一、快捷部署 &#xff08;1&#xff09;下载ds大模型安装助手&#xff0c;下载后直接点击快速安装即可。 https://file-cdn-deepseek.fanqiesoft.cn/deepseek/deepseek_28348_st.exe &#xff08;2&#xff09;打开软件&#xff0c;点击立即激活 &#xff08;3&#xff09;选…...

易基因特异性R-loop检测整体研究方案

大家好&#xff0c;这里是专注表观组学十余年&#xff0c;领跑多组学科研服务的易基因。 01.技术简述 R-loop是由DNA:RNA 杂交体和被置换的单链DNA组成的三链核酸结构&#xff0c;广泛参与基因转录、表观遗传调控及DNA修复等关键生物学过程。异常的R-loop积累会导致基因组不稳…...

虚拟系统配置案例

安全策略要求&#xff1a; 1、只存在一个公网IP地址&#xff0c;公司内网所有部门都需要借用同一个接口访问外网 2、财务部禁止访问Internet&#xff0c;研发部门只有部分员工可以访问Internet&#xff0c;行政部门全部可以访问互联网 3、为三个部门的虚拟系统分配相同的资源类…...

C语言【进阶篇】之结构体 —— 从基础声明到复杂应用的进阶之路

目录 &#x1f680;前言✍️结构体类型的声明&#x1f4af;结构体定义&#x1f4af;结构的特殊声明 &#x1f99c;结构的自引用&#x1f4bb;结构体内存对齐&#x1f4af;对齐规则&#x1f4af;为什么存在内存对齐&#x1f4af;修改默认对齐数 &#x1f40d;结构体传参&#x1…...

Python-列表和元组

列表 列表是什么, 元组是什么 编程中, 经常需要使用变量, 来保存/表示数据. 如果代码中需要表示的数据个数比较少, 我们直接创建多个变量即可. 但是有的时候, 代码中需要表示的数据特别多, 甚至也不知道要表示多少个数据. 这个时候, 就需要用到列表. 列表是一种让程序猿在代…...

PyTorch 中的混合精度训练方法,从 autocast 到 GradScalar

PyTorch 的混合精度训练主要由两个方法实现&#xff1a;amp.autocast 和 amp.GradScalar。在这两个工具的帮助下&#xff0c;可以实现以 torch.float16 的混合精度训练。当然&#xff0c;这两个方法都是模块化并且通常都会一起调用&#xff0c;但并不一定总是需要一起使用。 参…...

分享能在线运行C语言的网站

https://www.onlinegdb.com/# 我用vscode运行c语言总是报错&#xff0c;后面找到这个网站&#xff0c;可以在线调试和保存代码。 如下图&#xff0c;程序的效果是给变量x&#xff0c;y&#xff0c;z赋值&#xff0c;并打印出来。代码输入以后&#xff0c;右上角选择C语言&…...

AI-Deepseek + PPT

01--Deepseek提问 首先去Deepseek问一个问题&#xff1a; Deepseek的回答&#xff1a; 在汽车CAN总线通信中&#xff0c;DBC文件里的信号处理&#xff08;如初始值、系数、偏移&#xff09;主要是为了 将原始二进制数据转换为实际物理值&#xff0c;确保不同电子控制单元&…...

MacOS Big Sur 11 新机安装brew wget python3.12 exo

MacOS Big Sur 11,算是很老的系统了&#xff0c;所以装起来有点费劲。 首先安装brew 按照官网的方法&#xff0c;直接执行下面语句即可安装&#xff1a; export HOMEBREW_BREW_GIT_REMOTE"https://githubfast.com" # put your Git mirror of Homebrew/brew here …...

十大经典排序算法简介

一 概述 本文对十大经典排序算法做简要的总结(按常用分类方式排列),包含核心思想、时间/空间复杂度及特点。 二、比较类排序 1. 冒泡排序 (BUBBLE SORT) 思想:重复交换相邻逆序元素,像气泡上浮 复杂度: 时间:O(n^2)(最好情况O(n)) 空间:O(1) 特点:简单但效率低,稳…...

不小心更改了/etc权限为777导致sudo,ssh等软件都无法使用

修复流程 一、进入恢复模式&#xff08;无网络或无法登录时必选&#xff09; 1.重启系统&#xff0c;在 GRUB 启动菜单选择 Recovery Mode&#xff08;按 Shift 或 Esc 呼出菜单&#xff09;。2.以 root 身份挂载为可读写&#xff1a; bash 复制 mount -o remount,rw /确保文…...

AI档案审核2

以下是一个结合计算机视觉&#xff08;CV&#xff09;和自然语言处理&#xff08;NLP&#xff09;的智能档案审核系统完整实现方案&#xff0c;包含可落地的代码框架和技术路线&#xff1a; 一、系统架构设计 #mermaid-svg-UhBtIPrNXo5P89Zb {font-family:"trebuchet ms&q…...

【基础1】冒泡排序

核心思想 冒泡排序是通过相邻元素的连续比较和交换&#xff0c;使得较大的元素逐渐"浮"到数组的末尾&#xff0c;如同水中气泡上浮的过程 特点&#xff1a; 每轮遍历将最大的未排序元素移动到正确位置​稳定排序&#xff1a;相等元素的相对位置保持不变​原地排序…...

Trae AI 开发工具使用手册

这篇手册将介绍 Trae 的基本功能、安装步骤以及使用方法&#xff0c;帮助开发者快速上手这款工具。 Trae AI 开发工具使用手册 Trae 是字节跳动于 2025 年推出的一款 AI 原生集成开发环境&#xff08;IDE&#xff09;&#xff0c;旨在通过智能代码生成、上下文理解和自动化任务…...

揭开AI-OPS 的神秘面纱 第二讲-技术架构与选型分析 -- 数据采集层技术架构与组件选型分析

基于上一讲预设的架构图&#xff0c;深入讨论各个组件所涉及的技术架构、原理以及选型策略。我将逐层、逐组件地展开分析&#xff0c;并侧重于使用数据指标进行技术选型的对比。 我们从 数据采集层 开始&#xff0c;进行最细粒度的组件分析和技术选型比对。 数据采集层技术架构…...

基于Docker去创建MySQL的主从架构

基于Docker去创建MySQL的主从架构 用于开发与测试环境读写分离 主从的架构搭建步骤 基于Docker去创建MySQL的主从架构 # 创建主从数据库文件夹 mkdir -p /usr/local/mysql/master1/conf mkdir -p /usr/local/mysql/master1/data mkdir -p /usr/local/mysql/slave1/conf mkd…...

操作系统 2.2-多进程总体实现

多个进程使用CPU的图像 如何使用CPU呢&#xff1f; 通过让程序执行起来来使用CPU。 如何充分利用CPU呢&#xff1f; 通过启动多个程序&#xff0c;交替执行来充分利用CPU。 启动了的程序就是进程&#xff0c;所以是多个进程推进 操作系统需要记录这些进程&#xff0c;并按照…...

Jasypt 与 Spring Boot 集成文档

Jasypt 与 Spring Boot 集成文档 目录 简介版本说明快速开始 添加依赖配置加密密钥加密配置文件 高级配置 自定义加密算法多环境配置 最佳实践常见问题参考资料 简介 Jasypt 是一个简单易用的 Java 加密库&#xff0c;支持与 Spring Boot 无缝集成。通过 Jasypt&#xff0c;…...