我想做的事情如下:
MyObject myObj = GetMyObj(); // Create and fill a new object
MyObject newObj = myObj.Clone();
Run Code Online (Sandbox Code Playgroud)
然后更改未在原始对象中反映的新对象.
我不经常需要这个功能,所以当有必要的时候,我已经使用了创建一个新对象然后单独复制每个属性,但它总是让我觉得有更好或更优雅的处理方式情况.
如何克隆或深度复制对象,以便可以修改克隆对象而不会在原始对象中反映任何更改?
究竟是什么在LINQ到SQL方法Table<T>.Attach()和Table<T>.AttachAll()什么是他们正确使用的例子/局面?
另外,请查看以下相关问题:如何从DataContext的跟踪机制中分离LINQ-to-SQL数据对象?