成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面試官:什么是多線程中的上下文切換?

開發 前端
線程池可以復用線程,避免頻繁創建和銷毀線程,從而減少上下文切換開銷。線程池中的線程會被重新分配任務,避免重復的上下文切換。

在多線程編程中,“上下文切換”指的是操作系統在不同線程之間切換執行時保存和恢復線程狀態的過程。每個線程都包含一個“上下文”,即當前執行的狀態信息,包括寄存器的值、程序計數器(指令位置)、堆棧指針等。

步驟:

  1. 保存當前線程的狀態:當一個線程被掛起時,操作系統會將該線程的寄存器、程序計數器等狀態信息保存到內存中,以便將來能夠恢復。
  2. 恢復新線程的狀態:接下來,操作系統加載即將運行的線程的狀態信息,使得該線程能夠從中斷的位置繼續執行。
  3. 切換到新線程執行:完成狀態的保存和恢復后,CPU就會開始執行新線程的指令。

開銷:

雖然上下文切換使得多個線程能夠共享CPU資源,但它并非完全沒有成本。保存和恢復狀態需要時間,頻繁的上下文切換會導致:

  • 性能下降:頻繁切換會占用大量的CPU時間,導致真正執行任務的時間減少。
  • 緩存失效:每次切換線程時,CPU緩存可能會被刷新,導致緩存效率降低,增加內存訪問延遲。

如何減少上下文切換策略?

  • 減少線程數量:

每個線程都需要上下文切換資源,線程越多,切換頻率越高。如果任務量不大,減少線程數量可以降低上下文切換的頻率。

import java.util.List;
import java.util.Arrays;

public class ReduceThreadsExample {
    public static void main(String[] args) {
        List<String> tasks = Arrays.asList("task1", "task2", "task3", /* ... */ "task100");
        int threadCount = 10;
        int taskPerThread = tasks.size() / threadCount;

        for (int i = 0; i < threadCount; i++) {
            final int start = i * taskPerThread;
            final int end = (i == threadCount - 1) ? tasks.size() : (i + 1) * taskPerThread;

            new Thread(() -> {
                for (int j = start; j < end; j++) {
                    System.out.println("Processing " + tasks.get(j));
                }
            }).start();
        }
    }
}
  • 使用多線程池:

線程池可以復用線程,避免頻繁創建和銷毀線程,從而減少上下文切換開銷。線程池中的線程會被重新分配任務,避免重復的上下文切換。

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ThreadPoolExample {
    public static void main(String[] args) {
        ExecutorService executor = Executors.newFixedThreadPool(10);

        for (int i = 0; i < 100; i++) {
            int task = i;
            executor.submit(() -> System.out.println("Processing task " + task));
        }

        executor.shutdown();
    }
}
  • 增加任務的批處理:

盡量將多個小任務合并為一個批處理任務,減少線程之間的切換。這樣可以在同一個線程中連續完成多個任務,降低切換的頻率。

import java.util.List;
import java.util.Arrays;

public class BatchProcessingExample {
    public static void main(String[] args) {
        List<String> tasks = Arrays.asList("task1", "task2", "task3", /* ... */ "task100");
        int batchSize = 10;

        for (int i = 0; i < tasks.size(); i += batchSize) {
            final List<String> batch = tasks.subList(i, Math.min(i + batchSize, tasks.size()));

            new Thread(() -> {
                for (String task : batch) {
                    System.out.println("Processing " + task);
                }
            }).start();
        }
    }
}
  • 盡量減少鎖競爭:

當多個線程競爭同一個鎖時,線程會頻繁等待和喚醒,導致頻繁的上下文切換。可以通過優化鎖的使用,或者采用更細粒度的鎖來減少鎖的競爭。例如,使用讀寫鎖來避免多個讀取線程間的競爭。

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

public class LockCompetitionExample {
    private static int counter = 0;
    private static Lock lock = new ReentrantLock();

    public static void main(String[] args) {
        Runnable task = () -> {
            for (int i = 0; i < 1000; i++) {
                increment();
            }
        };

        Thread t1 = new Thread(task);
        Thread t2 = new Thread(task);

        t1.start();
        t2.start();

        try {
            t1.join();
            t2.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("Counter: " + counter);
    }

    private static void increment() {
        lock.lock();
        try {
            counter++;
        } finally {
            lock.unlock();
        }
    }
}
  • 無鎖編程:

在適用的場景下,使用無鎖編程(如原子操作或CAS操作)來實現線程間的同步,避免因為鎖競爭而產生的上下文切換。這通常適用于輕量級的并發操作。

import java.util.concurrent.atomic.AtomicInteger;

public class LockFreeExample {
    private static AtomicInteger counter = new AtomicInteger(0);

    public static void main(String[] args) {
        Runnable task = () -> {
            for (int i = 0; i < 1000; i++) {
                counter.incrementAndGet();
            }
        };

        Thread t1 = new Thread(task);
        Thread t2 = new Thread(task);

        t1.start();
        t2.start();

        try {
            t1.join();
            t2.join();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }

        System.out.println("Counter: " + counter.get());
    }
}
  • 使用協程替代多線程:

協程是一種輕量級的“線程”實現,可以在一個線程中實現多任務的協作切換。由于協程的切換是由程序控制的,不需要操作系統參與,因此可以大幅減少上下文切換的開銷。JDK21后支持協程。

public class VirtualThreadExample {
    public static void main(String[] args) {
        try (var executor = java.util.concurrent.Executors.newVirtualThreadPerTaskExecutor()) {
            for (int i = 0; i < 100; i++) {
                int taskNumber = i;
                executor.submit(() -> {
                    System.out.println("Processing task " + taskNumber + " in " + Thread.currentThread());
                    // 模擬一些I/O操作或其他阻塞任務
                    try {
                        Thread.sleep(1000);  // 模擬任務執行時間
                    } catch (InterruptedException e) {
                        Thread.currentThread().interrupt();
                    }
                    return taskNumber;
                });
            }
        }  // 自動關閉 executor,確保所有虛擬線程完成執行
    }
}

責任編輯:武曉燕 來源: 架構殿堂
相關推薦

2022-04-24 15:37:26

LinuxCPU

2019-05-06 14:36:48

CPULinux寄存器

2022-09-26 23:36:33

Linux系統CPU

2022-04-25 11:27:34

LinuxCPU

2024-08-27 09:46:39

Go協程效率

2021-05-25 11:10:36

GitLinux

2020-09-28 08:44:17

Linux內核

2022-09-05 08:02:10

上下文切換服務器

2024-03-19 09:15:12

服務器CPUI/O

2020-02-21 10:09:06

調度進程線程

2025-03-18 08:14:05

2023-11-24 16:18:15

操作系統Linux

2017-05-11 14:00:02

Flask請求上下文應用上下文

2023-12-20 14:35:37

Java虛擬線程

2025-05-12 00:00:15

2025-04-03 07:33:56

2021-09-07 10:44:33

Java 注解開發

2025-04-08 00:22:00

C#異步編程

2022-10-28 16:24:33

Context上下文鴻蒙

2021-02-19 10:02:57

HTTPSJava安全
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久成人一区二区三区 | 欧美一级片免费看 | 国产一区二区三区四区五区加勒比 | 日韩精品在线观看一区二区三区 | 99在线视频观看 | 国产福利观看 | 亚洲精品乱码久久久久久蜜桃 | 乱码av午夜噜噜噜噜动漫 | 中文字幕第一页在线 | 男人天堂国产 | 超碰3 | 久久99国产精品久久99果冻传媒 | 欧美色专区 | 亚洲成人一区 | 精品福利视频一区二区三区 | 成人日韩精品 | 欧美日韩国产精品一区 | 免费亚洲视频 | 久久一 | 日韩1区 | 久久99精品国产麻豆婷婷 | 91福利在线观看视频 | a级在线免费 | 玖玖在线精品 | 中文字幕在线播放第一页 | 在线免费观看视频黄 | 婷婷精品| 亚洲一区高清 | 国产精品久久在线 | 成人亚洲性情网站www在线观看 | 97精品久久 | 99视频网| 在线91 | 成人av免费看| a看片 | 国产精品入口麻豆www | 久久久精品黄色 | 亚洲一区二区三区视频 | 欧美一区二区精品 | 99久久精品免费看国产四区 | 金莲网|