ConditionalWeakTable<TKey,TValue>.CreateValueCallback Temsilci

Tanım

Bir nesneye anahtar/değer çiftinin parçası olarak eklenecek varsayılan olmayan bir değer oluşturan yöntemi ConditionalWeakTable<TKey,TValue> temsil eder.

C#
public delegate TValue ConditionalWeakTable<TKey,TValue>.CreateValueCallback(TKey key) where TKey : class where TValue : class;

Parametreler

key
TKey

Oluşturulacak değere ait anahtar.

Dönüş Değeri

TValue

Belirtilen anahtara eklenecek değeri temsil eden bir başvuru türünün örneği.

Örnekler

Aşağıdaki örnek bir MainClass sınıfı ve sınıfı MainInfo tanımlar. MainInfo örnek hakkında MainClass bilgi sağlar. Ayrıca, temsilciye atanabilen ve yöntemine ConditionalWeakTable<TKey,TValue>.CreateValueCallback geçirilebilen GetValue bir statik (SharedVisual Basic'te) CreateAttachedValue yöntemi tanımlar. Örnek, tabloya bir MainClass nesnesi ve buna karşılık gelen MainInfo nesnesini eklemek için ConditionalWeakTable<TKey,TValue> yöntemini çağırırGetValue. Örnek ayrıca tabloya Add anahtar/değer çiftleri eklemek için ve GetOrCreateValue yöntemlerine yapılan çağrıları ve var olan bir anahtara ait değeri almak için yöntemine yapılan çağrıyı TryGetValue gösterir.

C#
using System;
using System.Reflection;
using System.Runtime.CompilerServices;

public class Example
{
   string Name; 
   
   public Example(string name)
   {
      this.Name = name;
   }
   
   public override string ToString()
   {
      return this.Name;
   }
}

// Define a class to contain information about each Example instance.
public class ExampleInfo
{
   public string Name;
   public int Methods;
   public int Properties;
   
   public override string ToString()
   {
      return String.Format("{0}: {1} Methods, {2} Properties", 
                           this.Name, this.Methods, this.Properties);
   }
}

public class ExampleTest
{
   private static BindingFlags flags = BindingFlags.Public | BindingFlags.Instance;

   public static void Main()
   {
      Example ex1 = new Example("ex1");
      Example ex2 = new Example("ex2");
      Example ex3 = new Example("ex3");
      
      ExampleInfo exInfo1 = new ExampleInfo(); 
      exInfo1.Name = ex1.ToString();
      exInfo1.Methods = ex1.GetType().GetMethods(flags).Length;
      exInfo1.Properties = ex1.GetType().GetProperties(flags).Length;
      
      ExampleInfo exInfo3 = new ExampleInfo(); 
      exInfo3.Name = ex3.ToString();
      exInfo3.Methods = ex3.GetType().GetMethods(flags).Length;
      exInfo3.Properties = ex3.GetType().GetProperties(flags).Length;

      var attached = new ConditionalWeakTable<Example, ExampleInfo>();
      ExampleInfo value = null;

      // Attach a property to ex1 using the Add method, then retrieve it.
      attached.Add(ex1, exInfo1);
      if (attached.TryGetValue(ex1, out value))
         Console.WriteLine("{0}, {1}", ex1, value);
      else
         Console.WriteLine("{0} does not have an attached property.", ex1);

      // Attempt to retrieve the value attached to ex2.
      value = attached.GetValue(ex2, ExampleTest.CreateAttachedValue);      
      if (attached.TryGetValue(ex2, out value))
         Console.WriteLine("{0}, {1}", ex2, value);
      else 
         Console.WriteLine("{0} does not have an attached property.", ex2);
      
      // Attempt to retrieve the value attached to ex3.
      value = attached.GetOrCreateValue(ex3);
      Console.WriteLine("{0}, {1}", ex3, value);
   }

   public static ExampleInfo CreateAttachedValue(Example ex)
   {
      ExampleInfo info = new ExampleInfo();
      info.Name = ex.ToString();
      info.Methods = ex.GetType().GetMethods(flags).Length;
      info.Properties = ex.GetType().GetProperties(flags).Length;
      return info;
   }
}
// The example displays the following output:
//       ex1, ex1: 4 Methods, 0 Properties
//       ex2, ex2: 4 Methods, 0 Properties
//       ex3, : 0 Methods, 0 Properties

Açıklamalar

Temsilci, ConditionalWeakTable<TKey,TValue>.CreateValueCallback yöntemine geçirilen anahtar nesnede ConditionalWeakTable<TKey,TValue> bulunamadığında yöntemi tarafından ConditionalWeakTable<TKey,TValue>.GetValue çağrılan bir geri çağırma yöntemini kapsüller. GetValue yöntemi, geri çağırma yöntemini, bir özellik değerinin dinamik olarak eklendiği yönetilen nesneyi temsil eden anahtarı geçirir. yöntemi, özellik değerini çağırana döndürmekten sorumludur ve bu da anahtar/değer çiftini tabloya ekler.

ConditionalWeakTable<TKey,TValue>.CreateValueCallback yöntemi, belirtilen anahtara eklenebilen bir başvuru türünün örneğini döndürmek için kullanılır. Bu örneğin varsayılan olmayan değerler kullanılarak başlatılmasını sağlar. Anahtar tabloda bulunmazsa, yöntemi değerin ConditionalWeakTable<TKey,TValue>.GetOrCreateValue varsayılan değerler kullanılarak başlatıldığı bir anahtar/değer çifti ekler.

Uzantı Metotları

GetMethodInfo(Delegate)

Belirtilen temsilci tarafından temsil edilen yöntemi temsil eden bir nesnesi alır.

Şunlara uygulanır

Ürün Sürümler
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

Ayrıca bkz.