thread02 - synchronized

本文深入探讨了Java中synchronized关键字的使用方式及其背后的锁机制。通过具体的代码示例,解释了如何利用synchronized来实现线程间的同步,并讨论了不同情况下锁的行为差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

package com.neutron.t02;

/**
 * 解说内容:
 *     synchronized关键字对某个对象进行加锁
 *     使用自身对象this作为锁
 */
public class T02 {

    private int count = 10;

    public void m() {
        // 任何线程要执行下面的代码,必须先拿到this这把锁
        synchronized (this) {
            count --;
            System.out.println(Thread.currentThread().getName() + " count:" + count);
        }
    }

    // 任何线程要执行下面的代码,必须先拿到this这把锁
    public synchronized void m2() {
        count --;
        System.out.println(Thread.currentThread().getName() + " count:" + count);
    }

}

/*
    过程解说:
    1.如果想要使用当前类的m方法,那么需要new出来个T02的对象,把自身的对象锁定
    2.每次要执行m方法时,需要锁定自身,然后再执行代码块
    3.synchronized锁定的是什么内容呢?synchronized锁定的是对象,而非代码块。
    4.如果代码开始synchronized(this),那么有简单写法,即在方法上添加关键字synchronized。所以方法m和方法m2是等价的
    5.疑问:
        每次都是new新的对象,那么锁定不同的对象,因为每次都是不同的对象,那么就是不同的锁?这个没有理解明白
        当时如果每次都是某个类的同一个对象,那么就是锁定相同的对象,比如设置为单例模式,就可以确保所有的线程使用的是唯一的锁
 */

### 关于Spring Hibernate事务同步会话问题 在Spring与Hibernate集成开发过程中,“Could not obtain transaction-synchronized Session for current thread”这一异常通常表明当前线程未能成功获取到事务管理器所控制的Session对象。此错误可能由多种原因引起,例如配置不当或者事务未被正确初始化。 以下是针对该问题的具体分析以及解决方案: #### 配置检查 确保`SessionFactory`已被正确定义并注入至相关组件中。如果使用XML方式,则需确认以下内容已存在: ```xml <bean id="sessionFactory" class="org.springframework.orm.hibernate5.LocalSessionFactoryBean"> <!-- 数据库连接池等相关属性 --> </bean> ``` 同时,在定义DAO层时应通过依赖注入获得SessionFactory实例而非手动创建[^1]。 #### 事务管理设置 对于上述提到的异常情况来说,最常见原因之一就是缺少适当声明式事务支持。可以通过启用@Transactional注解来简化操作流程,并让框架自动处理资源分配等问题。下面是一个基于Java Config的例子展示如何开启全局事务功能: ```java @Configuration @EnableTransactionManagement public class AppConfig { @Bean(name = "transactionManager") public PlatformTransactionManager getPlatformTransactionManager(SessionFactory sessionFactory){ return new HibernateTransactionManager(sessionFactory); } } ``` 当以上基础环境搭建完成后,就可以放心大胆地利用如下形式执行增删改查动作而无需担心再遇到之前提及的那种麻烦状况啦! 另外值得注意的是,假如仍然坚持采用编程手段来进行细粒度控制的话(就像您给出的那个例子片段),那么就务必要保证每一个数据库访问请求都处于同一个活动状态之中——即要么全都是只读模式下的查询行为;要么全部涉及到了修改数据表结构之类的写入类指令集才行哦!否则很容易因为违反ACID原则而导致冲突现象发生从而触发类似的报错提示信息出来呢~ 最后提醒一下大家记得及时关闭不再使用的链接哟~ ```java @PersistenceContext private EntityManager entityManager; @Override public void deleteUserById(Long userId) throws Exception{ User user = this.entityManager.find(User.class ,userId ); if(null !=user ){ EntityTransaction tx=entityManager.getTransaction(); try{ tx.begin(); entityManager.remove(user); tx.commit(); } catch(RuntimeException ex){ if(tx.isActive())tx.rollback(); throw ex; } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值