C++總結筆記(十二)—— 智能指針

文章目錄

  • 前言
  • 一、智能指針是什么?
  • 二、示例
  • 總結


前言

C++對于內存管理的要求很高,如果不及時釋放對象內存,就可能會發生內存泄露或野指針等情況,鑒于這種情況,C++11提出了智能指針的概念。

一、智能指針是什么?

智能指針可以將指針封裝為一個棧對象,當不需要使用時,會在析構函數中釋放掉申請的內存,所有的智能指針類均包含于頭文件 < memory> 內。
其原理是:通過重載*,->,(),=運算符來完成普通指針的功能,并定義了一些成員函數,如reset,swap ,use_count,get等。
C++ 常見的有三種智能指針:unique_ptr、shared_ptr、weak_ptr。
另外還有一個auto_ptr目前已不推薦使用,原因是經常會誤用其指針賦值功能(將指向的對象轉移到賦值的指針下,之前的指針會指向NULL)造成內存錯誤。
其中:
unique_ptr聲明的指針只能指向唯一的對象,不能賦值給其他指針,但可以使用move方法移動內存到另一個指針指向的內存里。當對象銷毀時會釋放其持有的堆內存。
shared_ptr表示該類型的指針變量可以共享內存對象,同時可以使用use_count來統計引用次數。
std::weak_ptr 表示指針不控制對象的生命周期,只用于訪問對象。其目的是協助 std::shared_ptr 工作,構造和析構不會引起引用計數的增加或減少,可以解決shared_ptr 互相引用導致的死鎖問題。該類型指針沒有重載*和->運算符,但可以使用expired方法來判斷weak_ptr的對象是否被釋放。多應用于事件對象的聲明中。

二、示例

#include<iostream>
#include <memory>
using namespace std;void test1()
{//1unique_ptr<int> p1(new int(1));cout << *p1 << endl;//2unique_ptr<int> p2;p2.reset(new int(2));cout << *p2 << endl;//3,make_unique方法是C++14開發的unique_ptr<int> p3 = make_unique<int>(3);cout << *p3 << endl;
}void test2()
{//1shared_ptr<int> p1(new int(1));cout << *p1 << endl;//use_count方法用于獲取當前資源的引用計數cout << "use count: " << p1.use_count() << endl;//2shared_ptr<int> p2;p2.reset(new int(2));cout << *p2 << endl;//3shared_ptr<int> p3;p3 = make_shared<int>(3);cout << *p3 << endl;//4,可以拷貝和賦值p1的資源shared_ptr<int> p4(p1);cout << *p4 << endl;//use_count方法用于獲取當前資源的引用計數cout << "use count: " << p4.use_count() << endl;shared_ptr<int> p5 = p1;cout << *p5 << endl;//use_count方法用于獲取當前資源的引用計數cout << "use count: " << p5.use_count() << endl;
}void test3()
{//創建一個shared_ptr指針shared_ptr<int> p1(new int(1));cout << *p1 <<endl;//將shared_ptr指針拷貝給weak_ptr指針weak_ptr<int> p2(p1);cout << "use count: " << p1.use_count() << endl;//賦值weak_ptr<int> p3 = p1;cout << "use count: " << p1.use_count() << endl;
}int main()
{/*test1();*//*test2();*/test3();system("pause");return 0;
}

總結

使用智能指針需要注意其使用場合。聲明不需共享的對象,使用unique_ptr,需要共享,則使用shared_ptr,需要的時候用,不需要的時候不用,可以使用weak_ptr。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/256088.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/256088.shtml
英文地址,請注明出處:http://en.pswp.cn/news/256088.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

代碼生成工具之界面快速生成

界面開發&#xff0c;無論對于Web開發&#xff0c;還是Winform開發&#xff0c;都需要耗費一定的時間&#xff0c;特別對于一個數據庫字段比較多的界面&#xff0c;一般就需要在編輯界面上擺的更多的控件來做數據顯示&#xff0c;每次碰到這個&#xff0c;都有點頭痛&#xff0…

javascript - 封裝原生js實現ajax

1 /*2 * ajax方法3 */4 var Ajax function() {5 var that this;6 //創建異步請求對象方法7 that.createXHR function() {8 if(window.XMLHttpRequ…

QT對象樹、信號和槽機制

文章目錄一 、對象樹是什么&#xff1f;二、信號和槽的基本概念2.1 信號2.2 槽2.3 松散耦合2.4 特點三、示例總結一 、對象樹是什么&#xff1f; 對象樹是由父類和若干子類對象組成&#xff0c;而子類也可以由若干孫類。 QT中的對象樹是以QObject為起始父類來完成樹的構建的&a…

【數據結構】——歸并排序

目錄 一、代碼 二、隨筆 一、代碼 歸并排序的主要思路&#xff1a;將兩個有序的子列表歸并為一個有序的大列表 #歸并函數&#xff0c;假設li是由左右兩個有序的子列表組成,假設兩個子列表都是從小到大排好序的列表 def merge(li,low,mid,high)::param li: 由左右兩個有序的子列…

開發發布npm module包

開發發布npm module包 問題 在項目開發過程中&#xff0c;每當進入一個新的業務項目&#xff0c;從零開始搭建一套前端項目結構是一件讓人頭疼的事情&#xff0c;就要重新復制一個上一個項目的前端框架和組件代碼庫。其中很多功能的模塊組件都要重復拷貝&#xff0c;可以統一將…

如何使用ATS提高應用的安全性

App Transport Security&#xff0c;簡短的說就是ATS&#xff0c;是iOS9和OS X El Capitan的一個新特性。App Transport Security 的目標是提高Apple 操作系統的安全性以及在此操作系統上運行的任何應用的安全性。 基于HTTP傳輸數據的網絡請求都是明文。開啟App Transport Secu…

手機客戶端測試考慮的點

手機客戶端測試考慮點總結 版權聲明&#xff1a;本文為博主原創文章&#xff0c;未經博主允許不得轉載。 此文未本人工作中的總結&#xff0c;特此總結。 異常場景&#xff1a; 網絡異常&#xff0c;服務器異常&#xff0c;接口異常或參考參數篡改&#xff0c;斷電&#xff0c;…

NMS(非極大值抑制)算法詳解與示例

一、NMS是什么&#xff1f; NMS&#xff08;non maximum suppression&#xff09;即非極大值抑制&#xff0c;廣泛應用于傳統的特征提取和深度學習的目標檢測算法中。 NMS原理是通過篩選出局部極大值得到最優解。 在2維邊緣提取中體現在提取邊緣輪廓后將一些梯度方向變化率較小…

【數據結構】——冒泡排序、插入排序、選擇排序

# 冒泡排序&#xff0c;復雜度為O(n^2) def bubble_sorted(li:list)->list:for i in range(len(li)):# 第幾趟exchanged False# 這個是為了防止多余的遍歷&#xff0c;如果前面的元素已經是排序好的&#xff0c;那就不需要再進行比較了&#xff0c;減少運行時間for j in ra…

【轉載】ASP.NET應用程序與頁面生命周期

在本文中&#xff0c;我們將了解不同的事件&#xff0c;ASP.NET 應用程序的生命周期以瀏覽器向 Web 服務器&#xff08;對于 ASP.NET 應用程序&#xff0c;通常為 IIS&#xff09;發送請求為起點&#xff0c;直至將請求結果返回至瀏覽器結束。在這個過程中&#xff0c;首先我們…

基于PCL的ICP及其變種算法實現

文章目錄前言一、ICP算法基礎1.1 提取待匹配點對1.2 計算旋轉平移矩陣1.3 計算變換后的點和目標點之間的偏差二、ICP算法變種2.1 PLICP2.2 PointToPlane ICP2.3 NICP2.4 LM_ICP三、程序示例1. 傳統方法2. PointToPlane ICP總結前言 ICP&#xff08;Iterative Closest Point&am…

python 計算器

--coding:utf-8-- from Tkinter import * 創建橫條型框架 def frame(root, side): w Frame(root) w.pack(side side, expand YES, fill BOTH) return w 創建按鈕 def button(root, side, text, command None): w Button(root, text text, command command) w.pack(side…

最長公共子序列(LCS)

注意最長公共子串&#xff08;Longest CommonSubstring&#xff09;和最長公共子序列&#xff08;LongestCommon Subsequence, LCS&#xff09;的區別&#xff1a;子串&#xff08;Substring&#xff09;是串的一個連續的部分&#xff0c;子序列&#xff08;Subsequence&#x…

【數據結構】——排序算法系列總結

目錄 1、空間復雜度 2、穩定性 3、運行時間 4、目前默認的sort內置函數排序函數 5、六種常用排序方法 1、空間復雜度 空間復雜度產生的原因有兩個&#xff1a;①重新定義了一塊空間用于存儲數據&#xff1b;②遞歸產生了棧空間 冒泡排序、選擇排序、堆排序和插入排序屬于…

Spring Boot實踐教程(二):SpringApplication分析

2019獨角獸企業重金招聘Python工程師標準>>> 本文會通過分析上一篇中跑起來的示例程序來分析一下Spring Boot程序運行的基本原理。 概要 在上一篇的介紹中&#xff0c;程序是通過SpringBoot1HelloworldApplication.main()方法運行起來的&#xff1a; public static …

基于PCL的MLS(移動最小二乘)算法簡介與示例

一、MLS基礎 mls算法本質上和最小二乘一樣&#xff0c;是一種擬合數據的算法。區別在于mls是局部的&#xff0c;即通過系數向量和基函數分別對數據中不同位置的節點區域進行擬合&#xff0c;需要計算出全部節點域的擬合函數的參數。而傳統的最小二乘是全局的&#xff0c;采用所…

二分法php

二分法。分別使用while循環的方法和遞歸調用的方法。 <?php// 二分法的使用數組必須是有序的&#xff0c;或升序&#xff0c;或降序 $arr array(1, 3, 5, 7, 9, 13 );// 遞歸調用&#xff08;相比較好理解 function bsearch_r($v, $arr, $low, $high){if ($low > $high…

【JZOJ4861】【NOIP2016提高A組集訓第7場11.4】推冰塊

題目描述 Dpstr最近迷上了推冰塊。冰地是一個n行m列的網格區域&#xff0c;第i行第j列的格子記為(i,j)&#xff0c;也就是左上角為(1,1)&#xff0c;右下角為(n,m)。每個格子可能是冰面、障礙物、減速帶三者之一。其中&#xff0c;冰地外圍&#xff08;即第0行、第n1行、第0列、…

【圖像處理面試題】——1

鏈接&#xff1a;https://www.jianshu.com/p/e58ca1775700 1、給定0-1矩陣&#xff0c;求連通域。2、寫一個函數&#xff0c;求灰度圖的直方圖。3、寫一個均值濾波&#xff08;中值濾波&#xff09;。4、寫出高斯算子&#xff0c;Sobel算子&#xff0c;拉普拉斯算子等&#xff…

IT運維服務管理問題總結 #F#

1.管理現狀問題&#xff1a;支撐企業業務運行的IT系統主要由大量的網絡設備、主機系統和應用系統組成&#xff0c;這些設備和系統從應用角度來分又屬于不同的業務系統和部門&#xff0c;網絡設備、主機系統等具備獨立的用戶管理、認證授權和審計系統&#xff0c;且由不同的系統…