ThreadLocal与Synchronized
package com.demo; import org.hibernate.HibernateException;
import org.hibernate.classic.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration; public final class HibernateUtil {
private static SessionFactory sessionFactory;//现实中需要考虑属性的线程安全问题
/*
创建线程局部变量threadLocal,用来保存Hibernate的Session
ThreadLocal在其中设置任何对象,该对象对特定的线程访问将是“全局”且“局部”
全局:意味着这个线程的任何地方都可以访问到
局部:每个线程拥有它自己的ThreadLocal变量,一个线程不能访问或修改其他线程的ThreadLocal变量
*/
private static final ThreadLocal<Session> threadLocal = new ThreadLocal<Session>();
//使用静态代码块 初始化Hibernate
static{
try{
Configuration cfg = new Configuration().configure();
sessionFactory = cfg.buildSessionFactory();
}catch (HibernateException ex) {
// throw new RuntimeException("Exception building SessionFactory: "
// + ex.getMessage(), ex);
}
}
//获得ThreadLocal对象管理的session实例
/*
* 单一实例:在系统中全局使用一个唯一的SessionFactory实例,主要原因是Factory只需要一个实例可以调用方法就可以
* 另一个方面取得SessionFactory需要的时间太久,每次都实例化,会过分得浪费系统CPU资源
* 每个线程和使用自身对应的数据库连接session:这里是为每个线程建立一个局部的变量来达到这个目的
*/
public synchronized static Session getSession(){//同步锁 排队等候访问
/*
里面执行先取得当前线程的ThreadLocalMap 然后将threadSession作为key将对应的值取出
*/
Session s = (Session)threadLocal.get();//s--线程 私有
if(s==null){// 判断当前线程有无放进去session
s = sessionFactory.openSession();//创建一个session
//将新打开的session实例保存到线程局部变量threadLocal中
threadLocal.set(s);//实际上放到当前线程的ThreadLocal中
}
return s;
}
//关闭session实例
//@throws HibernateException
public static void closeSession() throws HibernateException{
//从线程局部变量threadLocal中获取之前存入的Session实例
Session session = threadLocal.get();
threadLocal.set(null);
if(session!=null){
session.close();
}
}
//获得sessionFactory的实例
public static SessionFactory getSessionFactory(){
if(sessionFactory == null){
Configuration cfg = new Configuration().configure();
sessionFactory = cfg.buildSessionFactory();
}
return sessionFactory;
}
//关闭sessionFactory
public static void closeSessionFactory(){
if(!sessionFactory.isClosed()){ //避免潜在的多线程并发问题
sessionFactory.close();
}
}
}
/*
threadLocal.set(session);将新创建的对象的引用保存到各线程的一个map中,每个线程都有这样的一个map
执行threadLocal.get()时,各线程从自己的map中取出放进去的对象 取出的是各自的对象
顺便说一下: synchronized(时间换空间 同步-仅仅提供一份变量 让不同的线程去排队访问)
ThreadLocal(空间换时间 并发性-为每一个线程都提供一份变量 因为可以同时访问而互不影响)
* new Configuration.configure() 会在默认的路径下找hiberate.cfg.xml配置文件,请看源代码: Java代码 收藏代码
public Configuration configure() throws HibernateException {
configure( "/hibernate.cfg.xml" );
return this;
} 所以你应该是:
Java代码 收藏代码
Configuration.configure("/hiberate.cfg.xml") *Configuration是hibernate的入口,在新建一个Configuration的实例的时候,
*使用不带参数的configure ()方法,hibernate会在classpath里面查找配置文件;
*Configuration的configure ()方法还支持带参数的访问方式,你可以指定hbm.xml文件的位置,
*而不是使用默认的classpath下面的配置文件。应该指定配置文件的位置。/
**/
package com.demo; import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration; public class HibernateUtils { // SessionFactory全局只需要有一个就可以了
private static SessionFactory sessionFactory; static {
Configuration cfg = new Configuration();
// cfg.configure(); // 读取默认的配置文件(hibernate.cfg.xml)
// // cfg.configure("hibernate.cfg.xml"); // 读取指定位置的配置文件
// sessionFactory = cfg.buildSessionFactory(); // cfg.addResource("cn/itcast/a_helloworld/User.hbm.xml");
// cfg.addClass(User.class); // 去User类所在的包中查找名称为User,后缀为.hbm.xml的文件 // 初始化SessionFactory
sessionFactory = new Configuration()//
.configure()//
.buildSessionFactory(); } /**
* 获取全局唯一的SessionFactory
*
* @return
*/
public static SessionFactory getSessionFactory() {
return sessionFactory;
} /**
* 从全局唯一的SessionFactory中打开一个Session
*
* @return
*/
public static Session openSession() {
return sessionFactory.openSession();
}
}
ThreadLocal与Synchronized的更多相关文章
- 【转】Java多线程编程中易混淆的3个关键字( volatile、ThreadLocal、synchronized)总结
概述 最近在看<ThinKing In Java>,看到多线程章节时觉得有一些概念比较容易混淆有必要总结一下,虽然都不是新的东西,不过还是蛮重要,很基本的,在开发或阅读源码中经常会遇到,在 ...
- 并发与同步 (一) ThreadLocal与Synchronized 用哪一个好
ThreadLocal是什么? 历史 早在JDK 1.2的版本中就提供java.lang.ThreadLocal,ThreadLocal为解决多线程程序的并发问题提供了一种新的思路.使用这个工具类可以 ...
- 处理java多线程时线程安全问题 - ThreadLocal和Synchronized
多线程在自动化测试中用的不多,也就是说我们用单线程可以完成大部分的自动化测试脚本. 主要有两个原因,首先是因为自动化测试首要考虑的是脚本的稳定性,所以一般会牺牲效率以保证脚本稳定,其次是由于局限于我们 ...
- 多线程学习三:Thread API,ThreadLocal,synchronized,volatile和Condition
一.Thread API: setDefaultUncaughtExceptionHandler(Thread.UncaughtExceptionHandler eh) 首先要了解什么是Thread. ...
- ThreadLocal 和Synchronized
并发都用到, 两个都是解决了线程并发问题,区别呢? Synchronized 同步机制, 共有变量被多个线程使用,会出现线程不安全,所以,加锁,锁机制很多种,例如Synchronized, lock ...
- ThreadLocal与Synchronized区别
ThreadLocal和Synchonized都用于解决多线程并发访问他们两者的区别:synchronized是利用锁的机制,使变量或代码块在某一时该只能被一个线程访问,而ThreadLocal为每一 ...
- ThreadLocal 与 Synchronized区别
相同:ThreadLocal和线程同步机制都是为了解决多线程中相同变量的访问冲突问题.不同:Synchronized同步机制采用了“以时间换空间”的方式,仅提供一份变量,让不同的线程排队访问:而Thr ...
- ThreadLocal, volatile, synchronized, map, epoll, AQS简单总结
ThreadLocal ThreadLocal主要是为了解决内存泄漏的问题,它是一种弱引用: 引用总共有四种,,我简单列一下: 强引用(Strong Reference):正常引用,根据垃圾回收算法, ...
- synchronized + volatile + ThreadLocal
线程的共享 synchronized + volatile + ThreadLocal <1> synchronized 锁住的是对象,当用它来锁住一个类时,实际上也是锁的一个对象. ...
随机推荐
- cloudera安装笔记
Cloudera安装教程 教程1:http://blog.csdn.net/a921122/article/details/51939692教程2:http://www.6gdown.com/soft ...
- 真实的人类第三季/全集Humans迅雷下载
Channel 4及AMC宣布续订<真实的人类 Humans>第三季,下季为8集:新季拍摄将在秋季开始,主要角色会回归.该剧设定在机器人Synth被繁忙都市人广泛使用的世界,呈现人类与机器 ...
- 低版本系统兼容的ActionBar(二)ActionProvider+分离式ActionBar+分离式的ActionMode
这篇文章主要讲的是在低版本兼容的ActionBar中实现自定义的ActionProvider,ShareActionProvider的使用方法,如何实现分离式ActionBar,外加在分 ...
- ImageView中scaleType属性详解
scaleType是指定图片的拉伸方式的一个属性,下面是具体的示例和介绍: <LinearLayout xmlns:android="http://schemas.android.co ...
- Oracle简单的备份和恢复-导出和导入(2)
ylbtech-Oracle:Oracle简单的备份和恢复-导出和导入(2) 简单的备份和恢复-导出和导入(2) 1. 用户导入导出文件中的一张表(emp)返回顶部 0.1, 我们在sql plus中 ...
- 奇怪吸引子---Coullet
奇怪吸引子是混沌学的重要组成理论,用于演化过程的终极状态,具有如下特征:终极性.稳定性.吸引性.吸引子是一个数学概念,描写运动的收敛类型.它是指这样的一个集合,当时间趋于无穷大时,在任何一个有界集上出 ...
- Qt信号槽的一些事 Qt::带返回值的信号发射方式
一般来说,我们发出信号使用emit这个关键字来操作,但是会发现,emit并不算一个调用,所以它没有返回值.那么如果我们发出这个信号想获取一个返回值怎么办呢? 两个办法:1.通过出参形式返回,引用或者指 ...
- leetcode关于数组的问题
关于数组的几道面试题 [Leetcode] 628. 三个数的最大乘积 解题思路: 这个一开始我是没想到思路的(除了遍历),因为有正负号的问题,后来看了一下别人的思路然后自己写的,思路是这样的: 三个 ...
- 遮罩层中的相对定位与绝对定位(Ajax)
前提:公司最近做的一个项目列表,然后点击项目,出现背景遮罩层,弹出的数据框需要异步加载数据数据,让这个数据框居中,搞了两天终于总算达到Boss满意的程度,做了半年C/S,反过来做B/S,顿时感到技术还 ...
- 3分钟搞定Linux系统正则表达式
正则表达式是一种字符模式,用于在查找过程中匹配制定的字符. 元字符通常在Linux中分为两类:Shell元字符,由Linux Shell进行解析:正则表达式元字符,由vi/grep/sed/awk等文 ...