Net Reflection Attributes Performans İyileştirme Stratejileri

2023-05-05

Bu makalede, Reflection kullanarak özel niteliklere (attributes) erişim ve performansı artırmak için kullanılabilecek stratejilere odaklanacağız.

Özel Niteliklerle (Attributes) Çalışma

Özel nitelikler, türler, üyeler ve diğer kod öğelerine meta veri eklemek için kullanılır. Özel nitelikler, çalışma zamanında Reflection kullanarak sorgulanabilir ve analiz edilebilir.

  1. Özel Nitelikleri Tanımlama Öncelikle, ‘System.Attribute’ sınıfından türetilmiş bir özel nitelik sınıfı tanımlayın.
public class MyCustomAttribute : Attribute
{
    public string Description { get; set; }
    public MyCustomAttribute(string description)
    {
        Description = description;
    }
}
  1. Özel Nitelikleri Kullanma Türler, metotlar, özellikler ve alanlara özel nitelikleri ekleyin.
[MyCustom("This is a custom attribute.")]
public class MyClass
{
    [MyCustom("This is another custom attribute.")]
    public void MyMethod() { }
}
  1. Özel Nitelikleri Elde Etme Reflection kullanarak, belirli bir tür veya üyeden özel nitelikleri elde edin.
Type myType = typeof(MyClass);
MyCustomAttribute attribute = (MyCustomAttribute)Attribute.GetCustomAttribute(myType, typeof(MyCustomAttribute));

Performans İyileştirme Stratejileri

  1. Reflection Kullanımını Azaltma Performansı artırmak için, Reflection işlemlerini sadece gerçekten gerekli olduğu durumlarda kullanın. Statik türler ve üyeler kullanarak işlemlerinizi gerçekleştirmeye özen gösterin.

  2. Önbellekleme (Caching) Reflection işlemleri sırasında elde edilen tür, üye ve özel nitelik bilgilerini önbellekte saklayarak işlem süresini azaltabilirsiniz. İşlemlerinizi tekrarlamadan önce önbelleği kontrol edin.

  3. Expression Trees Kullanma İşlem süresini azaltmak için, çalışma zamanında derlenen ve daha hızlı çalışan Expression Trees kullanarak metotları çağırmayı düşünün.

using System.Linq.Expressions;
// ...
MethodInfo methodInfo = typeof(MyClass).GetMethod("MyMethod");
ParameterExpression instance = Expression.Parameter(typeof(MyClass), "instance");
MethodCallExpression callExpression = Expression.Call(instance, methodInfo);
Expression<Action<MyClass>> lambda = Expression.Lambda<Action<MyClass>>(callExpression, instance);
Action<MyClass> action = lambda.Compile();
MyClass myInstance = new MyClass();
action(myInstance);
  1. DynamicMethod ve ILGenerator Kullanma İleri düzey kullanıcılar için, DynamicMethod sınıfı ve ILGenerator kullanarak doğrudan Intermediate Language (IL) kodu yazabilir ve çalıştırabilirsiniz. Bu yöntem, çalışma zamanında daha hızlı işlemler gerçekleştirmenize olanak sağlar, ancak daha karmaşık ve hata yapmaya açıktır.
using System.Reflection.Emit;
// ...

Type myType = typeof(MyClass);
MethodInfo methodInfo = myType.GetMethod("MyMethod");
DynamicMethod dynamicMethod = new DynamicMethod("MyDynamicMethod", typeof(void), new Type[] { myType }, myType);
ILGenerator ilGenerator = dynamicMethod.GetILGenerator();
ilGenerator.Emit(OpCodes.Ldarg_0); // Load the first argument (instance of MyClass)
ilGenerator.Emit(OpCodes.Call, methodInfo); // Call the method
ilGenerator.Emit(OpCodes.Ret); // Return
Action<MyClass> action = (Action<MyClass>)dynamicMethod.CreateDelegate(typeof(Action<MyClass>));
MyClass myInstance = new MyClass();
action(myInstance);

Sonuç olarak, Reflection, .NET uygulamalarında çalışma zamanında kod meta verilerine erişmek ve yönetmek için güçlü ve esnek bir araçtır. Performansı ve güvenliği optimize etmek için en uygun yöntemleri ve stratejileri kullanarak, Reflection ile etkili ve verimli uygulamalar geliştirebilirsiniz.



Bu gibi daha fazla gönderi...

SemaphoreSlim Sınıfı: C#'ta Çoklu Görevlere Dayalı Programlama

2023-06-10 | #net #semaphoreslim

Genel Bakış SemaphoreSlim sınıfı, bir veya daha fazla threadin aynı anda belirli bir kaynağı veya işlemi kullanmasını kontrol etmek için C# ‘ta kullanılan bir yapıdır. SemaphoreSlim, aynı anda kaynağa erişebilecek thread sayısını sınırlar. SemaphoreSlim kullanımı, genellikle çok threadli uygulamalarda deadlock durumlarını önlemek ve belirli bir kaynağın aynı anda yalnızca bir veya daha fazla thread tarafından kullanılmasını sağlamak için kullanılır. SemaphoreSlim Kullanımı SemaphoreSlim sınıfı, aşağıdaki gibi kullanılır: SemaphoreSlim semaphoreSlim = new SemaphoreSlim(1, 1); Burada ilk parametre, aynı anda kaç threadin kaynağı kullanabileceğini belirler.

Devamı 


Basit Bir Rest Api Client Geliştirelim 9

2023-05-14 | #diy-rest-api-client #do-it-yourself #net #rest-api

HTTP isteklerini izlemek ve teşhis etmek için daha fazla yetenek ekleyerek, kütüphanemizi daha da geliştirebiliriz. Bu amaçla, isteklerin ve yanıtların bazı temel bilgilerini loga kaydeden bir middleware ekleyelim. Bu özellik, HTTP isteklerinin ve yanıtlarının kaydını tutmak için HttpClient‘in DelegatingHandler sınıfını kullanır. Bu, bir HTTP isteği gönderildiğinde ve bir yanıt alındığında çalışan bir kod parçasıdır. Bu durumda, HTTP isteklerinin ve yanıtlarının bazı temel bilgilerini loga kaydeder. Aşağıda, bu özelliği eklemek için gereken kod parçacığı bulunmaktadır:

Devamı 


Basit Bir Rest Api Client Geliştirelim 8

2023-05-12 | #diy-rest-api-client #do-it-yourself #net #rest-api

Bu noktada, geliştirmemiz gereken bir diğer önemli konu da güvenlikle ilgili olabilir. Özellikle, API çağrıları genellikle belirli bir kimlik doğrulama yöntemi gerektirir. Bunu sağlamak için, HTTP istemcimizi çok kullanılan iki kimlik doğrulama yöntemiyle, yani Basic Authentication ve Bearer (Token) Authentication ile uyumlu hale getirebiliriz. Bu amaçla, istemcimize iki yeni metot ekleyelim: public void SetBasicAuthentication(string username, string password) { var basicAuthValue = Convert.ToBase64String(Encoding.UTF8.GetBytes($"{username}:{password}")); SetDefaultHeader("Authorization", $"Basic {basicAuthValue}"); } public void SetBearerToken(string token) { SetDefaultHeader("Authorization", $"Bearer {token}"); } Bu metodlar, Authorization başlığını ayarlar, böylece her HTTP talebi kimlik doğrulama bilgilerini içerir.

Devamı 