析构函数、dispose模式

2023-11-05 16:30
文章标签 函数 模式 析构 dispose

本文主要是介绍析构函数、dispose模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

析构函数书写规则

在C#3.0发布之前,析构函数有时也叫终结器(finalizer)
(1)每个类只能有一个析构函数
(2)析构函数不能有参数
(3)析构函数不能有访问修饰符
(4)析构函数名称与类名相同,但要在前面加一个~
(5)析构函数只能作用与类的实例,因此没有静态析构函数
(6)不能在代码中显式调用析构函数,相反,当垃圾回收器分析代码并认为代码中不存在指向该对象的可能路径时,系统会在垃圾回收过程中调用析构函数。

    public class A{~A()   //析构函数{//相关释放处理}}

析构函数的使用规则

(1)不要在不需要时实现析构函数,这会严重影响性能
(2)析构函数应该只释放对象拥有的外部资源
(3)析构函数不应该访问其他对象,因为无法认定这些对象是否已经被销毁

标准dispose模式

与C++析构函数不同,C#析构函数不会在实例超出作用域时立即调用,事实上,你无法知道何时会调用析构函数,而且你也不能显式调用析构函数,你所能知道的只是,系统会在对象从托管堆上移除之前的某个时刻调用析构函数。如果你想让你的代码中包含的非托管资源越快释放越好,就不能将这个任务留给析构函数,因为无法保证它会何时执行,这时应该采用标准dispose模式

标准dispose模式使用规则

(1)包含非托管资源的类应该实现IDisposable接口,该接口包含单一方法Dispose,Dispose包含释放资源的清除代码。
(2)如果代码使用完了这些资源并且希望将它们释放,应该在程序代码中调用Dispose方法,注意这是在你的代码中(不是系统中)调用Dispose。
(3)你的类还应该实现一个析构函数,在其中调用Dispose方法,以防止之前没有调用该方法。但是如果调用了Dispose,就需要通知垃圾回收器不要再调用析构函数,因为已经由Dispose执行了清除操作。

析构函数和Disposed代码应遵守的规则

(1)俩者的逻辑应该是,如果由于某种原因代码没有调用Dispose,那么析构函数应该调用它,并释放资源
(2)在public版本的Dispose方法的最后应该调用GC.SuppressFinalize方法通知CLR不要调用该对象的析构函数,因为清除工作已经完成。
(3)在Dispose中实现的这些代码,经过多次调用也应该是安全的,也就是说这个方法已经被调用过一次后,后续的调用不会执行额外的工作,也不会抛出任何异常。
(4)Dispose方法有俩个重载,一个是public的,一个是protected的,protected的重载包含实际的清除代码
(5)public版本可以在代码中显式调用来执行清除工作,它会在内部调用protected版本
(6)析构函数调用的是protected版本
(7)protected版本的bool参数通知方法是被析构函数或是其他代码调用,这一点很重要,因为结果不同所执行的操作会略有不同。

析构函数与构造函数

这篇关于析构函数、dispose模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/351094

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

迭代器模式iterator

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/iterator 不暴露集合底层表现形式 (列表、 栈和树等) 的情况下遍历集合中所有的元素

《x86汇编语言:从实模式到保护模式》视频来了

《x86汇编语言:从实模式到保护模式》视频来了 很多朋友留言,说我的专栏《x86汇编语言:从实模式到保护模式》写得很详细,还有的朋友希望我能写得更细,最好是覆盖全书的所有章节。 毕竟我不是作者,只有作者的解读才是最权威的。 当初我学习这本书的时候,只能靠自己摸索,网上搜不到什么好资源。 如果你正在学这本书或者汇编语言,那你有福气了。 本书作者李忠老师,以此书为蓝本,录制了全套视频。 试

利用命令模式构建高效的手游后端架构

在现代手游开发中,后端架构的设计对于支持高并发、快速迭代和复杂游戏逻辑至关重要。命令模式作为一种行为设计模式,可以有效地解耦请求的发起者与接收者,提升系统的可维护性和扩展性。本文将深入探讨如何利用命令模式构建一个强大且灵活的手游后端架构。 1. 命令模式的概念与优势 命令模式通过将请求封装为对象,使得请求的发起者和接收者之间的耦合度降低。这种模式的主要优势包括: 解耦请求发起者与处理者

利用matlab bar函数绘制较为复杂的柱状图,并在图中进行适当标注

示例代码和结果如下:小疑问:如何自动选择合适的坐标位置对柱状图的数值大小进行标注?😂 clear; close all;x = 1:3;aa=[28.6321521955954 26.2453660695847 21.69102348512086.93747104431360 6.25442246899816 3.342835958564245.51365061796319 4.87