首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

共享指针的赋值/初始化差异

共享指针的赋值/初始化差异是指在C++中,使用智能指针进行资源管理时,对于共享指针的赋值和初始化有一些不同的方式。

共享指针是一种智能指针,它可以在多个指针之间共享同一个对象,并且会自动管理对象的生命周期,避免内存泄漏和悬空指针的问题。

在C++中,常用的共享指针是std::shared_ptr,它是C++11引入的标准库类型。

  1. 赋值操作: 共享指针的赋值操作可以通过拷贝构造函数或赋值运算符进行。当将一个共享指针赋值给另一个共享指针时,会发生以下情况:
    • 如果被赋值的共享指针为空(即指向nullptr),则赋值后的共享指针也为空。
    • 如果被赋值的共享指针不为空,且没有其他共享指针指向同一个对象,则赋值后的共享指针指向被赋值的对象。
    • 如果被赋值的共享指针不为空,且有其他共享指针指向同一个对象,则赋值后的共享指针也指向同一个对象,并且对象的引用计数会增加。
  • 初始化操作: 共享指针的初始化可以通过直接使用构造函数或std::make_shared函数进行。以下是几种常见的初始化方式:
    • 直接初始化:使用构造函数将一个指针或nullptr作为参数传递给共享指针的构造函数进行初始化。 例如:std::shared_ptr<int> ptr(new int(10));
    • 隐式转换初始化:将一个指针或nullptr赋值给共享指针,编译器会自动进行类型转换和初始化。 例如:std::shared_ptr<int> ptr = nullptr;
    • 使用std::make_shared函数初始化:该函数可以直接创建一个共享指针,并将参数传递给对象的构造函数。 例如:std::shared_ptr<int> ptr = std::make_shared<int>(10);

共享指针的赋值/初始化差异主要体现在语法上的不同,但它们的效果是相同的,都可以用于管理动态分配的资源,避免内存泄漏和悬空指针的问题。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云C++ SDK:https://cloud.tencent.com/document/product/876
  • 腾讯云云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云云数据库MySQL版:https://cloud.tencent.com/product/cdb_mysql
  • 腾讯云云原生容器服务:https://cloud.tencent.com/product/tke
  • 腾讯云音视频处理:https://cloud.tencent.com/product/mps
  • 腾讯云人工智能:https://cloud.tencent.com/product/ai
  • 腾讯云物联网平台:https://cloud.tencent.com/product/iotexplorer
  • 腾讯云移动开发:https://cloud.tencent.com/product/mobdev
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云区块链服务:https://cloud.tencent.com/product/baas
  • 腾讯云元宇宙:https://cloud.tencent.com/product/tencent-metaverse
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

C语言指针初始化赋值

1、指针初始化 指针初始化时,“=”右操作数必须为内存中数据地址,不可以是变量,也不可以直接用整型地址值(但是int*p=0;除外,该语句表示指针为空)。...因为p是指向7所在地址,*p = 7给p所指向内存赋值,p没有赋值,所以p所指向内存位置是随机,没有初始化。...p1 = p2; //注意啦,p1指向了val2,而没有指向val1 备注:字符串与指针初始化赋值 初始化: char *cp = “abcdefg”; //这个初始化过程,是将指针cp指向字符串首地址...,如:char *cp = “abcdefg”; 对指针进行初始化赋值实质是将一个地址或同类型(或相兼容类型)指针赋给它,而不管这个地址是怎么取得。...6、指向指针指针指针初始化第5种方式中提到了用一个指针地址来初始化一个指针。回忆一下上一讲内容:指针是一种变量,它也有自己地址,所以它本身也是可用指针指向对象。

2.5K10

【编程基础】C语言指针初始化赋值

1、指针初始化 指针初始化时,“=”右操作数必须为内存中数据地址,不可以是变量,也不可以直接用整型地址值(但是int*p=0;除外,该语句表示指针为空)。...因为p是指向7所在地址,*p = 7给p所指向内存赋值,p没有赋值,所以p所指向内存位置是随机,没有初始化。...p1 = p2; //注意啦,p1指向了val2,而没有指向val1 备注:字符串与指针初始化赋值 初始化: char *cp = "abcdefg"; //这个初始化过程,是将指针cp指向字符串首地址...,如:char *cp = “abcdefg”; 对指针进行初始化赋值实质是将一个地址或同类型(或相兼容类型)指针赋给它,而不管这个地址是怎么取得。...6、指向指针指针指针初始化第5种方式中提到了用一个指针地址来初始化一个指针。回忆一下上一讲内容:指针是一种变量,它也有自己地址,所以它本身也是可用指针指向对象。

2.9K80
  • 【C 语言】指针间接赋值 ( 指针作为 函数参数 意义 | 间接赋值 代码示例 )

    文章目录 一、指针作为 函数参数 ( 间接赋值 ) 意义 二、间接赋值 代码示例 一、指针作为 函数参数 ( 间接赋值 ) 意义 ---- 调用函数时 , 调用 & 取地址 生成 实参 p , 将...指针变量 p 实参 传递给 函数形参 , 在函数中 借助传入 指针 可以 实现 与 外部函数 内存共享 , 在函数中使用 *p 修改内存值 , 可以将 运算结果通过 *p 传递出来 ; 指针 作为...函数参数 , 可以实现 主函数 与 被调用子函数 之间 内存交换 ; 下面是逻辑链 : 指针作函数参数 ( 间接赋值 ) -> 接口封装与设计 -> 模块划分 -> 软件分层 正是因为有了 间接赋值 ,...才能实现 接口封装与设计 , 进而实现了 模块划分 , 最后实现了 软件分层 ; 使用 指针 ( 一级指针 或 多级指针 ) 作为参数 , 可以更加灵活在 函数中 对 传入 指针 指向内存数据...进行处理 , 这些修改 , 可以保留到函数值返回之后 , 这些参数都可以作为返回值使用 ; 使用 指针 ( 一级指针 或 多级指针 ) 作为参数 , 实现了 main 函数 , 与 其它 子函数 之间

    1.2K10

    关于golang中指针赋值问题

    最近在SO上找到了一个很有意思问题: 这个问题是关于一个指针在外部函数赋值,当然,解决方法也很简单。...如果是学过C风格指针的话应该会发现这条语句是很奇怪,从语法上讲u中存放地址会被改变,但是实际上它并不会改变(PS:原来这个代码需要修改一下,不然会有dereference nil错误) 修改后例子...0xc000006028, address inside pointer is 0xc000004580 main(): user IP address is 129.0.0.1 可以看到,对于主函数中指针...问题在于,传入函数中指针地址是变动,也就是传入函数指针并不是原来指针(这很正常,因为golang并没有引用传值,每一个变量地址都是不一样)。...所以,单纯修改指针中存放内容是没有任何用处。如果假设指针是杯子,里面存放内容是某种液体,现在main函数中u杯子里面装是水,那么defaultIP杯子中装就是酱油。

    99430

    const修饰双重指针赋值解惑

    在c程序中,我们可能经常会使用到指针之间赋值。...传统赋值操作: char *cp = "c"; const char *ccp; ccp = cp; printf("*ccp:%c",*ccp); 会正常打印出*cpp所指字符。...ccp是一个const修饰符修饰指向char类型指针,也就是说,它指向是char类型,但是指针本身是不可修改。...也就是说: ccp是一个指向有const修饰符指针,cp是一个指向没有const修饰符指针。ccp中包含了cp所有修饰符(其实cp就没啥修饰符),因此可以进行赋值。...这样,我们看一下面的代码: c是一个指向char类型指针指针。 cc是一个指向const修饰符修饰char类型指针指针。 cc 与 c指向内容并不相同,因此无法进行赋值操作。

    99490

    深拷贝浅拷贝和赋值差异

    区别 浅拷贝---拷贝是一个对象指针,而不是复制对象本身,拷贝出来对象共用一个指针,其中一个改变了值,其他也会同时改变。...深拷贝---拷贝出来一个新对象,开辟一块新空间,拷贝前后对象相互独立,互相不会改变,拥有不同指针。...,赋值对于基本数据来说就是在栈中新开了一个变量,相当于是两个独立栈内存,所以相互不会影响,但是对于引用数据类型,他只是复制了一份a在栈内存指针,所以两个指针指向了同一个堆内存空间,通过任何一个指针改变值都会影响其他...,通过这样赋值可以产生多个指针,但是堆内存空间始终只有一个,这就是赋值产生问题,我们在开发中当然不希望改变B而影响了A,所以这个时候就需要用到浅拷贝和深拷贝了。...针对基本数据类型,随便赋值都不会相互影响 针对引用数据类型,赋值就会出现我们不想看到,改动一方双方都变化。

    46020

    c语言中指针赋值问题,关于C语言指针赋值问题「建议收藏」

    大家好,又见面了,我是你们朋友全栈君。 为方便各位小伙伴更好学习C语言,武林技术小编为此给大家整理了一批资料,供大家交流学习,下面就跟随武林技术频道编辑一起来先来看看关于C语言指针赋值问题。...:22: 警告: 赋值时将指针赋给整数,未作类型转换 test.c:23: 警告: 赋值时将指针赋给整数,未作类型转换 test.c:24: 警告: 赋值时将指针赋给整数,未作类型转换 test.c:25...(uchar *)强制类型转换是为了配合(uchar *p). ——————————————- 应该注意2点是: 1.给指针只能传地址,不能传值.否则要做强制类型转换. 2.在做类型转换和赋值时候,...应该注意赋值类型匹配....以上就是关于C语言指针赋值问题,想必都已有了一定了解,更多关于C语言内容请继续关注武林技术频道。

    1.6K10

    PLSQL 集合初始化赋值

    对于集合类型,与单一数据类型相比较而言,应该以一个整体观念来考虑集合,即是一批类型相同数据组合而非单一数据。因此集 合类型集合声明、赋值初始化较之单一类型而言,有很大不同。...有关集合类型描述请参考: PL/SQL 联合数组与嵌套表 PL/SQL 变长数组 PL/SQL --> PL/SQL记录 一、联合数组赋值     联合数组不需要初始化,直接赋值即可。...|| ') value is ' || loc_tab( v_counter ) ); END LOOP; END; 二、集合初始化赋值 1、初始化方法      集合类型主要分为三步来完成...,使用构造函数直接初始化赋值 -->变长数组初始化与嵌套表一样,可以使用构造函数直接初始化赋值 DECLARE TYPE varry_loc_type IS VARRAY( 10 ) OF...5、集合类型赋值可以在声明块声明时赋值,也可以在执行块执行时使用extend方式扩展后再赋值。 6、集合类型初始化过程连同赋值可以在声明集合同时使用构造函数直接进行初始化赋值,从而一步完成。

    2.3K50

    字符数组初始化赋值

    代码编译运行环境:VS2017+Win32+Debug ---- 1.字符数组初始化方式 C语言中表示字符串有两种方式,数组和指针,字符数组是我们经常使用方式。...变量定义包括指明变量所属类型、变量名称、分配空间以及初始化。可以看出,变量初始化是变量定义一部分。...除了const变量需要显示初始化以外,其它变量如果在定义时未显示初始化,编译器会为变量以默认值进行初始化。变量赋值初始化有着本质区别,字符数组也是如此,具体见我另一篇博客:认识初始化。...test3[256]={'\0'}; 2.字符数组赋值 当为已经完成定义字符数组赋值时,不能采用类似于初始化方式为字符数组赋值了。...左值概念见博客:认识左值与常引用。 2.1逐个字符赋值 (1)for循环方式。

    7.2K20

    类成员初始化赋值

    y = yy; } 其中,x 以构造函数特有的语法(初始化列表)形式被初始化,而 y 则在构造函数中被赋值。...: 初始化发生时机比赋值要早。...初始化发生时刻实际上是程序刚刚开始运行时候,而赋值语句则要等到程序执行到该语句才开始。 初始化执行效率比赋值要高。...事实上,类成员数据在构造函数中被赋值之前,已经被系统进行过一次 default 初始化,因此赋值语句相当于抹掉了先前初始化执行效果,使得系统做了一次无用功。...而在构造函数中运用初始化列表则可以避免这样效率浪费。 常量成员(const)和引用成员(reference)只能使用初始化列表来赋值

    1.1K20

    es6解构赋值_字符串赋值给字符指针

    大家好,又见面了,我是你们朋友全栈君。...ES6 模板字符串与解构赋值 解构赋值 展开运算符 模板字符串 特点 模板字符串可以换行 模板字符串中变量表达方式 ${变量/表达式} //模板字符串 //特点...特点: 可以定义默认值 可以嵌套 可以不完全解构 好处: 不通过遍历,方便快捷将元素取出来 //解构赋值 //可以定义默认值 //可以嵌套 //可以不完全解构...//数组用法 let a=[1,2,3] let [b,c,d]=a; console.log(b,c,d)//1,2,3 //数组解构赋值时可以嵌套 let s=[[1,2...一定要与对象属性名一致,如果想不一致的话,要在变量前面加属性名: console.log(name,age);//xiaoxiao 15 //错误写法 // let {fg

    2.3K20

    类成员初始化赋值内幕

    { b = bb; } private: int a; int b; }; 可以看到 a 值是用初始化列表方式进行初始化,而 b 值是通过构造函数参数进行赋值...在类对象调用构造函数时候,以上两种方式都可以确保 a 和 b 值是可以确定,但是初始化赋值两种方式是有区别的: 初始化发生时机肯定比赋值早。...初始化会在程序刚开始运行时候发生,而赋值是只有在程序执行到这条语句才会发生。 初始化执行效率要比赋值高。...类成员在构造函数中执行赋值语句之前已经被系统进行了初始化,当执行赋值时候就需要抹掉之前default初始化数据,这样就相当于多做了一次无用功,而构造函数中运行初始化列表则不需要做这次无用功。...另外,类成员初始化顺序固定:如果有基类的话,先初始化基类,然后按照类中声明顺序去初始化派生类中类成员。

    40520

    【C 语言】指针数据类型 ( 指针类型变量 与 指针指向内存块 概念区别 | 指针赋值 | 指针运算 | 内存赋值 | 内存取值 | 内存修改注意事项 )

    文章目录 一、指针类型变量 与 指针指向内存块 概念区别 1、指针赋值 2、指针运算 3、内存赋值 4、内存取值 5、内存修改注意事项 一、指针类型变量 与 指针指向内存块 概念区别 ---- 指针类型变量...&a; 1、指针赋值指针赋值 : 给上述指针变量 p 赋值操作 , 如 p = 0x7F451D12 , 只改变指针变量 p 值 , 没有改变指针变量 p 原来指向 内存块 中存储值 ; char..., p + 1 与 p++ 计算结果是指针地址值加上指针类型对应字节大小值 , 如果是 int 类型指针 , 则增加 4 字节 ; 3、内存赋值 ** 给指针指向内存赋值 * 给上述指针变量...p 指向内存 进行赋值操作 , 如 *p = 0x7F451D12 , 不会改变指针变量 p 值 , 只会改变指针变量 p 原来指向 内存块 中存储值 ; 4、内存取值 指针指向内存赋值与取值...: 给内存赋值 : *p 如果在 等号 = 左边 , 则表示给 指针 指向 内存 赋值 ; 从内存取值 : *p 如果在 等号 = 右边 , 则表示从 指针 指向 内存 取值 ; 5、内存修改注意事项

    3K20

    【C 语言】指针间接赋值 ( 间接赋值三要素 | 间接赋值 使用三种场景 )

    ; ② 实参地址赋值给形参 ; ③ 使用形参指针修改实参值 ; 间接赋值 3 大要素 : 要素 ① : 定义 实际变量 ( 实参 ) , 以及接收 实际变量 地址 指针参数 ( 形参 ) ; 如果...: 使用 形参指针 修改 实际变量 ( 实参 ) 值 ; *p = 20; 二、间接赋值 使用场景 ---- 上述 间接赋值 3 要素 , ① 定义实参和形参 ; ② 实参地址赋值给形参 ;...; ( 最常见 ) 语法现象 三 : ① 在一个函数中 , ② ③ 在另一个函数中 ; ( 初始化函数常用 ) 1、① ② ③ 都在同一个函数中 #include #include...0 char *p = NULL; // 将 a 地址赋值指针变量 p p = &a; // 通过指针 简介修改 变量 a 值 // * 符号可以看做..., 并为其设置 NULL 初始值 // NULL 就是 0 int *p = NULL; // 将 a 地址赋值指针变量 p p = &a; // 调用

    1.9K20

    指向字符串指针赋值就出错?

    现有一个指向字符串指针, char *test ="123123123"; 如果执行下面这句话就会出错 *test=“321321”; 这是因为 test 这个指针指向是123123123这个储存于常量区字符串...这个区域数据是不可改写,所以运行*test=“321321”;这句话会出错。 数据存在于哪里通常可以用4个区来表达,也就是常说内存四区。...通常说内存四区指就是上图中堆区、栈区、全局区和代码区这四个部分,全局区又可以分为全局变量区和常量区。 栈区包括局部变量、函数入参,返回值等。堆区是由程序员自行分配内存。...为什么要划分这几个区呢,这是因为把不同数据放到不同区里,就赋予了这些变量或常量不同生命周期和不同释放方式,这样我们在编程中就可以根据需求灵活运用。...通过以上可以看出,上图中红色框内是不可以更改,开头那个字符串是存储在常量区,是不可以更改。所以开头那个程序运行就会出错。

    52530

    【Kotlin】类初始化 ③ ( init 初始化块 | 初始化顺序 : 主构造函数属性赋值 -> 类属性赋值 -> init 初始化块代码 -> 次构造函数代码 )

    文章目录 一、init 初始化块 二、初始化顺序 一、init 初始化块 ---- 在 Kotlin 类中 , 可以定义 init 初始化块 , 在其中可以为 变量赋值 , 执行一些检查相关代码 ,...时会执行一系列 初始化操作 , 这些操作按照如下顺序执行 : 主构造函数 中属性赋值 类中属性赋值 init 初始化块 中代码执行 次构造函数 中代码执行 代码示例 : 通过下面的代码分析 Kotlin..., 这是在 主构造函数 中完成操作 ; 然后 , 为 age 和 type 属性赋值 , 这是在 类 中 age 属性进行赋值 , 使用是 主构造函数 中临时变量 ; 最后 , 为 gender...赋值 , 这是在 init 初始化块 中进行赋值 ; 然后分析 次构造函数 , 在 如下 次构造函数代码中 , 先执行了 主构造函数 , 然后才为 type 属性赋值 , 这是在次构造函数中执行...: 主构造函数属性赋值 -> 类属性赋值 -> init 初始化块代码 -> 次构造函数代码

    1.9K30
    领券