- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
出于开发目的,我在单例 bean 中实现了一个虚拟数据存储库。单例 bean 的构造函数创建虚拟数据,并且有检索、插入、更新和删除虚拟数据的方法。
当我对其进行单元测试时,检查插入和更新的对象是否可以在插入和更新的相同状态下检索(即逐个属性相等),单元测试通过。在此测试中,我只是将单例 bean 实例化为常规对象,即通过其构造函数。当我实际使用单例 bean 时,将其注入(inject) @RequestScoped
JSF 支持 bean(将 bean 创建留给 EJB 容器),在更新数据项并随后通过其 ID 检索它之后,更新似乎会丢失并使用旧的字段值。因此,bean 在容器内和容器外的行为并不相同。然而,有一个System.out.println
在只执行一次的构造函数中,因此从这个意义上说,它似乎只实例化一次。
单例 bean 的结构如下:
@ConcurrencyManagement(ConcurrencyManagementType.BEAN)
@Singleton
@LocalBean
public class DummyDataRepository {
public DummyDataRepository() {
// Initial dummy data created here.
}
public final synchronized Foo findFooById(int id) {
// Retreive a Foo by ID.
// ...
}
public final synchronized void addFoo(Foo foo) {
// Add the Foo.
// ...
}
public final synchronized void updateFoo(Foo foo) {
// Find the existing Foo by foo.id and replace it with foo.
// ...
}
public final synchronized void deleteFoo(int id) {
// Find the existing Foo by id and delete it.
// ...
}
}
似乎没有任何理由表明该 bean 应该在 EJB 容器内外产生不同的结果。它不使用任何外部资源。同步是 bean 管理的(因此在这方面应该是相同的)。该 bean 被声明为单例。但在容器中,它似乎充当无状态 session bean。
我使用的是 GlassFish 3.1.2.2。
更新:我将 bean 从 @javax.ejb.Singleton
更改为至@javax.enterprise.context.ApplicationScoped
(并通过 @javax.inject.Inject
而不是 @javax.ejb.EJB
在需要的地方注入(inject)它),它现在按预期工作。但两者之间应该没有区别。看起来,虽然单例 EJB 仅被实例化一次,但它会以某种方式在方法调用之间恢复其状态。
最佳答案
单例 bean 中的公共(public)方法不应声明为 final
。我已将它们声明为最终的,因为我从构造函数中调用它们以使用初始虚拟数据集填充集合。当未声明为 Final 时,NetBeans 会正确警告从基类构造函数调用可能在子类中重写的方法。当未声明为 Final 时,我只需从构造函数中调用单例 bean 自己的公共(public)方法即可得到 NullPointerException。因此,非 final方法必须发生某种代理。
我仍然不确定为什么它看起来好像 final方法的结果被缓存(即得到过时的结果)。但我有我的答案,所以我对此很满意。
关于java - Singleton EJB 在 EJB 容器外部的行为应该相同,但事实并非如此,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12207983/
是否有一个意思是“不是单例”的名字? 最佳答案 CaSTLe Windsor 使用术语“ transient ”来描述所有非单例对象。 不过,我个人更喜欢“非单例”一词。 关于singleton -
我有很多(抽象)工厂,它们通常被实现为单例。 通常是为了方便,不必让他们通过那些真正与使用或了解这些工厂无关的层。 大多数时候我只需要在启动时决定其余代码程序的工厂实现,也许通过一些配置 它看起来例如
我有几个关卡都使用相同的音效。我没有在每个级别都使用相同的代码,而是将所有声音合并到一个单例类中。但是,当我从其他类运行该方法时,将其置于单例中不会播放任何声音。我没有错误或警告。 当我在每个类中使用
我应该使用 EJB-@Singleton (javax.ejb.Singleton) 进行统计或监控,还是将统计信息缓存在公共(public) @SessionScoped-Bean 中会更好?为了澄
我有这个单例类: public class Utente { private static readonly Lazy lazy = new Lazy(() => new Utente
我的 iOS 应用程序对 Web 服务做了很多不同的请求。每个请求都是对 ConnectionManager 对象的方法的调用。当响应从 Web 服务到达时,将调用委托(delegate)的方法来通知
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: cracking singleton with other ways 任何人都可以告诉我 Singleton不能用作
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: cracking singleton with other ways 任何人都可以告诉我 Singleton不能用作
做用 @Singleton 注释的类必须遵循 Singleton design pattern ? 我的猜测是他们没有:没有必要有私有(private)构造函数和 static .instance()
我想提供 Java 中可用的内置单例类列表以及使它们成为单例的原因。 对于 E.G. java.lang.Runtime 原因:因为整个 Java 应用程序只能有一个运行时环境。 java.awt.T
我有一个 Python 3 类,它目前是使用 @singleton 装饰器定义的单例,但有时它需要不是是单例。 问题:是否可以在实例化类的对象时传递一个参数,由该参数决定该类是单例还是非单例? 我正试
我正在使用 get_it 包,你有两个选项来注册单例,懒惰和我猜是“常规”(分别是 GetIt.instance.registerLazySingleton 和 GetIt.instance.regi
单例模式在 Spring 容器级别维护实例,而单例设计模式在类加载器级别维护实例。 还有其他区别吗? 其次,我仍然认为上述理由不成立。事实上,一个应用程序上下文/容器仅加载在一个类加载器中。因此从技术
这个问题在这里已经有了答案: What is an undefined reference/unresolved external symbol error and how do I fix it?
在 Guice 中,有什么区别: // Inside your AbstractModule subclass: @Override public void configure() { bin
我使用 pthread TLS 实现了一种“线程本地单例”,我想知道在这种情况下我如何(以及何时)可以删除 pthread_key_t,因为就像现在一样,TLS key 使用的内存永远不会空闲' d。
如何从 @Singleton 组件返回非单例对象? 例如我有: ApplicationComponent.kt @Singleton @Component(modules = [Application
我正在学习 Dagger 2,我注意到在某些示例中,模块方法中有一个 @Singleton,而组件方法中有其他 @Singleton?模块方法和组件方法上的 @Singleton 批注有什么区别,究竟
我的代码中需要一个单例。我读了 Jon Skeet 的 page在单例上并根据他的推荐选择了这个模型(#4): public sealed class Singleton { private
我正在尝试使用 label2rgb 生成 RGB 标签切片并使用它来更新 RGB 体积,如下所示: labelRGB_slice=label2rgb(handles.label(:,:,han
我是一名优秀的程序员,十分优秀!