自动实现的属性是否支持属性?

发布于 2024-07-12 09:12:33 字数 185 浏览 12 评论 0原文

有人告诉我,在 C# 中,自动实现的属性不允许使用属性。 真的吗? 如果是这样为什么?

编辑:我从一本关于 LINQ 的流行书中得到了这些信息,简直不敢相信! 编辑:请参阅 Paul Kimmel 的 LINQ Unleashed 第 34 页,其中他说“自动实现的属性上不允许使用属性,因此如果需要属性,请自行创建属性”

I was told that in c# attributes are not allowed on the auto-implemented properties. Is that true? if so why?

EDIT: I got this information from a popular book on LINQ and could not believe it!
EDIT: Refer page 34 of LINQ Unleashed by Paul Kimmel where he says "Attributes are not allowed on auto-implemented properties, so roll your own if you need an attribute"

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(5

π浅易 2024-07-19 09:12:33

您可以毫无问题地将属性应用于自动属性。

引用自 MSDN

允许使用属性
自动实现的属性但是
显然不在支持领域
因为这些无法从
你的源代码。 如果您必须使用
a 的支持字段上的属性
属性,只需创建一个常规的
属性。

You can apply attributes to automatic properties without a problem.

Quote from MSDN:

Attributes are permitted on
auto-implemented properties but
obviously not on the backing fields
since those are not accessible from
your source code. If you must use an
attribute on the backing field of a
property, just create a regular
property.

八巷 2024-07-19 09:12:33

证明这是错误的最简单方法就是测试它:

using System;
using System.ComponentModel;
using System.Reflection;

class Test
{
    [Description("Auto-implemented property")]
    public static string Foo { get; set; }  

    static void Main(string[] args)
    {
        var property = typeof(Test).GetProperty("Foo");
        var attributes = property.GetCustomAttributes
                (typeof(DescriptionAttribute), false);

        foreach (DescriptionAttribute description in attributes)
        {
            Console.WriteLine(description.Description);
        }
    }
}

我建议您向作者发送电子邮件,以便他可以将其作为勘误表发布。 如果他的意思是您不能将属性应用于字段,这将使他有机会更仔细地解释。

The easiest way to prove that's wrong is to just test it:

using System;
using System.ComponentModel;
using System.Reflection;

class Test
{
    [Description("Auto-implemented property")]
    public static string Foo { get; set; }  

    static void Main(string[] args)
    {
        var property = typeof(Test).GetProperty("Foo");
        var attributes = property.GetCustomAttributes
                (typeof(DescriptionAttribute), false);

        foreach (DescriptionAttribute description in attributes)
        {
            Console.WriteLine(description.Description);
        }
    }
}

I suggest you email the author so he can publish it as an erratum. If he meant that you can't apply an attribute to the field, this will give him a chance to explain more carefully.

时常饿 2024-07-19 09:12:33

我认为作者的意思是,您不能将自定义属性应用于私有支持字段。
例如,如果要将自动属性标记为非序列化,则不能这样做:

[Serializable]
public class MyClass
{
    [field:NonSerializedAttribute()]
    public int Id
    {
        get;
        private set;
    }
}

此代码可以编译,但不起作用。
可以将属性应用于属性本身,但不能将其应用于支持字段。

I think that author meant, that you can't apply custom attributes to private backing field.
For example, if you want to mark automatic property as non serialized, you can't do this:

[Serializable]
public class MyClass
{
    [field:NonSerializedAttribute()]
    public int Id
    {
        get;
        private set;
    }
}

This code compiles, but it doesn’t work.
You can apply attribute to property itself, but you can't apply it for backing field.

遥远的她 2024-07-19 09:12:33

另请注意,任何“自动”属性也将应用 CompilerGenerateAttribute。

Note also that any Automatic property will have the CompilerGeneratedAttribute applied to it as well.

三生殊途 2024-07-19 09:12:33

当前版本的 Visual Studio 和 C# 编译器支持此功能。 我使用启用了 C# 8.0 的 VS 16.4.2 进行了测试。 我不知道它是在哪个版本中启用的,但这是个好消息。

语法:

[field: NonSerialized]
public SomeNonSerializableType MyAutoProperty { get; set; } = DefaultValueAfterSerialization;

实际用例; 支持整洁/可往返的合格 XML 序列化,无需混乱的支持字段,但避免运行时异常并解决代码分析错误 CA2235:

/// <summary>
/// XML name table for serialization.
/// </summary
[XmlSerializerNamespaces]
[field: NonSerialized]
public XmlSerializerNamespaces XmlNamespaces { get; set; } = new XmlSerializerNamespaces();

如果您正在使用 .NET Core 3、.NET Standard 开发新的“SDK”样式项目之一2.1 或更高版本它将立即工作,因为它们默认为语言版本 8。否则,对于所有“旧版”.NET Framework 和非 SDK 项目,您必须将“LangVersion”设置添加到您的项目 如此处记录至“ 8.0”或“最新”。

The current version of Visual Studio and C# compilers support this. I tested with VS 16.4.2 with C# 8.0 enabled. I don't know exactly which version it was enabled in but it's good news.

Syntax:

[field: NonSerialized]
public SomeNonSerializableType MyAutoProperty { get; set; } = DefaultValueAfterSerialization;

Practical use case; support neat/round-trip-able qualified XML serialization without messy backing fields but avoid runtime exceptions and resolve code analysis error CA2235:

/// <summary>
/// XML name table for serialization.
/// </summary
[XmlSerializerNamespaces]
[field: NonSerialized]
public XmlSerializerNamespaces XmlNamespaces { get; set; } = new XmlSerializerNamespaces();

If you're working on one of the new "SDK" style projects with .NET Core 3, .NET Standard 2.1 or later it will work immediately as they default to language version 8. Otherwise for all "legacy" .NET Framework and non-SDK projects you'll have to add the "LangVersion" setting to your project as documented here to "8.0" or "latest".

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文