You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
> > Another question: Any good reason why this lists can't just be initialized and hence empty if not neede and/or used? Makes the nullable stuff a lot easier and even more intuitive to use. Currently accessing `DirtyProperties` in a rule would return `null` instead of an empty list...
/// Gets a list of dirty properties (value was updated).
/// </summary>
/// <value>
/// The dirty properties.
/// </value>
[EditorBrowsable(EditorBrowsableState.Never)]
publicList<IPropertyInfo>DirtyProperties
{
get
{
if(!_dirtyProperties.IsValueCreated)
returnnull;
return_dirtyProperties.Value;
}
}
CSLA often doesn't initialize lists of types that might be serialized, because it is much smaller to serialize null than it is to serialize an empty list. This is because the serializer doesn't need to flow the list's type information for null, but it does need to flow the type information for an empty list so the empty list can be deserialized on the other end of the process.
For MobileFormatter, yes, you need to serialize type information for a collection type so you know what to create on the other side. But that isn't a strict requirement for CSLA serialization. For example, my source generator serializer doesn't require this, because it knows at compile-time what the underlying type is for the field, and can new it up how it sees fit. For collections like List<T>, I don't special-case that one, but it's trivial to add a custom implementation for that in my generator through configuration.
Also, I do like empty collections over null in general overall. Then I don't need to wonder, "is this a null list or not?" everywhere in my code. If the performance implications of a null list over an empty one is significant during serialization, then....maybe keep them null, but if it's essentially negligible, then I'd much rather see an empty list.
I agree. I find it really weird to have a list null instead of just empty. What exactly is the difference in use?
If we want to keep/improve (de)serialization speed, we can special-case empty lists etc. so null is transported and we just re-initialize it on the other side.
That's a good point. If a list is empty, serialize null, and then deserialize to an empty list.
I would really like to see perf data (using something like Benchmark.NET) to see what the perf benefit is to using null for serialization over an empty list. My guess is that it's negligible and doesn't outweigh the benefits of being able to reason about you code without worrying about null values. But the only way to know for sure is to measure and get numbers :)
Null and empty aren't the same thing, so I don’t think we can translate arbitrarily. I kind of suspect that would affect lazy loading, though that'll require some exploration.
It isn't the perfect of serialization that's in question, it is the size of the payload. And that may be incidental, so metrics need to be established.
For
MobileFormatter
, yes, you need to serialize type information for a collection type so you know what to create on the other side. But that isn't a strict requirement for CSLA serialization. For example, my source generator serializer doesn't require this, because it knows at compile-time what the underlying type is for the field, and cannew
it up how it sees fit. For collections likeList<T>
, I don't special-case that one, but it's trivial to add a custom implementation for that in my generator through configuration.Also, I do like empty collections over
null
in general overall. Then I don't need to wonder, "is this anull
list or not?" everywhere in my code. If the performance implications of anull
list over an empty one is significant during serialization, then....maybe keep them null, but if it's essentially negligible, then I'd much rather see an empty list.Originally posted by @JasonBock in #1233 (comment)
The text was updated successfully, but these errors were encountered: