gpt4 book ai didi

.net - JavascriptSerializer 或 JavascriptDeserializer 线程的不同实例上的不同线程是否安全

转载 作者:行者123 更新时间:2023-12-04 18:08:55 26 4
gpt4 key购买 nike

我在这里寻找一个明确的答案。

根据the documentation JavascriptSerializer 的公共(public)静态方法是线程安全的,但非静态方法不是。

是否保证对于此类的公共(public)非静态方法,运行不同线程的不同实例是线程安全的(即没有可能违反线程安全的私有(private)静态资源)?特别是我感兴趣的JavascriptSerializer和JavascriptDeserializer中的序列化和反序列化方法,但想大致了解答案。

也就是说,如果线程 A 只在实例 A 上运行,而线程 B 只在实例 B 上运行,那么在这种情况下,公共(public)非静态方法的线程安全是否有明确的保证?

最佳答案

概括一下这个问题:JavaScriptSerializer 的离散实例是否可以?用于不同线程,最多有一个线程与特定实例交互?

I am looking for a definitive answer here.



我不能给你那个。但是,(您可能知道)文档中的线程安全消息非常通用,并且几乎无处不在(异常(exception)是管理并发的类型)。

轶事:我不知道存储共享内部状态的任何类型不是线程安全的。这无异于询问您是否可以使用 List 的两个不同实例或 XmlDocument在两个不同的线程上;如果您不能,该框架将毫无用处。
JavaScriptSerializer意味着像 Web 服务器那样在多个线程上多次实例化(ASP.Net 线程非常复杂,但肯定会在不同的线程上创建和调用多个类型的实例)。 MVC 框架使用 JavaScriptSerializer在内部,因此很明显该团队打算在多线程 Web 环境中使用它。

反编译源的快速查看显示没有共享的内部状态。正如@usr 所指出的,不能保证内部实现的一致性。但是,由于上述原因,这种情况似乎不太可能发生变化。

综上所述, JSON.net library由于其性能和灵 active ,通常被认为是 JSON(反)序列化的优越替代方案。

关于.net - JavascriptSerializer 或 JavascriptDeserializer 线程的不同实例上的不同线程是否安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19454142/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com