Perbezaan antara boleh dipanggil dan boleh dijalankan di Java
Jul 04, 2025 am 02:50 AMTerdapat tiga perbezaan utama antara yang boleh dipanggil dan boleh dijalankan di Jawa. Pertama, kaedah yang boleh dipanggil boleh mengembalikan hasilnya, sesuai untuk tugas -tugas yang perlu mengembalikan nilai, seperti Callable
Di Java, kedua -dua Callable
dan Runnable
digunakan untuk mewakili tugas yang boleh dilaksanakan oleh benang. Walau bagaimanapun, mereka mempunyai perbezaan utama yang menjadikan setiap sesuai untuk senario yang berbeza.

1. Nilai pulangan
Salah satu perbezaan utama antara Callable
dan Runnable
ialah Callable
boleh mengembalikan hasil, sementara Runnable
tidak boleh.

-
Callable
pulangan nilai melalui kaedahcall()
, iaituObject
jenis. Ini menjadikannya berguna apabila anda perlu melakukan beberapa pengkomputeran dan mendapatkan hasil kembali. -
Runnable
, sebaliknya, mempunyai kaedahrun()
yang tidak mengembalikan apa -apa. Ia biasanya digunakan untuk tugas yang hanya perlu dijalankan tanpa mengembalikan nilai.
Sebagai contoh, jika anda memuat turun fail dan ingin tahu sama ada ia berjaya, anda mungkin menggunakan Callable<boolean></boolean>
. Jika anda hanya melayari beberapa maklumat atau mengemas kini UI, Runnable
akan mencukupi.
2. Pengendalian Pengecualian
Satu lagi perbezaan penting ialah bagaimana pengecualian dikendalikan.

- Kaedah
call()
dalamCallable
boleh membuang pengecualian yang diperiksa. Ini bermakna anda boleh mengendalikan kesilapan dengan lebih anggun dan menyerahkannya kepada pemanggil. - Sebaliknya, kaedah
run()
dalamRunnable
tidak membenarkan pengecualian yang diperiksa. Sebarang pengendalian pengecualian mesti dilakukan di dalam kaedah itu sendiri.
Ini menjadikan Callable
lebih fleksibel apabila bekerja dengan kod yang mungkin gagal kerana faktor luaran seperti operasi I/O atau panggilan rangkaian.
3. Penggunaan dengan benang dan pelaksana lagipat
Bagaimana antara muka ini digunakan dengan benang dan pelaksana juga berbeza:
-
Runnable
boleh dihantar secara langsung ke objekThread
atau dikemukakan kepadaExecutorService
. -
Callable
hanya boleh dikemukakan kepadaExecutorService
, tidak digunakan secara langsung denganThread
. Apabila anda menyerahkanCallable
, ia mengembalikan objekFuture
, yang membolehkan anda mengambil keputusan apabila ia tersedia.
Inilah cara anda menggunakannya:
// Contoh Runnable Tugas Runnable = () -> System.out.println ("Running a Runnable"); thread baru (tugas) .start (); // Contoh yang boleh dipanggil Callable <string> task = () -> "hasil dari callable"; ExecutOrservice Executor = executors.NewSingLethreadExecutor (); Masa depan <string> masa depan = executor.submit (tugas);
Jadi jika anda memerlukan hasil atau ingin bekerja dengan niaga hadapan, Callable
adalah pilihan yang lebih baik. Jika anda hanya memerlukan sesuatu untuk dijalankan tanpa nilai pulangan, tetap dengan Runnable
.
Itu pada dasarnya - perbezaan utama datang untuk mengembalikan jenis, pengendalian pengecualian, dan bagaimana ia digunakan dengan benang dan pelaksana. Tidak terlalu rumit, tetapi mudah dicampur jika anda tidak memberi perhatian.
Atas ialah kandungan terperinci Perbezaan antara boleh dipanggil dan boleh dijalankan di Java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Mekanisme pemuatan kelas Java dilaksanakan melalui kelas, dan aliran kerja terasnya dibahagikan kepada tiga peringkat: memuatkan, menghubungkan dan memulakan. Semasa fasa pemuatan, kelas muat turun secara dinamik membaca bytecode kelas dan mencipta objek kelas; Pautan termasuk mengesahkan ketepatan kelas, memperuntukkan memori kepada pembolehubah statik, dan rujukan simbol parsing; Inisialisasi melakukan blok kod statik dan tugasan pembolehubah statik. Pemuatan kelas mengamalkan model delegasi induk, dan mengutamakan loader kelas induk untuk mencari kelas, dan cuba bootstrap, lanjutan, dan appliclassloader pada gilirannya untuk memastikan perpustakaan kelas teras selamat dan mengelakkan pemuatan pendua. Pemaju boleh menyesuaikan kelas, seperti UrlClassl

Java menyokong pengaturcaraan asynchronous termasuk penggunaan aliran yang boleh diselesaikan, aliran responsif (seperti ProjectReactor), dan benang maya di Java19. 1.CompletableFuture meningkatkan kebolehbacaan dan penyelenggaraan kod melalui panggilan rantai, dan menyokong orkestrasi tugas dan pengendalian pengecualian; 2. ProjectReactor menyediakan jenis mono dan fluks untuk melaksanakan pengaturcaraan responsif, dengan mekanisme tekanan belakang dan pengendali yang kaya; 3. Thread maya mengurangkan kos konvensional, sesuai untuk tugas I/O-intensif, dan lebih ringan dan lebih mudah untuk berkembang daripada benang platform tradisional. Setiap kaedah mempunyai senario yang berkenaan, dan alat yang sesuai harus dipilih mengikut keperluan anda dan model campuran harus dielakkan untuk mengekalkan kesederhanaan

Javanio adalah IOAPI baru yang diperkenalkan oleh Java 1.4. 1) bertujuan untuk penampan dan saluran, 2) mengandungi komponen teras penampan, saluran dan pemilih, 3) menyokong mod tidak menyekat, dan 4) mengendalikan sambungan serentak lebih cekap daripada IO tradisional. Kelebihannya dicerminkan dalam: 1) IO yang tidak menyekat mengurangkan overhead thread, 2) Buffer meningkatkan kecekapan penghantaran data, 3) pemilih menyedari multiplexing, dan 4) memori pemetaan memori sehingga membaca dan menulis fail. Nota Apabila menggunakan: 1) Operasi flip/jelas penampan mudah dikelirukan, 2) Data yang tidak lengkap perlu diproses secara manual tanpa menyekat, 3) Pendaftaran pemilih mesti dibatalkan dalam masa, 4) NIO tidak sesuai untuk semua senario.

Kunci untuk mengendalikan pengecualian di Java adalah untuk menangkap mereka, mengendalikan mereka dengan jelas, dan tidak menutup masalah. Pertama, kita mesti menangkap jenis pengecualian tertentu seperti yang diperlukan, elakkan tangkapan umum, dan mengutamakan pemeriksaan pemeriksaan. Pengecualian runtime harus dinilai terlebih dahulu; Kedua, kita mesti menggunakan rangka kerja log untuk merekodkan pengecualian, dan mencuba semula, melancarkan atau membuang berdasarkan jenis; Ketiga, kita mesti menggunakan blok akhirnya untuk melepaskan sumber, dan mengesyorkan cuba-dengan-sumber; Keempat, kita mesti secara munasabah menentukan pengecualian adat, mewarisi runtimeexception atau pengecualian, dan membawa maklumat konteks untuk debugging mudah.

Di Java, enums sesuai untuk mewakili set tetap tetap. Amalan terbaik termasuk: 1. Gunakan enum untuk mewakili keadaan tetap atau pilihan untuk meningkatkan keselamatan jenis dan kebolehbacaan; 2. Tambah sifat dan kaedah untuk meningkatkan fleksibiliti, seperti menentukan bidang, pembina, kaedah penolong, dan lain -lain; 3. Gunakan enummap dan enumset untuk meningkatkan prestasi dan jenis keselamatan kerana mereka lebih cekap berdasarkan tatasusunan; 4. Elakkan penyalahgunaan enum, seperti nilai dinamik, perubahan kerap atau senario logik kompleks, yang harus digantikan dengan kaedah lain. Penggunaan enum yang betul boleh meningkatkan kualiti kod dan mengurangkan kesilapan, tetapi anda perlu memberi perhatian kepada sempadannya yang berkenaan.

Corak reka bentuk singleton di Java memastikan bahawa kelas hanya mempunyai satu contoh dan menyediakan titik akses global melalui pembina swasta dan kaedah statik, yang sesuai untuk mengawal akses kepada sumber yang dikongsi. Kaedah pelaksanaan termasuk: 1. 2. Pemprosesan Safe Thread, memastikan bahawa hanya satu contoh yang dibuat dalam persekitaran berbilang threaded melalui kaedah penyegerakan atau penguncian cek berganda, dan mengurangkan kesan prestasi; 3. 4. Pelaksanaan penghitungan, menggunakan penghitungan Java untuk secara semulajadi menyokong serialisasi, keselamatan thread dan mencegah serangan reflektif, adalah kaedah ringkas dan boleh dipercayai. Kaedah pelaksanaan yang berbeza boleh dipilih mengikut keperluan khusus

Kelas dalaman tanpa nama digunakan di Java untuk membuat subkelas atau melaksanakan antara muka dengan cepat, dan sering digunakan untuk mengatasi kaedah untuk mencapai tujuan tertentu, seperti pengendalian peristiwa dalam aplikasi GUI. Borang sintaksnya adalah antara muka atau kelas baru yang secara langsung mentakrifkan badan kelas, dan memerlukan pembolehubah tempatan yang diakses mestilah muktamad atau setara tidak berubah. Walaupun mereka mudah, mereka tidak boleh digunakan terlalu banyak. Terutamanya apabila logiknya kompleks, mereka boleh digantikan oleh ekspresi Lambda Java8.

String tidak berubah, StringBuilder boleh berubah dan tidak selamat-selamat, StringBuffer boleh berubah dan selamat. 1. Sebaik sahaja kandungan rentetan dicipta tidak dapat diubah suai, ia sesuai untuk sedikit splicing; 2. StringBuilder sesuai untuk splicing kerap benang tunggal, dan mempunyai prestasi yang tinggi; 3. StringBuffer sesuai untuk senario bersama pelbagai threaded, tetapi mempunyai prestasi yang sedikit lebih rendah; 4. Berjaga -jaga menetapkan kapasiti awal dan elakkan menggunakan splicing rentetan dalam gelung dapat meningkatkan prestasi.
