草庐IT

transaction-synchronized

全部标签

java - Spring Data JPA - 在没有@Transactional 的情况下获取延迟加载的集合

我的期望是,当在事务范围内访问集合时,应该获取延迟加载的集合。例如,如果我想获取一个集合,我可以调用foo.getBars.size()。缺少Activity事务将导致异常并显示错误消息,如failedtolazilyinitializeacollectionofbars:....couldnotinitializeproxy-noSession但是,我注意到我最新的应用程序中的行为有所不同。我将SpringBoot1.5.1与“data-jpa”启动器一起使用。我过去使用过SpringBoot,但data-jpastarter对我来说是新的。考虑以下情况。我有一个延迟加载的ManyT

java - 组织.hibernate.HibernateException : get is not valid without active transaction

我是Hibernate新手。自动创建hibernate.cfg.xml(Netbeans向导)自动创建HibernateUtil.java自动创建带注释的POJO类尝试从数据库中获取对象但出现错误:Exceptioninthread"pool-1-thread-1"org.hibernate.HibernateException:getisnotvalidwithoutactivetransactionatorg.hibernate.context.ThreadLocalSessionContext$TransactionProtectionWrapper.invoke(ThreadL

java - Java 中的并发性 : synchronized static methods

我想了解如何在Java中对静态方法进行锁定。假设我有以下类(class):classFoo{privatestaticintbar=0;publicstaticsynchronizedvoidinc(){bar++;}publicsynchronizedintget(){returnbar;}据我了解,当我调用f.get()时,线程会获取对象f上的锁,而当我调用Foo.inc()线程获取类Foo上的锁。我的问题是这两个调用如何相互同步?调用静态方法是否也会获取所有实例化的锁,或者反过来(这似乎更合理)?编辑:我的问题不完全是staticsynchronized如何工作,而是静态和非静态

超过 1 个对象的 java 同步块(synchronized block)?

我有两个数组,我需要跨线程同步访问它们。我将把它们放在同步块(synchronizedblock)中。问题是,我只能一次将其中一个传递给“同步”。如何确保对两个数组的访问是同步的?我是否将它们放在一个类中并创建一个对象?或者我只在同步块(synchronizedblock)中访问另一个数组,这会处理对它的同步访问?谢谢, 最佳答案 无论你做什么,都不要这样做:synchronized(array1){synchronized(array2){//dostuff}}这很可能导致deadlock除非你非常小心。如果您采用这种方法,则必须

java - GAE HDR : Are entity retrievals by key eventually consistent within a XG transaction?

考虑“事务用途”中的第二个示例(“使用命名键更新实体,如果它尚不存在则创建它”):https://developers.google.com/appengine/docs/java/datastore/transactions现在考虑这个场景。多人游戏只允许任何两个玩家之间进行一场比赛。为确保这一点,使用播放器的每个键创建一个键。此键用作UniqueMatch实体的键。因此,为了创建匹配,创建了XG交易。在此交易中:我们检查是否不存在具有该键的UniqueMatch实体。如果使用该键的datastore.get()调用没有抛出EntityNotFoundException,那么我们就知

java - 使用 JUnit4 进行测试时,Spring @transactional 不会启动事务

我有以下配置。org.hibernate.dialect.SQLServerDialecttruetrueorg.hibernate.dialect.SQLServerDialectfalsefalsetruetrue然后,当我运行具有插入语句的测试时,它们会产生这样的错误消息:javax.persistence.TransactionRequiredException:Executinganupdate/deletequeryatorg.hibernate.ejb.QueryImpl.executeUpdate(QueryImpl.java:47)经过深思熟虑,我尝试了这个:@Run

java - 为什么要在单线程方法中放置同步块(synchronized block)?

我偶然发现了thisarticle在IBM-developerworks上,他们发布的代码让我提出了一些问题:为什么局部变量Map的构建包含在synchronizedblock中?请注意,他们隐含地表示只有一个producer线程。实际上,为什么这个片段需要一个synchronizedblock?volatile变量应该足以完成这项工作,因为新创建的map只有在填满后才会发布。锁对象上只有一个线程同步有什么意义?文章提到:ThesynchronizedblockandthevolatilekeywordinListing1arerequiredbecausenohappens-befo

java - 为什么 synchronized 关键字在 Java 中称为 'synchronized' 而不是更精确的 'mutexed' ?

我听说在Java中选择使用“同步”一词来描述互斥语句是一个错误(编辑:“错误”在这里是一个错误的选择。请参阅编辑),但我想知道如果选择背后确实有原因。[编辑]受Safyan评论的启发,我想补充一点,同步是在线程之间建立计时关系的通用术语。它可以包括互斥和速率控制之类的东西(例如,两个线程以相同的速率做某事)。使用“synchronized”来表示互斥而不是使用更具体的关键字(如“mutexed”)似乎不必要地模棱两可。 最佳答案 这不是一个错误。意思就是它所说的;代码必须与其他线程同步以提供互斥。而且,事实上,术语同步可能比“互斥锁

java - 测试自定义插件 portlet : BeanLocatorException and Transaction roll-back for services testing

我的问题:我可以成功测试CRUD服务操作。我在做在@Before[setUp()]上插入并在@After上删除相同的数据[tearDown()]但今后我需要支持交易而不是编写用于插入和删除的代码。我成功获取了我的实体的单个记录,但是当我触发搜索查询或尝试获取多个实体时,我得到:com.liferay.portal.kernel.bean.BeanLocatorException:BeanLocatorhasnotbeensetforservletcontextMyCustom-portlet我已经按照以下一些链接使用Liferay设置Junit:Liferaywiki-Howtouse

java - 如何在没有同步块(synchronized block)(即低成本锁)的情况下在一个安全操作中原子地检查 Java 中的两个 AtomicBooleans?

所以我有两个AtomicBoolean,我需要检查它们。类似的东西:if(atomicBoolean1.get()==true&&atomicBoolean2.get()==false){//...}但两者之间存在竞争条件:(有没有办法将两个原子boolean检查组合成一个而不使用同步(即同步块(synchronizedblock))? 最佳答案 好吧,我可以想到几种方法,但这取决于您需要的功能。一种方法是“作弊”并使用AtomicMarkableReference:finalAtomicMarkableReferencetwoBo