PropertyInfo.SetValue 方法

定义

设置指定对象的属性值。

重载

SetValue(Object, Object)

设置指定对象的属性值。

SetValue(Object, Object, Object[])

用索引化属性的可选索引值设置指定对象的该属性值。

SetValue(Object, Object, BindingFlags, Binder, Object[], CultureInfo)

当在派生类中重写时,为具有指定绑定、索引和区域性特定信息的指定对象设置属性值。

SetValue(Object, Object)

Source:
PropertyInfo.cs
Source:
PropertyInfo.cs
Source:
PropertyInfo.cs

设置指定对象的属性值。

C#
public void SetValue (object obj, object value);
C#
public void SetValue (object? obj, object? value);

参数

obj
Object

将设置其属性值的对象。

value
Object

新的属性值。

例外

找不到该属性的 set 取值函数。

value 无法转换为 PropertyType 的类型。

obj 的类型与目标类型不匹配,或属性是实例属性,但 objnull

注意:在 适用于 Windows 应用商店应用的 .NET可移植类库中,请改为 catch Exception

试图非法访问类中的私有或受保护方法。

注意:在 适用于 Windows 应用商店应用的 .NET可移植类库中,改为捕获基类异常 MemberAccessException

设置属性值时出错。 InnerException 属性指示出错的原因。

示例

以下示例声明名为 的Example类,其中 Visual Basic) Shared 中具有一个 static (和一个实例属性。 该示例使用 SetValue(Object, Object) 方法更改原始属性值并显示原始值和最终值。

C#
using System;
using System.Reflection;

class Example
{
    private static int _staticProperty = 41;
    private int _instanceProperty = 42;

    // Declare a public static property.
    public static int StaticProperty
    {
        get { return _staticProperty; }
        set { _staticProperty = value; }
    }

    // Declare a public instance property.
    public int InstanceProperty
    {
        get { return _instanceProperty; }
        set { _instanceProperty = value; }
    }

    public static void Main()
    {
        Console.WriteLine("Initial value of static property: {0}",
            Example.StaticProperty);

        // Get a type object that represents the Example type.
        Type examType = typeof(Example);

        // Change the static property value.
        PropertyInfo piShared = examType.GetProperty("StaticProperty");
        piShared.SetValue(null, 76);

        Console.WriteLine("New value of static property: {0}",
                          Example.StaticProperty);

        // Create an instance of the Example class.
        Example exam = new Example();

        Console.WriteLine("\nInitial value of instance property: {0}",
                          exam.InstanceProperty);

        // Change the instance property value.
        PropertyInfo piInstance = examType.GetProperty("InstanceProperty");
        piInstance.SetValue(exam, 37);

        Console.WriteLine("New value of instance property: {0}",
                          exam.InstanceProperty);
    }
}
// The example displays the following output:
//       Initial value of static property: 41
//       New value of static property: 76
//
//       Initial value of instance property: 42
//       New value of instance property: 37

注解

SetValue(Object, Object) 载设置非索引属性的值。 若要确定是否为属性编制索引,请 GetIndexParameters 调用 方法。 如果生成的数组具有 0 个 (零个) 元素,则不会为属性编制索引。 若要设置索引属性的值,请 SetValue(Object, Object, Object[]) 调用 重载。

如果此 PropertyInfo 对象的属性类型是值类型且 valuenull,则 属性将设置为该类型的默认值。

这是一种方便的方法,它调用抽象SetValue(Object, Object, BindingFlags, Binder, Object[], CultureInfo)方法的运行时实现,为 BindingFlags 参数指定 BindingFlags.DefaultnullBinderObject[]null 指定 、为 指定 。CultureInfonull

若要使用 SetValue 方法,请首先获取表示 Type 类的 对象。 从 中 Type获取 PropertyInfo 对象。 从 对象调用 PropertyInfoSetValue 方法。

备注

从 .NET Framework 2.0 开始,如果调用方已使用 标志授予ReflectionPermissionReflectionPermissionFlag.RestrictedMemberAccess,并且非公共成员的授权集仅限于调用方授权集或其子集,则此方法可用于访问非公共成员。 (请参阅 Reflection.) 若要使用此功能,应用程序应面向 .NET Framework 3.5 或更高版本。

适用于

.NET 9 和其他版本
产品 版本
.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
.NET Framework 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.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

SetValue(Object, Object, Object[])

Source:
PropertyInfo.cs
Source:
PropertyInfo.cs
Source:
PropertyInfo.cs

用索引化属性的可选索引值设置指定对象的该属性值。

C#
public virtual void SetValue (object obj, object value, object[] index);
C#
public virtual void SetValue (object? obj, object? value, object?[]? index);

参数

obj
Object

将设置其属性值的对象。

value
Object

新的属性值。

index
Object[]

索引化属性的可选索引值。 对于非索引化属性,该值应为 null

实现

例外

index 数组不包含所需的参数类型。

找不到该属性的 set 取值函数。

value 无法转换为 PropertyType 的类型。

该对象与目标类型不匹配,或者某属性是实例属性但 objnull

注意:在 适用于 Windows 应用商店应用的 .NET可移植类库中,请改为 catch Exception

index 中的参数数量与索引属性采用的参数数量不匹配。

试图非法访问类中的私有或受保护方法。

注意:在 适用于 Windows 应用商店应用的 .NET可移植类库中,改为捕获基类异常 MemberAccessException

设置属性值时出错。 例如,为一个索引属性指定的索引值超出范围。 InnerException 属性指示出错的原因。

示例

以下示例定义名为 的 TestClass 类,该类具有名为 的 Caption读写属性。 它显示属性的 Caption 默认值,调用 SetValue 方法来更改属性值,并显示结果。

C#
using System;
using System.Reflection;

// Define a class with a property.
public class TestClass
{
    private string caption = "A Default caption";
    public string Caption
    {
        get { return caption; }
        set
        {
            if (caption != value)
            {
                caption = value;
            }
        }
    }
}

class TestPropertyInfo
{
    public static void Main()
    {
        TestClass t = new TestClass();

        // Get the type and PropertyInfo.
        Type myType = t.GetType();
        PropertyInfo pinfo = myType.GetProperty("Caption");

        // Display the property value, using the GetValue method.
        Console.WriteLine("\nGetValue: " + pinfo.GetValue(t, null));

        // Use the SetValue method to change the caption.
        pinfo.SetValue(t, "This caption has been changed.", null);

        //  Display the caption again.
        Console.WriteLine("GetValue: " + pinfo.GetValue(t, null));

        Console.WriteLine("\nPress the Enter key to continue.");
        Console.ReadLine();
    }
}

/*
This example produces the following output:

GetValue: A Default caption
GetValue: This caption has been changed

Press the Enter key to continue.
*/

请注意,由于 Caption 属性不是参数数组,因此参数 indexnull

以下示例声明一个名为 Example 的类,该类具有三个 static 属性:Visual Basic) 中 (Shared 属性、实例属性和索引实例属性。 该示例使用 SetValue 方法更改属性的默认值,并显示原始值和最终值。

用于搜索带反射的索引实例属性的名称因语言和应用于属性的属性而异。

  • 在 Visual Basic 中,属性名称始终用于搜索具有反射的属性。 可以使用 Default 关键字使属性成为默认的索引属性,在这种情况下,可以在访问属性时省略名称,如以下示例所示。 还可以使用属性名称。

  • 在 C# 中,索引实例属性是一个称为索引器的默认属性,在代码中访问属性时,永远不会使用该名称。 默认情况下,属性的名称为 Item,并且必须在搜索带反射的属性时使用该名称。 可以使用 IndexerNameAttribute 属性为索引器指定不同的名称。 在本示例中,该名称为 IndexedInstanceProperty

  • 在 C++ 中 default ,说明符可用于将索引属性设置为默认索引属性, (类索引器) 。 在这种情况下,属性的名称默认为 Item,并且必须在搜索带反射的属性时使用该名称,如以下示例所示。 可以使用 IndexerNameAttribute 特性在反射中为类索引器提供不同的名称,但不能使用该名称在代码中访问属性。 在代码和反射中使用其名称访问不是类索引器的索引属性。

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

class Example
{
    private static int _staticProperty = 41;
    public static int StaticProperty
    {
        get
        {
            return _staticProperty;
        }
        set
        {
            _staticProperty = value;
        }
    }

    private int _instanceProperty = 42;
    public int InstanceProperty
    {
        get
        {
            return _instanceProperty;
        }
        set
        {
            _instanceProperty = value;
        }
    }

    private Dictionary<int, string> _indexedInstanceProperty =
        new Dictionary<int, string>();
    // By default, the indexer is named Item, and that name must be used
    // to search for the property. In this example, the indexer is given
    // a different name by using the IndexerNameAttribute attribute.
    [IndexerNameAttribute("IndexedInstanceProperty")]
    public string this[int key]
    {
        get
        {
            string returnValue = null;
            if (_indexedInstanceProperty.TryGetValue(key, out returnValue))
            {
                return returnValue;
            }
            else
            {
                return null;
            }
        }
        set
        {
            if (value == null)
            {
                throw new ArgumentNullException("IndexedInstanceProperty value can be an empty string, but it cannot be null.");
            }
            else
            {
                if (_indexedInstanceProperty.ContainsKey(key))
                {
                    _indexedInstanceProperty[key] = value;
                }
                else
                {
                    _indexedInstanceProperty.Add(key, value);
                }
            }
        }
    }

    public static void Main()
    {
        Console.WriteLine("Initial value of class-level property: {0}",
            Example.StaticProperty);

        PropertyInfo piShared = typeof(Example).GetProperty("StaticProperty");
        piShared.SetValue(null, 76, null);

        Console.WriteLine("Final value of class-level property: {0}",
            Example.StaticProperty);

        Example exam = new Example();

        Console.WriteLine("\nInitial value of instance property: {0}",
            exam.InstanceProperty);

        PropertyInfo piInstance =
            typeof(Example).GetProperty("InstanceProperty");
        piInstance.SetValue(exam, 37, null);

        Console.WriteLine("Final value of instance property: {0}",
            exam.InstanceProperty);

        exam[17] = "String number 17";
        exam[46] = "String number 46";
        exam[9] = "String number 9";

        Console.WriteLine(
            "\nInitial value of indexed instance property(17): '{0}'",
            exam[17]);

        // By default, the indexer is named Item, and that name must be used
        // to search for the property. In this example, the indexer is given
        // a different name by using the IndexerNameAttribute attribute.
        PropertyInfo piIndexedInstance =
            typeof(Example).GetProperty("IndexedInstanceProperty");
        piIndexedInstance.SetValue(
            exam,
            "New value for string number 17",
            new object[] { (int) 17 });

        Console.WriteLine(
            "Final value of indexed instance property(17): '{0}'",
            exam[17]);
    }
}

/* This example produces the following output:

Initial value of class-level property: 41
Final value of class-level property: 76

Initial value of instance property: 42
Final value of instance property: 37

Initial value of indexed instance property(17): 'String number 17'
Final value of indexed instance property(17): 'New value for string number 17'
 */

注解

如果此 PropertyInfo 对象是值类型且 valuenull,则 属性将设置为该类型的默认值。

若要确定是否为属性编制索引,请使用 GetIndexParameters 方法。 如果生成的数组具有 0 个 (零个) 元素,则不会为属性编制索引。

这是一种方便的方法,它调用抽象SetValue(Object, Object, BindingFlags, Binder, Object[], CultureInfo)方法的运行时实现,为 BindingFlags 参数指定 BindingFlags.Defaultnull为 指定 null ,为 Binder指定 。CultureInfo

若要使用 SetValue 方法,请首先获取表示 Type 类的 对象。 Type从 中获取 PropertyInfo。 在 中 PropertyInfo,使用 SetValue 方法。

备注

从 .NET Framework 2.0 开始,如果调用方已使用 标志授予ReflectionPermissionReflectionPermissionFlag.RestrictedMemberAccess,并且非公共成员的授权集仅限于调用方授权集或其子集,则此方法可用于访问非公共成员。 (请参阅 Reflection.) 若要使用此功能,应用程序应面向 .NET Framework 3.5 或更高版本。

适用于

.NET 9 和其他版本
产品 版本
.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
.NET Framework 1.1, 2.0, 3.0, 3.5, 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.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 2.0, 2.1
UWP 10.0

SetValue(Object, Object, BindingFlags, Binder, Object[], CultureInfo)

Source:
PropertyInfo.cs
Source:
PropertyInfo.cs
Source:
PropertyInfo.cs

当在派生类中重写时,为具有指定绑定、索引和区域性特定信息的指定对象设置属性值。

C#
public abstract void SetValue (object? obj, object? value, System.Reflection.BindingFlags invokeAttr, System.Reflection.Binder? binder, object?[]? index, System.Globalization.CultureInfo? culture);
C#
public abstract void SetValue (object obj, object value, System.Reflection.BindingFlags invokeAttr, System.Reflection.Binder binder, object[] index, System.Globalization.CultureInfo culture);

参数

obj
Object

将设置其属性值的对象。

value
Object

新的属性值。

invokeAttr
BindingFlags

以下指定该调用特性的枚举成员的按位组合:InvokeMethodCreateInstanceStaticGetFieldSetFieldGetPropertySetProperty。 必须指定合适的调用属性。 例如,为了调用静态成员,设置 Static 标志。

binder
Binder

一个对象,它启用绑定、对参数类型的强制、对成员的调用,以及通过反射对 MemberInfo 对象的检索。 如果 bindernull,则使用默认联编程序。

index
Object[]

索引化属性的可选索引值。 对于非索引化属性,该值应为 null

culture
CultureInfo

要为其本地化资源的区域性。 请注意,如果没有为此区域性本地化该资源,则在搜索匹配项的过程中将继续调用 Parent 属性。 如果该值为 null,则从 CurrentUICulture 属性获取区域性的特定信息。

实现

例外

index 数组不包含所需的参数类型。

找不到该属性的 set 取值函数。

value 无法转换为 PropertyType 的类型。

该对象与目标类型不匹配,或者某属性是实例属性但 objnull

index 中的参数数量与索引属性采用的参数数量不匹配。

试图非法访问类中的私有或受保护方法。

设置属性值时出错。 例如,为一个索引属性指定的索引值超出范围。 InnerException 属性指示出错的原因。

注解

如果此 PropertyInfo 对象是值类型且 valuenull,则 属性将设置为该类型的默认值。

若要确定是否为属性编制索引,请使用 GetIndexParameters 方法。 如果生成的数组具有 0 个 (零) 元素,则不会为 属性编制索引。

对于完全受信任的代码,将忽略访问限制。 也就是说,只要代码完全受信任,就可以通过反射访问和调用专用构造函数、方法、字段和属性。

若要使用 SetValue 方法,请首先获取 类 Type。 从 中 Type获取 PropertyInfo。 在 中 PropertyInfo,使用 SetValue 方法。

备注

从 .NET Framework 2.0 开始,如果调用方已使用 标志授予ReflectionPermissionReflectionPermissionFlag.RestrictedMemberAccess调用方,并且非公共成员的授予集仅限于调用方授权集或其子集,则此方法可用于访问非公共成员。 (请参阅 Reflection.) 若要使用此功能,应用程序应面向 .NET Framework 3.5 或更高版本。

适用于

.NET 9 和其他版本
产品 版本
.NET Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 1.1, 2.0, 3.0, 3.5, 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 2.0, 2.1