zoukankan      html  css  js  c++  java
  • 多线程的并发控制(synchronized与ThreadLocal)

    synchronized

      synchronized的4种用法 :

        1.方法声明时使用,线程获得的是成员锁. 

        2.对某一代码块使用,synchronized后跟括号,括号里是变量,线程获得的是成员锁. 

        3.synchronized后面括号里是一对象,此时,线程获得的是对象锁. 

        4.synchronized后面括号里是类,此时,线程获得的是对象锁.

    ThreadLocal

     ThreadLocal并非是一个线程的本地实现版本,它并不是一个Thread,而是threadlocalvariable(线程局部变量)。

    线程局部变量(ThreadLocal)就是为每一个使用该变量的线程都提供一个变量值的副本,是Java中一种较为特殊的线程绑定机制,是每一个线程都可以独立地改变自己的副本,而不会和其它线程的副本冲突。在ThreadLocal类中有一个Map,用于存储每一个线程的变量的副本。  

    ThreadLocal() 

    创建一个线程本地变量。 

    get() 

    返回此线程局部变量的当前线程副本中的值,如果这是线程第一次调用该方法,则创建并初始化此副本。  

    protected T initialValue() 

    返回此线程局部变量的当前线程的初始值。最多在每次访问线程来获得每个线程局部变量时调用此方法一次,即线程第一次使用 get() 方法访问变量的时候。如果线程先于 get 方法调用 set(T) 方法,则不会在线程中再调用 initialValue 方法。 

    void remove() 

    移除此线程局部变量的值。这可能有助于减少线程局部变量的存储需求。如果再次访问此线程局部变量,那么在默认情况下它将拥有其 initialValue。 

    void set(T value) 

    将此线程局部变量的当前线程副本中的值设置为指定值。许多应用程序不需要这项功能,它们只依赖于 initialValue() 方法来设置线程局部变量的值。 

    在程序中一般都重写initialValue方法,以给定一个特定的初始值。

      eg:

        //创建一个Integer型的线程本地变量
        public static final ThreadLocal<Integer> local = new ThreadLocal<Integer>() {
          @Override
          protected Integer initialValue() {
          return 0;
          }
        };

  • 相关阅读:
    【翻译】Flink Table Api & SQL — 流概念
    Flink Table Api & SQL 翻译目录
    【翻译】Flink Table Api & SQL — 性能调优 — 流式聚合
    记一次kube-apiserver启动失败排错
    使用Docker和K8s搭建FastDFS分布式文件系统
    Windows 下安装RabbitMQ服务器及基本配置
    k8s部署ingress-nginx报错排错
    k8s使用私有镜像仓库Harbor下载镜像ImagePullBackOff错误拍错
    第二次安装docker时,报Transaction check error的解决方法
    k8s出现error: no configuration has been provided, try setting KUBERNETES_MASTER environment variable
  • 原文地址:https://www.cnblogs.com/cqyy/p/9430590.html
Copyright © 2011-2022 走看看