`
k_lb
  • 浏览: 799368 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论
  • kitleer: 据我所知,国内有款ETL调度监控工具TaskCTL,支持ket ...
    kettle调度

线程基础

 
阅读更多

原子操作:假设有操作A和操作B,从A的角度看,B要么没执行,要么全部执行完成,这样A、B互为原子操作。

java强制原子性的内置锁机制:synchronized ,包括对锁对象的引用和锁保护的代码块。获得内部锁的唯一途径就是进入这个内部锁保护的代码块或方法中。内部锁是可以重进入的,当线程想获得他本身占有的锁时会成功的,这是因为jvm维护着锁的占有者和一个计算器,同一线程的一次请求,计数器会递增,同时每退出一次计数器也会递减,达到0时锁会被释放。

volatile保证了变量已最新的更新值被其他线程所访问,因为此变量是共享的,不会被缓存在寄存器中,或是放到其他处理器看不到的地方。

变量存在同步这样的风险,对象同样也存在同步的风险,也就是常说的publishing和escape。

Threadlocal为每个线程维护一份单独的拷贝,get时可以获得当前线程的最新值,set亦如此。




分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics