1.前言
CLR和GC高度耦合,.Net7里面分离CLR和GC,则比较容易实现这件事情。本篇来看下,自定义一个GC垃圾回收器。
2.概述
这里首先演示下自定义GC垃圾回收后的效果。
1.下载Custom.dll
2.找到当前.Net目录,比如这里的7.0.10
C:Program FilesdotnetsharedMicrosoft.NETCore.App服务器托管网7.0.10
把Custom.dll复制到此目录
3.比如有以下C#代码:
static void Main(string[] args){
Console.WriteLine("Hello Main");
Program pm = new 服务器托管网Program();
pm = null;
GC.Collect();
}
在项目属性-》调试-》常规-》打开调试启动配置文件UI-》环境变量里面填写如下键值:
名称:DOTNET_GCName
值:Custom.dll
4.运行此段代码,显示如下
hello Jianghupt这三条语句就是Custom.dll里面自定义了GC的标识效果。表示它是自定义的。
5.原理
CLR在初始化的时候,会判断是否有DOTNET_GCName环境变量,如果有则替换掉默认的GC回收器,用DOTNET_GCName指定的GC回收器。这里很明显的就是进入了自定义垃圾回收器里面去了。如果取消掉DOTNET_GCName环境变量,则不会有这三句话。可以自己去尝试下。
如何自定义GC垃圾回收呢?
自定义GC垃圾回收器,需要进行如下操作。新建一个C++ DLL库项目
引入两个头文件,实现三个接口
#include "gcenv.base.h"
#include "gcinterface.h"
IGCHandleManager
IGCHandleStore
IGCHeap
需要导出两个函数
extern "C" DLLEXPORT HRESULT
GC_Initialize(
/* In */ IGCToCLR* clrToGC,
/* Out */ IGCHeap** gcHeap,
/* Out */ IGCHandleManager** gcHandleManager,
/* Out */ GcDacVars* gcDacVars
)
{
printf("Hello Jianghupt! This Is Custom GC Into CLR!!!!!!!!!rn");
printf("Hello Jianghupt! Welcom To Customer GC CLR!!!!!!!!!rn");
printf("Hello Jianghupt! Microsfot The GC Update Customer!!!!!!!!!rn");
IGCHeap* heap = new CustomGCHeap(clrToGC);
IGCHandleManager* handleManager = new CustomGCHandleManager();
*gcHeap = heap;
*gcHandleManager = handleManager;
return S_OK;
}
extern "C" DLLEXPORT void
GC_VersionInfo(
/* Out */ VersionInfo* result
)
{
result->MajorVersion = GC_INTERFACE_MAJOR_VERSION;
result->MinorVersion = GC_INTERFACE_MINOR_VERSION;
result->BuildVersion = 0;
result->Name = "Custom";
}
可以看到GC_Initialize里面的三句话,就是上面控制台显示的三句话。这个时候它实际上已经进入到了自定义GC里面去了。
源码下载
有任何问题,可以关注公众号(jianghupt),了解更多。
服务器托管,北京服务器托管,服务器租用 http://www.fwqtg.net
机房租用,北京机房租用,IDC机房托管, http://www.fwqtg.net
相关推荐: 【Jetpack-Navigation】想去哪就去哪,Android世界的指南针
前言 androidx Navigation 组件是 Android 中应用内导航的官方库 很多人不喜欢 Navigation 因为其设计不符合开发者的预期,它在管理「平级界面」时来回切换会导致平级的 fragment 重建。网上针对这一问题有一个 重写 Na…