दिलचस्प पोस्ट
लिंक स्क्रिप्ट के लिए jQuery के पाठ? सी # में पाठ के रूप में एक एक्सेल कॉलम (या सेल) को प्रारूपित करें? कैसे git में करने के बाद स्वचालित रूप से धक्का? सीएसएस में प्रमुख बिंदु बनाएं तिथि (डेटस्ट्रिंग) और नए दिनांक (डेटस्ट्रिंग) के बीच अंतर एंड्रॉइड: टॉगलबुटन्स के साथ रेडियोग्राम कैसे प्राप्त करें? किसी ने एक देशी iPhone ऐप के माध्यम से पेपैल एपीआई को लागू किया है? "मैत्रीपूर्ण" OS संस्करण नाम कैसे प्राप्त करें? सीएसएस: पृष्ठभूमि का रंग सेट करें जो खिड़की की चौड़ाई का 50% है मैं कैसे सत्यापित कर सकता हूं कि कोई Windows सेवा चल रही है या नहीं हेक्स मुद्रण करते समय प्रिंटफ़ केवल एक बाइट क्यों नहीं प्रिंट करता? CodeIgniter PHP फ़्रेमवर्क – क्वेरी स्ट्रिंग प्राप्त करने की आवश्यकता है गिट SSH प्रमाणीकरण "रेंज-आधारित लूपों" के साथ काम करने के लिए मेरा कस्टम प्रकार कैसे बना सकता है? Google मानचित्र API का "मेरा स्थान" बटन की स्थिति बदलें

क्या सी # वर्ग अपने इंटरफेस से गुण प्राप्त कर सकता है?

यह "नहीं" को प्रकट करने के लिए प्रकट होगा कौन सा दुर्भाग्यपूर्ण है

[AttributeUsage(AttributeTargets.Interface | AttributeTargets.Class, AllowMultiple = true, Inherited = true)] public class CustomDescriptionAttribute : Attribute { public string Description { get; private set; } public CustomDescriptionAttribute(string description) { Description = description; } } [CustomDescription("IProjectController")] public interface IProjectController { void Create(string projectName); } internal class ProjectController : IProjectController { public void Create(string projectName) { } } [TestFixture] public class CustomDescriptionAttributeTests { [Test] public void ProjectController_ShouldHaveCustomDescriptionAttribute() { Type type = typeof(ProjectController); object[] attributes = type.GetCustomAttributes( typeof(CustomDescriptionAttribute), true); // NUnit.Framework.AssertionException: Expected: 1 But was: 0 Assert.AreEqual(1, attributes.Length); } } 

क्या कोई वर्ग किसी इंटरफ़ेस से गुण प्राप्त कर सकता है? या मैं यहाँ गलत पेड़ को भौंक कर रहा हूँ?

वेब के समाधान से एकत्रित समाधान "क्या सी # वर्ग अपने इंटरफेस से गुण प्राप्त कर सकता है?"

नहीं। जब भी व्युत्पन्न वर्ग में इंटरफ़ेस या ओवरराइड सदस्यों को कार्यान्वित करते हैं, तो आपको गुणों को फिर से घोषित करना होगा।

यदि आप केवल घटक मॉोडेल (प्रत्यक्ष प्रतिबिंब नहीं) के बारे में ध्यान रखते हैं, तो एक मौजूदा प्रकार (दोहराव से बचने के लिए) के सुझावों का एक तरीका ( [AttributeProvider] ) है, लेकिन यह केवल संपत्ति और अनुक्रमणक उपयोग के लिए मान्य है।

उदहारण के लिए:

 using System; using System.ComponentModel; class Foo { [AttributeProvider(typeof(IListSource))] public object Bar { get; set; } static void Main() { var bar = TypeDescriptor.GetProperties(typeof(Foo))["Bar"]; foreach (Attribute attrib in bar.Attributes) { Console.WriteLine(attrib); } } } 

आउटपुट:

 System.SerializableAttribute System.ComponentModel.AttributeProviderAttribute System.ComponentModel.EditorAttribute System.Runtime.InteropServices.ComVisibleAttribute System.Runtime.InteropServices.ClassInterfaceAttribute System.ComponentModel.TypeConverterAttribute System.ComponentModel.MergablePropertyAttribute 

आप एक उपयोगी एक्सटेंशन विधि को परिभाषित कर सकते हैं …

 Type type = typeof(ProjectController); var attributes = type.GetCustomAttributes<CustomDescriptionAttribute>( true ); 

यहां एक्सटेंशन विधि है:

 /// <summary>Searches and returns attributes. The inheritance chain is not used to find the attributes.</summary> /// <typeparam name="T">The type of attribute to search for.</typeparam> /// <param name="type">The type which is searched for the attributes.</param> /// <returns>Returns all attributes.</returns> public static T[] GetCustomAttributes<T>( this Type type ) where T : Attribute { return GetCustomAttributes( type, typeof( T ), false ).Select( arg => (T)arg ).ToArray(); } /// <summary>Searches and returns attributes.</summary> /// <typeparam name="T">The type of attribute to search for.</typeparam> /// <param name="type">The type which is searched for the attributes.</param> /// <param name="inherit">Specifies whether to search this member's inheritance chain to find the attributes. Interfaces will be searched, too.</param> /// <returns>Returns all attributes.</returns> public static T[] GetCustomAttributes<T>( this Type type, bool inherit ) where T : Attribute { return GetCustomAttributes( type, typeof( T ), inherit ).Select( arg => (T)arg ).ToArray(); } /// <summary>Private helper for searching attributes.</summary> /// <param name="type">The type which is searched for the attribute.</param> /// <param name="attributeType">The type of attribute to search for.</param> /// <param name="inherit">Specifies whether to search this member's inheritance chain to find the attribute. Interfaces will be searched, too.</param> /// <returns>An array that contains all the custom attributes, or an array with zero elements if no attributes are defined.</returns> private static object[] GetCustomAttributes( Type type, Type attributeType, bool inherit ) { if( !inherit ) { return type.GetCustomAttributes( attributeType, false ); } var attributeCollection = new Collection<object>(); var baseType = type; do { baseType.GetCustomAttributes( attributeType, true ).Apply( attributeCollection.Add ); baseType = baseType.BaseType; } while( baseType != null ); foreach( var interfaceType in type.GetInterfaces() ) { GetCustomAttributes( interfaceType, attributeType, true ).Apply( attributeCollection.Add ); } var attributeArray = new object[attributeCollection.Count]; attributeCollection.CopyTo( attributeArray, 0 ); return attributeArray; } /// <summary>Applies a function to every element of the list.</summary> private static void Apply<T>( this IEnumerable<T> enumerable, Action<T> function ) { foreach( var item in enumerable ) { function.Invoke( item ); } } 

अद्यतन करें:

साइमनड द्वारा एक टिप्पणी में प्रस्तावित एक छोटा संस्करण है:

 private static IEnumerable<T> GetCustomAttributesIncludingBaseInterfaces<T>(this Type type) { var attributeType = typeof(T); return type.GetCustomAttributes(attributeType, true). Union(type.GetInterfaces(). SelectMany(interfaceType => interfaceType.GetCustomAttributes(attributeType, true))). Distinct().Cast<T>(); } 

इस बारे में ब्रैड विल्सन का एक लेख: इंटरफ़ेस गुण! = कक्षा गुण

संक्षेप में: कक्षाएं इंटरफेस से वंशानुगत नहीं होती हैं, वे उन्हें लागू करते हैं। इसका मतलब यह है कि विशेषताएं स्वतः कार्यान्वयन का हिस्सा नहीं हैं

यदि आपको गुणों का वारिस होना है, तो इंटरफ़ेस के बजाय एक सार बेस क्लास का उपयोग करें।

जबकि सी # वर्ग अपने इंटरफेस से गुणों का उत्तराधिकारी नहीं है, जबकि एएसपी.नेट एमवीसी 3 में बाध्यकारी मॉडलों के लिए एक उपयोगी विकल्प है।

यदि आप दृश्य के मॉडल को ठोस प्रकार के बजाय इंटरफ़ेस घोषित करते हैं, तो दृश्य और मॉडल बाइंडर विशेषताएँ (उदाहरण के लिए, [Required] या [DisplayName("Foo")] को प्रस्तुति और मान्य करते समय इंटरफ़ेस से लागू होंगे आदर्श:

 public interface IModel { [Required] [DisplayName("Foo Bar")] string FooBar { get; set; } } public class Model : IModel { public string FooBar { get; set; } } 

तो इस दृश्य में:

 @* Note use of interface type for the view model *@ @model IModel @* This control will receive the attributes from the interface *@ @Html.EditorFor(m => m.FooBar) 

यह उन लोगों के लिए अधिक है जो एक कार्यान्वित इंटरफ़ेस पर मौजूद गुणों से गुणों को निकालने की तलाश में हैं। क्योंकि उन विशेषताओं वर्ग का हिस्सा नहीं हैं, यह आपको उन तक पहुंच प्रदान करेगा। ध्यान दें, मेरे पास एक सरल कंटेनर वर्ग है जो आपको संपत्ति इन्फोकेशन तक पहुंच देता है – जैसा कि मैं इसके लिए आवश्यक हूं आप की जरूरत के अनुसार हैक करें यह मेरे लिए अच्छी तरह से काम किया

 public static class CustomAttributeExtractorExtensions { /// <summary> /// Extraction of property attributes as well as attributes on implemented interfaces. /// This will walk up recursive to collect any interface attribute as well as their parent interfaces. /// </summary> /// <typeparam name="TAttributeType"></typeparam> /// <param name="typeToReflect"></param> /// <returns></returns> public static List<PropertyAttributeContainer<TAttributeType>> GetPropertyAttributesFromType<TAttributeType>(this Type typeToReflect) where TAttributeType : Attribute { var list = new List<PropertyAttributeContainer<TAttributeType>>(); // Loop over the direct property members var properties = typeToReflect.GetProperties(); foreach (var propertyInfo in properties) { // Get the attributes as well as from the inherited classes (true) var attributes = propertyInfo.GetCustomAttributes<TAttributeType>(true).ToList(); if (!attributes.Any()) continue; list.AddRange(attributes.Select(attr => new PropertyAttributeContainer<TAttributeType>(attr, propertyInfo))); } // Look at the type interface declarations and extract from that type. var interfaces = typeToReflect.GetInterfaces(); foreach (var @interface in interfaces) { list.AddRange(@interface.GetPropertyAttributesFromType<TAttributeType>()); } return list; } /// <summary> /// Simple container for the Property and Attribute used. Handy if you want refrence to the original property. /// </summary> /// <typeparam name="TAttributeType"></typeparam> public class PropertyAttributeContainer<TAttributeType> { internal PropertyAttributeContainer(TAttributeType attribute, PropertyInfo property) { Property = property; Attribute = attribute; } public PropertyInfo Property { get; private set; } public TAttributeType Attribute { get; private set; } } }