Java多線程

1、多線程怎么用 ?是什么?進(jìn)程和線程的區(qū)別?

進(jìn)程:操作系統(tǒng)上一塊獨(dú)立的運(yùn)行的程序,有自己的數(shù)據(jù)管理和其他進(jìn)程數(shù)據(jù)是不共享的。
操作系統(tǒng)的一塊獨(dú)立區(qū)域,
線程:是一個(gè)程序中的并行線路之一,一個(gè)進(jìn)程中可能會(huì)有多個(gè)線程。
1、多線程使用:
(1)thread

private void thread () {
   Thread thread = new Thread() {
          @Override
           public void run() {
                System.out.println("Thread started!");
            }
         }
     };
thread.start;

(2) runnable
可以重用runnable

private void runnable() {
    Runnable runnable = new Runnable() {
           @Override
            public void run() {
               System.out.println("Thread With Runnable Started!");
            }
         };
     Thread thread = new Thread(runnable);
     thread.start();
   }

(3)ThreadFactory
工廠方法的使用,統(tǒng)一的初始化線程操作,不用每一個(gè)線程都初始化一邊線程操作。

ThreadFactory factory = new ThreadFactory() {
    @Override
    public Thread newThread(Runnable runnable) {
        return new Thread(runnable);
    }
};
Runnable runnable = new Runnable() {
    @Override
    public void run() {
          System.out.println("ThreadFactory print");
    }
};
Thread thread = factory.newThread(runnable);
thread.start();

(4) Executor
線程池 Executor

Runnable runnable = new Runnable() {
    @Override
    public void run() {
        System.out.println("newCachedThreadPool print");
    }
};
//可緩存線程池,如果緩存中沒(méi)有可用的,則移出60秒未使用過(guò)的線程
Executor executor = Executors.newCachedThreadPool();
//創(chuàng)建一個(gè)單線程的線程池
Executor executor = Executors.newSingleThreadExecutor();
//創(chuàng)建一個(gè)固定線程的線程池,可以用來(lái)處理集中瞬時(shí)爆發(fā)的任務(wù)
Executors.newFixedThreadPool(10);
//加延遲的線程池,支持定時(shí)和周期,一般情況下可替代timer
Executors.newScheduledThreadPool(10);
executor.execute(runnable);

(5) callable
相當(dāng)于帶返回值的runable

private void callable() {
   Callable<String> callable = new Callable<String>() {
        @Override
        public String call()  {
         try {
              Thread.sleep(1500);
          } catch (Exception e) {
              e.printStackTrace();
         }
           return "";
         }
    };
   ExecutorService service = Executors.newSingleThreadExecutor();
   Future<String> future = service.submit(callable);
   if (future.isDone()) {
       try {
           String result = future.get();
       } catch (ExecutionException | InterruptedException e) {
          e.printStackTrace();
      }
   }
}

2、線程同步:

原子性 : AtomicInteger,AtomicBoolean
(1)volatile 關(guān)鍵字
當(dāng)寫(xiě)一個(gè)volatile變量時(shí),JMM會(huì)把該線程本地內(nèi)存中的變量強(qiáng)制刷新到主內(nèi)存中去
(2)synchronized
1.修飾方法,修飾代碼塊

//修飾方法
private synchronized void count() {
        x += 1;
        y += 1;
    }

修飾代碼塊

//修飾修飾代碼塊
private void count() {
     synchronized (this) {
          x += 1;
          y += 1;
      }
 }

另外,修飾代碼塊可以指定鎖

private Object object = new Object();
private void count() {
      synchronized (object) {
         x += 1;
         y += 1;
      }
  }
  1. 修飾一個(gè)代碼塊,被修飾的代碼塊稱(chēng)為同步語(yǔ)句塊,其作用的范圍是大括號(hào){}括起來(lái)的代碼,作用的對(duì)象是調(diào)用這個(gè)代碼塊的對(duì)象;
  2. 修飾一個(gè)方法,被修飾的方法稱(chēng)為同步方法,其作用的范圍是整個(gè)方法,作用的對(duì)象是調(diào)用這個(gè)方法的對(duì)象;
  3. 修改一個(gè)靜態(tài)的方法,其作用的范圍是整個(gè)靜態(tài)方法,作用的對(duì)象是這個(gè)類(lèi)的所有對(duì)象;
  4. 修改一個(gè)類(lèi),其作用的范圍是synchronized后面括號(hào)括起來(lái)的部分,作用主的對(duì)象是這個(gè)類(lèi)的所有對(duì)象。

3.使用synchronized的例子,線程安全的單例模式

public class Singleton {
    //保證有序性,防止指令重排
    private static volatile Singleton singleton;

    public Singleton() {

    }

    private static Singleton getInstance() {
         //先判斷對(duì)象是否已經(jīng)實(shí)例過(guò),沒(méi)有實(shí)例化過(guò)才進(jìn)入加鎖代碼
        if (singleton == null) {
           //類(lèi)對(duì)象加鎖
            synchronized (Singleton.class) {
                if (singleton == null) {
                    singleton = new Singleton();
                }
            }
        }
        return singleton;
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容