I have a class named WhatClass that has List field in it. I need to be able to read-only this field, so I used a get property to expose it to other objects.
public class WhatClass { List<SomeOtherClass> _SomeOtherClassItems; public List<SomeOtherClass> SomeOtherClassItems { get { return _SomeOtherClassItems; } } } However it turns out that any object can call
WhatClass.SomeOtherClassItems.Add(item); How can I prevent this?
One of those methods is .append() , you can add items to the end of an existing list object. You can also use . append() in a for loop to populate lists programmatically.
As others have said, you are looking for the .AsReadOnly() extension method.
However, you should store a reference to the collection instead of creating it during each property access:
private readonly List<SomeOtherClass> _items; public WhatClass() { _items = new List<SomeOtherClass>(); this.Items = _items.AsReadOnly(); } public ReadOnlyCollection<SomeOtherClass> Items { get; private set; } This is to ensure that x.Items == x.Items holds true, which could otherwise be very unexpected for API consumers.
Exposing ReadOnlyCollection<> communicates your intent of a read-only collection to consumers. Changes to _items will be reflected in Items.
You're looking for the ReadOnlyCollection<T> class, which is a read-only wrapper around an IList<T>.
Since the ReadOnlyCollection<T> will reflect changes in the underlying list, you don't need to create a new instance every time.
For example:
public class WhatClass { public WhatClass() { _SomeOtherClassItems = new List<SomeOtherClass>(); SomeOtherClassItems = _SomeOtherClassItems.AsReadOnly(); } List<SomeOtherClass> _SomeOtherClassItems; public ReadOnlyCollection<SomeOtherClass> SomeOtherClassItems { get; private set; } }
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With