In many applications, a set of types (Type) or type members (derived from MemberInfo) are bound and these objects are stored in some form of collection. Later, this collection is searched for a specific object and then called. This is a nice mechanism, but there is a small problem: objects derived from Type and MemberInfo require a lot of memory. If an application contains too many such classes but uses them only occasionally, the application's memory will grow rapidly, affecting the application's performance.
Internally, the CLR represents this information in a more streamlined form. The CLR creates these objects for applications simply to make the developer's life easier. The CLR does not need these large objects at runtime. If a large number of Type and MemberInfo derived objects need to be cached, developers can use runtime handles instead of objects to reduce the working set (memory occupied). FCL defines three runtime handle types (all in the System namespace), RuntimeTypeHandle, RuntimeFieldHandle, and RumtimeMethodHandle. All three types are value types, and they only contain one field, which is an IntPtr; thus, instances of these types are quite memory-saving. The ItPtr field is a handle that references a type, field, or method in the AppDomain's Loader heap. Conversion method:
Type→RuntimeTypeHandle, by querying the read-only field attribute TypeHandle of Type.
RuntimeTypeHandle→Type, by calling the static method GetTypeFromHanlde of Type.
FieldInfo→RuntimeFieldHandle, by querying the read-only field FieldHandle of the FieldInfo instance.
RuntimeFieldHandle→FieldInfo, by calling the static method GetFieldFromHandle of FieldInfo.
MethodInfo→RuntimeMethodHandle, by querying the instance read-only field MethodHandle of MethodInof.
RuntimeMethodHandle→MethodInfo, by calling the static method GetMethodFromHandle of MethodInfo.
The following example obtains many MethodInfo objects, converts them into RuntimeMethodHandle instances, and demonstrates the memory difference before and after conversion.
private void UseRuntimeHandleToReduceMemory() { Show("Before doing anything");//从MSCorlib.dll中地所有方法构建methodInfos 对象缓存 List<MethodBase> methodInfos = new List<MethodBase>(); foreach (Type t in typeof(object).Assembly.GetExportedTypes()) { if (t.IsGenericType) continue; MethodBase[] mbs = t.GetMethods(c_bf); methodInfos.AddRange(mbs); } //显示当绑定所有方法之后,方法的个数和堆的大小 Console.WriteLine("# of Methods={0:###,###}", methodInfos.Count); Show("After building cache of MethodInfo objects");//为所有MethodInfo对象构建RuntimeMethodHandle缓存 List<RuntimeMethodHandle> methodHandles = new List<RuntimeMethodHandle>(); methodHandles = methodInfos.ConvertAll<RuntimeMethodHandle>(m => m.MethodHandle); Show("Holding MethodInfo and RuntimeMethodHandle"); GC.KeepAlive(methodHandles);//阻止缓存被过早垃圾回收 methodInfos = null;//现在允许缓存垃圾回收 Show("After freeing MethodInfo objects"); methodInfos = methodHandles.ConvertAll<MethodBase>(r => MethodBase.GetMethodFromHandle(r)); Show("Size of heap after re-creating methodinfo objects"); GC.KeepAlive(methodHandles);//阻止缓存被过早垃圾回收 GC.KeepAlive(methodInfos);//阻止缓存被过早垃圾回收 methodInfos = null;//现在允许缓存垃圾回收 methodHandles = null;//现在允许缓存垃圾回收 Show("after freeing MethodInfo and MethodHandle objects"); }
The results are as follows:
Heap Size = 114,788 - Before doing anything # of Methods=10,003Heap Size = 2,205,652 - After building cache of MethodInfo objects Heap Size = 2,245,744 - Holding MethodInfo and RuntimeMethodHandle Heap Size = 2,171,976 - After freeing MethodInfo objects Heap Size = 2,327,516 - Size of heap after re-creating methodinfo objects Heap Size = 247,028 - after freeing MethodInfo and MethodHandle objects
This article is compiled from "NET CLR via C#"
Author: jiankunking Source: http://www.php.cn/
In many applications, a set of types (Type) or type members (derived from MemberInfo) are bound and these objects are stored in some form of collection. Later, this collection is searched for a specific object and then called on that object. This is a nice mechanism, but there is a small problem: Type and MemberInfo-derived objects require a lot of memory. If an application contains too many such classes but uses them only occasionally, the application's memory will grow rapidly, affecting the application's performance.
Internally, the CLR represents this information in a more streamlined form. The CLR creates these objects for applications simply to make the developer's life easier. The CLR does not need these large objects at runtime. If a large number of Type and MemberInfo derived objects need to be cached, developers can use runtime handles instead of objects to reduce the working set (memory occupied). FCL defines three runtime handle types (all in the System namespace), RuntimeTypeHandle, RuntimeFieldHandle, and RumtimeMethodHandle. All three types are value types, and they only contain one field, which is an IntPtr; thus, instances of these types are quite memory-saving. The ItPtr field is a handle that references a type, field, or method in the AppDomain's Loader heap. Conversion method:
Type→RuntimeTypeHandle, by querying the read-only field attribute TypeHandle of Type.
RuntimeTypeHandle→Type, by calling the static method GetTypeFromHanlde of Type.
FieldInfo→RuntimeFieldHandle, by querying the read-only field FieldHandle of the FieldInfo instance.
RuntimeFieldHandle→FieldInfo, by calling the static method GetFieldFromHandle of FieldInfo.
MethodInfo→RuntimeMethodHandle, by querying the instance read-only field MethodHandle of MethodInof.
RuntimeMethodHandle→MethodInfo, by calling the static method GetMethodFromHandle of MethodInfo.
The following example obtains many MethodInfo objects, converts them into RuntimeMethodHandle instances, and demonstrates the memory difference before and after conversion.
private void UseRuntimeHandleToReduceMemory() { Show("Before doing anything");//从MSCorlib.dll中地所有方法构建methodInfos 对象缓存 List<MethodBase> methodInfos = new List<MethodBase>(); foreach (Type t in typeof(object).Assembly.GetExportedTypes()) { if (t.IsGenericType) continue; MethodBase[] mbs = t.GetMethods(c_bf); methodInfos.AddRange(mbs); } //显示当绑定所有方法之后,方法的个数和堆的大小 Console.WriteLine("# of Methods={0:###,###}", methodInfos.Count); Show("After building cache of MethodInfo objects");//为所有MethodInfo对象构建RuntimeMethodHandle缓存 List<RuntimeMethodHandle> methodHandles = new List<RuntimeMethodHandle>(); methodHandles = methodInfos.ConvertAll<RuntimeMethodHandle>(m => m.MethodHandle); Show("Holding MethodInfo and RuntimeMethodHandle"); GC.KeepAlive(methodHandles);//阻止缓存被过早垃圾回收 methodInfos = null;//现在允许缓存垃圾回收 Show("After freeing MethodInfo objects"); methodInfos = methodHandles.ConvertAll<MethodBase>(r => MethodBase.GetMethodFromHandle(r)); Show("Size of heap after re-creating methodinfo objects"); GC.KeepAlive(methodHandles);//阻止缓存被过早垃圾回收 GC.KeepAlive(methodInfos);//阻止缓存被过早垃圾回收 methodInfos = null;//现在允许缓存垃圾回收 methodHandles = null;//现在允许缓存垃圾回收 Show("after freeing MethodInfo and MethodHandle objects"); }
The results are as follows:
Heap Size = 114,788 - Before doing anything # of Methods=10,003Heap Size = 2,205,652 - After building cache of MethodInfo objects Heap Size = 2,245,744 - Holding MethodInfo and RuntimeMethodHandle Heap Size = 2,171,976 - After freeing MethodInfo objects Heap Size = 2,327,516 - Size of heap after re-creating methodinfo objects Heap Size = 247,028 - after freeing MethodInfo and MethodHandle objects
The above is the content of C# using binding handles to reduce the memory consumption of the process. For more related content, please pay attention to the PHP Chinese website (www.php.cn) !

C# and .NET provide powerful features and an efficient development environment. 1) C# is a modern, object-oriented programming language that combines the power of C and the simplicity of Java. 2) The .NET framework is a platform for building and running applications, supporting multiple programming languages. 3) Classes and objects in C# are the core of object-oriented programming. Classes define data and behaviors, and objects are instances of classes. 4) The garbage collection mechanism of .NET automatically manages memory to simplify the work of developers. 5) C# and .NET provide powerful file operation functions, supporting synchronous and asynchronous programming. 6) Common errors can be solved through debugger, logging and exception handling. 7) Performance optimization and best practices include using StringBuild

.NETFramework is a cross-language, cross-platform development platform that provides a consistent programming model and a powerful runtime environment. 1) It consists of CLR and FCL, which manages memory and threads, and FCL provides pre-built functions. 2) Examples of usage include reading files and LINQ queries. 3) Common errors involve unhandled exceptions and memory leaks, and need to be resolved using debugging tools. 4) Performance optimization can be achieved through asynchronous programming and caching, and maintaining code readability and maintainability is the key.

Reasons for C#.NET to remain lasting attractive include its excellent performance, rich ecosystem, strong community support and cross-platform development capabilities. 1) Excellent performance and is suitable for enterprise-level application and game development; 2) The .NET framework provides a wide range of class libraries and tools to support a variety of development fields; 3) It has an active developer community and rich learning resources; 4) .NETCore realizes cross-platform development and expands application scenarios.

Design patterns in C#.NET include Singleton patterns and dependency injection. 1.Singleton mode ensures that there is only one instance of the class, which is suitable for scenarios where global access points are required, but attention should be paid to thread safety and abuse issues. 2. Dependency injection improves code flexibility and testability by injecting dependencies. It is often used for constructor injection, but it is necessary to avoid excessive use to increase complexity.

C#.NET is widely used in the modern world in the fields of game development, financial services, the Internet of Things and cloud computing. 1) In game development, use C# to program through the Unity engine. 2) In the field of financial services, C#.NET is used to develop high-performance trading systems and data analysis tools. 3) In terms of IoT and cloud computing, C#.NET provides support through Azure services to develop device control logic and data processing.

.NETFrameworkisWindows-centric,while.NETCore/5/6supportscross-platformdevelopment.1).NETFramework,since2002,isidealforWindowsapplicationsbutlimitedincross-platformcapabilities.2).NETCore,from2016,anditsevolutions(.NET5/6)offerbetterperformance,cross-

The C#.NET developer community provides rich resources and support, including: 1. Microsoft's official documents, 2. Community forums such as StackOverflow and Reddit, and 3. Open source projects on GitHub. These resources help developers improve their programming skills from basic learning to advanced applications.

The advantages of C#.NET include: 1) Language features, such as asynchronous programming simplifies development; 2) Performance and reliability, improving efficiency through JIT compilation and garbage collection mechanisms; 3) Cross-platform support, .NETCore expands application scenarios; 4) A wide range of practical applications, with outstanding performance from the Web to desktop and game development.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

mPDF
mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

SublimeText3 Chinese version
Chinese version, very easy to use

WebStorm Mac version
Useful JavaScript development tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver Mac version
Visual web development tools
