Rumah Java javaTutorial Bagaimana untuk melaksanakan pengaturcaraan serentak menggunakan multithreading di Java?

Bagaimana untuk melaksanakan pengaturcaraan serentak menggunakan multithreading di Java?

Aug 06, 2023 pm 01:24 PM
Pengaturcaraan serentak java multithreading

Bagaimana untuk melaksanakan pengaturcaraan serentak menggunakan multi-threading dalam Java?

Dalam pembangunan pemproses komputer moden, kami telah melihat kemunculan pemproses berbilang teras, yang memberikan lebih banyak kemungkinan untuk pengaturcaraan serentak. Sebagai bahasa pengaturcaraan yang digunakan secara meluas, Java menyediakan perpustakaan multi-threading yang kaya untuk membantu pembangun mencapai pengaturcaraan serentak yang cekap. Artikel ini akan memperkenalkan cara melaksanakan pengaturcaraan serentak menggunakan multi-threading dalam Java dan memberikan contoh kod.

  1. Dua cara untuk mencipta utas

Di Java, terdapat dua cara untuk mencipta utas: mewarisi kelas Thread dan melaksanakan antara muka Runnable. Kaedah 1: Warisi kelas Thread Untuk mengelakkan masalah ini, kita perlu memastikan penyegerakan dan pengecualian bersama antara rangkaian. Java menyediakan kata kunci yang disegerakkan untuk mencapai penyegerakan dan pengecualian bersama antara benang.

class MyThread extends Thread {
    @Override
    public void run() {
        System.out.println("MyThread is running");
    }
}

public class Main {
    public static void main(String[] args) {
        MyThread myThread = new MyThread();
        myThread.start();
    }
}
Salin selepas log masuk

Dalam kod di atas, kami mencipta Kaunter kelas kaunter selamat benang, menggunakan kata kunci yang disegerakkan untuk memastikan operasi atom kaedah kenaikan() dan getCount(). Dalam kaedah main(), kami mencipta dua utas untuk menambah nilai pembilang dan akhirnya mengeluarkan nilai pembilang.

Komunikasi antara utas
  1. Berbilang utas mungkin perlu berkomunikasi Java menyediakan kaedah seperti tunggu(), notify() dan notifyAll() untuk mencapai komunikasi antara utas.
class MyRunnable implements Runnable {
    @Override
    public void run() {
        System.out.println("MyRunnable is running");
    }
}

public class Main {
    public static void main(String[] args) {
        MyRunnable myRunnable = new MyRunnable();
        Thread thread = new Thread(myRunnable);
        thread.start();
    }
}
Salin selepas log masuk

Dalam kod di atas, kami mencipta kelas Mesej untuk menyimpan mesej. Kaedah read() menunggu apabila mesej kosong dan tidak kembali sehingga mesej baharu ditulis. Kaedah write() menunggu apabila mesej tidak kosong dan terus menulis mesej baharu sehingga mesej dibaca.

Kolam Benang
  1. Dalam aplikasi sebenar, mencipta dan memusnahkan benang ialah operasi yang sangat intensif sumber, tetapi kumpulan benang boleh menggunakan semula benang dan mengawal bilangan benang, meningkatkan penggunaan sumber. Java menyediakan kelas ThreadPoolExecutor untuk melaksanakan kumpulan benang.
class Counter {
    private int count = 0;

    public synchronized void increment() {
        count++;
    }

    public synchronized int getCount() {
        return count;
    }
}

public class Main {
    public static void main(String[] args) throws InterruptedException {
        Counter counter = new Counter();

        Thread thread1 = new Thread(() -> {
            for (int i = 0; i < 1000000; i++) {
                counter.increment();
            }
        });

        Thread thread2 = new Thread(() -> {
            for (int i = 0; i < 1000000; i++) {
                counter.increment();
            }
        });

        thread1.start();
        thread2.start();

        thread1.join();
        thread2.join();

        System.out.println("Count: " + counter.getCount());
    }
}
Salin selepas log masuk

Dalam kod di atas, kami mencipta kumpulan benang yang mengandungi 5 utas dan menyerahkan 10 tugasan kepada kumpulan benang untuk dilaksanakan. Akhir sekali, kita perlu memanggil kaedah executor.shutdown() untuk menutup kumpulan benang.

Ringkasan:

    Artikel ini memperkenalkan cara menggunakan multi-threading dalam Java untuk melaksanakan pengaturcaraan serentak dan menyediakan contoh kod yang sepadan. Dengan menggunakan berbilang utas dan melaksanakan penyegerakan, pengecualian bersama dan komunikasi antara utas, kami boleh mencapai pengaturcaraan serentak yang cekap. Pada masa yang sama, menggunakan kumpulan benang juga boleh meningkatkan penggunaan sumber dan prestasi program. Saya harap artikel ini membantu anda memahami pengaturcaraan serentak.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan pengaturcaraan serentak menggunakan multithreading di Java?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Reka bentuk struktur data selamat konkurensi dalam pengaturcaraan serentak C++? Reka bentuk struktur data selamat konkurensi dalam pengaturcaraan serentak C++? Jun 05, 2024 am 11:00 AM

Dalam pengaturcaraan serentak C++, reka bentuk struktur data yang selamat serentak adalah penting: Bahagian kritikal: Gunakan kunci mutex untuk mencipta blok kod yang membenarkan hanya satu utas untuk dilaksanakan pada masa yang sama. Kunci baca-tulis: membenarkan beberapa utas dibaca pada masa yang sama, tetapi hanya satu utas untuk ditulis pada masa yang sama. Struktur data tanpa kunci: Gunakan operasi atom untuk mencapai keselamatan serentak tanpa kunci. Kes praktikal: Barisan selamat benang: Gunakan bahagian kritikal untuk melindungi operasi baris gilir dan mencapai keselamatan benang.

Pengaturcaraan serentak C++: bagaimana untuk melaksanakan penjadualan tugas dan pengurusan kolam benang? Pengaturcaraan serentak C++: bagaimana untuk melaksanakan penjadualan tugas dan pengurusan kolam benang? May 06, 2024 am 10:15 AM

Penjadualan tugas dan pengurusan kumpulan benang adalah kunci untuk meningkatkan kecekapan dan kebolehskalaan dalam pengaturcaraan serentak C++. Penjadualan tugas: Gunakan std::thread untuk membuat thread baharu. Gunakan kaedah join() untuk menyertai utas. Pengurusan kolam benang: Buat objek ThreadPool dan nyatakan bilangan utas. Gunakan kaedah add_task() untuk menambah tugas. Panggil kaedah join() atau stop() untuk menutup kumpulan benang.

Apakah mekanisme dipacu peristiwa bagi fungsi C++ dalam pengaturcaraan serentak? Apakah mekanisme dipacu peristiwa bagi fungsi C++ dalam pengaturcaraan serentak? Apr 26, 2024 pm 02:15 PM

Mekanisme dipacu peristiwa dalam pengaturcaraan serentak bertindak balas kepada peristiwa luaran dengan melaksanakan fungsi panggil balik apabila peristiwa berlaku. Dalam C++, mekanisme dipacu peristiwa boleh dilaksanakan dengan penunjuk fungsi: penunjuk fungsi boleh mendaftarkan fungsi panggil balik untuk dilaksanakan apabila peristiwa berlaku. Ungkapan Lambda juga boleh melaksanakan panggilan balik acara, membenarkan penciptaan objek fungsi tanpa nama. Kes sebenar menggunakan penunjuk fungsi untuk melaksanakan peristiwa klik butang GUI, memanggil fungsi panggil balik dan mencetak mesej apabila peristiwa itu berlaku.

Pengaturcaraan Serentak C++: Bagaimana untuk mengendalikan komunikasi antara benang? Pengaturcaraan Serentak C++: Bagaimana untuk mengendalikan komunikasi antara benang? May 04, 2024 pm 12:45 PM

Kaedah untuk komunikasi antara benang dalam C++ termasuk: memori dikongsi, mekanisme penyegerakan (kunci mutex, pembolehubah keadaan), paip dan baris gilir mesej. Contohnya, gunakan kunci mutex untuk melindungi pembilang yang dikongsi: mengisytiharkan kunci mutex (m) dan pembolehubah yang dikongsi (pembilang); untuk mengelakkan keadaan perlumbaan.

Pengaturcaraan Serentak C++: Bagaimana untuk mengelakkan kebuluran benang dan penyongsangan keutamaan? Pengaturcaraan Serentak C++: Bagaimana untuk mengelakkan kebuluran benang dan penyongsangan keutamaan? May 06, 2024 pm 05:27 PM

Untuk mengelakkan kebuluran benang, anda boleh menggunakan kunci yang adil untuk memastikan peruntukan sumber yang adil, atau menetapkan keutamaan benang. Untuk menyelesaikan penyongsangan keutamaan, anda boleh menggunakan warisan keutamaan, yang meningkatkan keutamaan utas yang memegang sumber buat sementara waktu atau menggunakan promosi kunci, yang meningkatkan keutamaan utas yang memerlukan sumber.

Penjelasan terperinci tentang primitif penyegerakan dalam pengaturcaraan serentak C++ Penjelasan terperinci tentang primitif penyegerakan dalam pengaturcaraan serentak C++ May 31, 2024 pm 10:01 PM

Dalam pengaturcaraan berbilang benang C++, peranan primitif penyegerakan adalah untuk memastikan ketepatan berbilang utas yang mengakses sumber yang dikongsi Ia termasuk: Mutex (Mutex): melindungi sumber yang dikongsi dan menghalang akses serentak (ConditionVariable): thread Tunggu khusus syarat yang perlu dipenuhi sebelum meneruskan operasi atom: memastikan bahawa operasi dilaksanakan dengan cara yang tidak terganggu.

Pengaturcaraan Serentak C++: Bagaimana untuk melakukan penamatan dan pembatalan benang? Pengaturcaraan Serentak C++: Bagaimana untuk melakukan penamatan dan pembatalan benang? May 06, 2024 pm 02:12 PM

Mekanisme penamatan dan pembatalan utas dalam C++ termasuk: Penamatan utas: std::thread::join() menyekat utas semasa sehingga utas sasaran menyelesaikan pelaksanaan std::thread::detach() menanggalkan utas sasaran daripada pengurusan utas. Pembatalan utas: std::thread::request_termination() meminta utas sasaran untuk menamatkan pelaksanaan; benang. Dalam pertempuran sebenar, request_termination() membenarkan utas untuk menentukan masa penamatan, dan join() memastikan bahawa pada baris utama

Apakah rangka kerja dan perpustakaan pengaturcaraan serentak dalam C++? Apakah kelebihan dan batasan masing-masing? Apakah rangka kerja dan perpustakaan pengaturcaraan serentak dalam C++? Apakah kelebihan dan batasan masing-masing? May 07, 2024 pm 02:06 PM

Rangka kerja pengaturcaraan serentak C++ menampilkan pilihan berikut: utas ringan (std::benang-benang Boost concurrency concurrency dan algoritma OpenMP untuk pemproses berbilang pemproses berprestasi tinggi (TBB); (cpp-Setuju).

See all articles