- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
在用作并行下载管理器的双工 WCF 服务中,我有一个显示每个下载状态的下载器类和一个包含下载器实例的 ObservableCollection。当我尝试通过 BinaryFormatter 序列化 ObservableCollection 时,我得到 SerializationException 消息:“Type\System.Net.ConnectStream\in assembly\System.Version 4.0.0.0, Culture=neutral, PublicKey Token=b77a5c561934e089\is not marked as serializable”。下面是 Downloader 类的精简版:
[Serializable()]
public class Downloader
{
/// <summary>
/// "Download status changed" event.
/// </summary>
[field: NonSerialized()]
public event EventHandler<InServiceHandledDownloadStatusChangedEventArgs> InServiceHandledDownloadStatusChanged;
/// <summary>
/// URL of downloaded resource.
/// </summary>
private String _targetUrl;
/// <summary>
/// Path to save downloaded data on local drive.
/// </summary>
private String _pathToSave;
/// <summary>
/// The number of bytes downloaded from internet resource.
/// </summary>
private Int64 _downloadedBytesQuantity = 0;
/// <summary>
/// Current status of downloading ("Await", "Running", "Completed").
/// </summary>
private String _status = "Added";
/// <summary>
/// Task that performs download.
/// </summary>
[NonSerialized()]
public Task TaskPerformingDownload;
/// <summary>
/// The source of cancellation token for cancelling of TaskPerformingDownload.
/// </summary>
[NonSerialized()]
public CancellationTokenSource CancelDownloadTokenSource;
/// <summary>
/// Gets or sets stream to read downloaded data from internet.
/// </summary>
public Stream ReadСontentStream { get; set; }
/// <summary>
/// Gets or sets stream to write downloaded data to local drive.
/// </summary>
public Stream SaveСontentStream { get; set; }
/// <summary>
/// This method executes in TaskPerformingDownload and performs downloading.
/// of a resource from internet.
/// </summary>
/// <param name="p_CancellationToken">Cancellation Token</param>
public void PerformDownload(Object p_CancellationToken)
{
try
{
// Get cancellation token.
CancellationToken cancellationToken = (CancellationToken)p_CancellationToken;
// Check was the task canceled?
cancellationToken.ThrowIfCancellationRequested();
. . . . . . . .
HttpWebRequest webResourceRequest = (HttpWebRequest)WebRequest.Create(TargetUrl);
HttpWebResponse webResourceResponse = (HttpWebResponse)webResourceRequest.GetResponse();
this.ReadСontentStream = webResourceResponse.GetResponseStream();
this.SaveСontentStream = new FileStream(this.PathToSave, FileMode.Create, FileAccess.Write, FileShare.None);
int bytesReceivedInChank = 0;
byte[] downloadBuffer = new byte[2048];
// The downloading loop.
while ((bytesReceivedInChank = this.ReadСontentStream.Read(downloadBuffer, 0, downloadBuffer.Length)) > 0)
{
if (cancellationToken.IsCancellationRequested)
cancellationToken.ThrowIfCancellationRequested();
this.SaveСontentStream.Write(downloadBuffer, 0, bytesReceivedInChank);
. . . . . . . .
}
}
catch(Exception){. . . .}
finally
{
if (this.ReadСontentStream != null)
{
this.ReadСontentStream.Close();
this.ReadСontentStream.Dispose();
}
if (this.SaveСontentStream != null)
{
this.SaveСontentStream.Close();
this.SaveСontentStream.Dispose();
}
}
}
}
TaskPerformingDownload 成员是执行一次下载的 TPL 任务。它是从 StartDownload() 契约(Contract)方法开始的,当客户端要求这样做时,WCF 服务会调用该方法。在此任务中执行 PerformDownload 方法。 WCF 服务创建与必须执行的下载一样多的下载器实例。每次下载一个下载器实例。带有消息的 SerializationException 异常:“Type\System.Net.ConnectStream\in assembly\System.Version 4.0.0.0, Culture=neutral, PublicKey Token=b77a5c561934e089\is not marked as serializable”仅当我尝试序列化 ObservableCollection 时才会发生下载。下载完成后,其任务(TaskPerformingDownload 成员)也已完成其工作,不再执行。我尝试在已完成的下载中处理任务,但它没有帮助并且 SerializationException 异常仍然存在。但是,如果 ObservableCollection 中只有新的下载,那么尚未运行的下载(因此此下载的 TaskPerformingDownload 成员尚未运行),在这种情况下,ObservableCollection 序列化很好,没有任何异常或错误。你能告诉我为什么会出现这种情况吗?这对我来说非常重要。
最佳答案
您正在尝试序列化一个Stream
。这是灾难的根源:流不是数据桶——它们是管道;它们很少以任何有意义的方式序列化,如果有的话。我的建议很简单:不要那样做。事实上,根本不要尝试序列化 Downloader
;您应该序列化数据,而不是实现状态。创建一个单独的模型,仅用于序列化,其中包含您要以最简单、最明显的方式存储的数据。如果你想序列化一个二进制请求/响应:byte[]
。等等。
另外:出于多种原因,我强烈建议不要在几乎所有场景中使用 BinaryFormatter
。
关于c# - 序列化异常 : "Type\...\in assembly\...\is not marked as serializable" appears when I try to serialize ObservableCollection,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24573122/
目前我有以下内容: $.ajax({ type: 'POST', url: this.action, data: $(this).serialize(), }); 这工作正常,
目前我有以下内容: $.ajax({ type: 'POST', url: this.action, data: $(this).serialize(), }); 这很好用,但
我知道什么是序列化,但对我来说,这是一个无法描述其含义的术语。 为什么我们称序列化为序列化?将对象转换为原始数据(以及膨胀/反序列化,就此而言)有什么意义?谁创造了这个术语,为什么? 最佳答案 它可能
是否可以将数据结构(使用 boost::serialization)序列化为字符串变量或缓冲区(而不是磁盘上的文件)? 最佳答案 当然,让它在stringstream上完成工作。 关于serializ
假设我有以下类型定义,它依赖于常量来指示记录成员的向量长度: type point_t is record x: std_logic_vector(X_WIDTH-1 downto 0);
我尝试序列化一个向量和一个 map 容器,并通过 cout 输出它们的值。然而,我很难理解boost输出的含义。我的代码如下所示: #include #include #include #
我正在尝试将序列化功能添加到我的 Rust 结构之一。这是一个日历事件,看起来像这样: #[derive(PartialEq, Clone, Encodable, Decodable)] pub st
正如主题所暗示的那样,在将大量数据序列化到文件时,我遇到了 boost::serialization 的一个小问题。问题在于应用程序的序列化部分的内存占用大约是被序列化对象内存的 3 到 3.5 倍。
在搜索解决方案时,我得到了 this和 this但我不清楚这个概念,所以无法实现:(。当我尝试更新数据库中的值(特别是日期时间对象)时会发生此错误。以下是我正在使用的代码:- var upd
我收到以下错误, 模板对象不可迭代 def get_AJAX(request, id): data = serializers.serialize("json", Template.objec
由于方便,我正在考虑对我的所有数据 i/o 使用 serialize() 和 deserialize()。但是,我不想在 Julia 更新中被不可读的文件所困扰。 serialize() 和 dese
我有一个通常使用 JMS Serializer 包序列化的实体。我必须在序列化中添加一些不驻留在实体本身中但通过一些数据库查询收集的字段。 我的想法是创建一个自定义对象,用实体字段填充字段并添加自定义
我正在尝试使用 XmlParser 从 xml 文件中删除和添加标签。以下是我在使用“grails run-app”命令部署的 grails 应用程序中执行时运行良好的代码块: def parser
我正在使用 MRUnit 测试 MultipleOutputs。测试用例失败并显示以下消息。 java.lang.ClassCastException: org.apache.hadoop.io.se
本文整理了Java中com.jme3.network.serializing.serializers.ZIPSerializer类的一些代码示例,展示了ZIPSerializer类的具体用法。这些代码
我有一个处理草图,需要与 USB 设备建立 2 个连接。我无法提前判断哪个设备是 USB0 哪个是 USB1。 (不是我至少知道) 其中一台设备发出问候语,另一台设备根本不回答。因此,我编写了带有简单
我在下面有这个代码,我来自 this forum我遵循了。它对我不起作用,但他们声称代码很好。我已经尝试了几种字符串比较方法,例如 string.equals(string)和标准==运营商,仍然没有
当我尝试调用特定的 Web 服务方法时,我收到“Unspecified error”。使用 XMLSpy 我发现参数对象还没有被序列化。 在生成的序列化程序源中,我注意到以下几行: if (!need
在 Rust 中编写 NEAR 智能合约,我的编译器似乎要求通过 API 发送的对象具有 Serialize trait,以及存储在区块链中的对象 BorshSerialize和 BorshDeser
我正在尝试 Kotlin 序列化。按照说明进行设置后,我得到了 Unresolved reference: serializer使用此代码构建错误: val serializer : KSeriali
我是一名优秀的程序员,十分优秀!