L'errore "Conversione definita dall'utente deve convertire in o dal tipo di chiusura" dice esattamente cosa significa. Se si dispone di un operatore di conversione
class MyClass {
public static explicit operator xxx(string s) { // details }
public static implicit operator string(xxx x) { // details }
}
Poi xxx
deve essere MyClass
. Questo è ciò che si intende per "la conversione deve essere convertita in o dal tipo di chiusura". Il tipo di allegato qui è MyClass
.
La sezione dedicata del ECMA334 C# spec è 17.9.4:
A conversion operator converts from a source type, indicated by the parameter type of the conversion operator, to a target type, indicated by the return type of the conversion operator. A class or struct is permitted to declare a conversion from a source type S to a target type T only if all of the following are true, where S0 and T0 are the types that result from removing the trailing ? modifiers, if any, from S and T:
S0 and T0 are different types.
Either S0 or T0 is the class or struct type in which the operator declaration takes place.
Neither S0 nor T0 is an interface-type.
Excluding user-defined conversions, a conversion does not exist from S to T or from T to S.
Quindi, ecco il codice:
public static explicit operator List<Model.objA>(List<Entity.objA> entities) {
List<Model.objA> objs= new List<Model.objA>();
foreach (Entity.objA entity in entities) {
objs.Add((Model.objA)entity);
}
return claims;
}
Il problema è che per questo deve essere definito come un operatore di conversione è deve risiedere nelle classi List<Model.objA>
o List<Entity.objA>
ma ovviamente non è possibile farlo poiché non si ha accesso per modificare tali tipi.
È possibile utilizzare Enumerable.Select
per proiettare sull'altro tipo o List<T>.ConvertAll
. Ad esempio:
public static class ListExtensions {
public static List<Model.objA> ConvertToModel(this List<Entity.objA> entities) {
return entities.ConvertAll(e => (Model.objA)e);
}
}