c# – 受保护的内部成员的可访问性不一致
发布时间:2020-12-15 05:39:49 所属栏目:百科 来源:网络整理
导读:尝试在公共类中创建受保护的内部类的受保护内部成员会导致以下问题: Inconsistent accessibility: field type ‘what.Class1.ProtectedInternalClass’ is less accessible than field ‘what.Class1.SomeDataProvider.data’ 据我所知,可访问性应该是等效
尝试在公共类中创建受保护的内部类的受保护内部成员会导致以下问题:
据我所知,可访问性应该是等效的. 我哪里弄错了? 起源类: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace what { public class Class1 { // This class cannot be modified,is only // here to produce a complete example. public class PublicClass { public PublicClass() { } } protected internal class ProtectedInternalClass : PublicClass { public ProtectedInternalClass() { } public void SomeExtraFunction() { } } public class SomeDataProvider { public int AnInterestingValue; public int AnotherInterestingValue; protected internal ProtectedInternalClass data; //<--- Occurs here. public PublicClass Data { get { return data; } } } public static SomeDataProvider RetrieveProvider() { SomeDataProvider provider = new SomeDataProvider(); provider.data = new ProtectedInternalClass(); provider.data.SomeExtraFunction(); return provider; } } } 验证受保护和内部属性,相同的程序集: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace what { public class Class2 : Class1 { public Class2() { var pi = new ProtectedInternalClass(); var provider = new SomeDataProvider(); provider.data = pi; } // no errors here } public class Class3 { public Class3() { var pi = new Class1.ProtectedInternalClass(); var provider = new Class1.SomeDataProvider(); provider.data = pi; } // no errors here } } 验证受保护和内部属性,不同的程序集: using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace some_other_assembly { public class Class4 : what.Class1 { public Class4() { var pi = new ProtectedInternalClass(); var provider = new SomeDataProvider(); provider.data = pi; } // no errors here } public class Class5 { public Class5() { var pi = new what.Class1.ProtectedInternalClass(); // <--- Inaccessible due to protection level,as it should be. var provider = new what.Class1.SomeDataProvider(); provider.data = pi; // <--- Intellisense implies inaccessible,but not indicated via error. } } } 解决方法
受保护适用于不同的类,这可以看作
class Derived : what.Class1.SomeDataProvider // note: Derived is not a nested class { public void f() { var data = this.data; } } 在一个不同的集会. 必须可以访问this.data,因为该类派生自SomeDataProvider.它的类型ProtectedInternalClass是不可访问的,因为该类不是从Class1派生的. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |