Dalam artikel The Free Lunch Is Over yang terkenal dari 2005, Herb Sutter meramalkan Revolusi Pemrograman Serentak sebesar Revolusi Berorientasi Objek. Apakah revolusi ini benar-benar terjadi di tahun 2005 - 2013?
Poin-poin penting dalam artikel:
Produsen prosesor telah kehabisan ruang dengan sebagian besar pendekatan tradisional mereka untuk meningkatkan kinerja CPU. Alih-alih mengemudi kecepatan jam semakin tinggi, mereka malah beralih ke arsitektur hyperthreading dan multicore.
Aplikasi akan semakin perlu berbarengan jika mereka ingin sepenuhnya memanfaatkan perolehan throughput CPU.
"Oh, kinerja tidak terlalu penting, komputer terus saja semakin cepat" pernyataan akan salah.
Efisiensi dan optimalisasi kinerja akan menjadi lebih penting, bukan lebih sedikit. Bahasa-bahasa yang sudah siap untuk optimasi berat akan menemukan kehidupan baru; mereka yang tidak perlu menemukan cara untuk bersaing dan menjadi lebih efisien dan optimal. Harapkan peningkatan permintaan jangka panjang untuk bahasa dan sistem yang berorientasi kinerja.
Memprogram bahasa dan sistem akan semakin dipaksa untuk berurusan dengan konkurensi. Kami sangat membutuhkan model pemrograman tingkat tinggi untuk konkurensi daripada bahasa yang ditawarkan saat ini.
sumber
Jawaban:
Ya, tapi itu tergantung.
Anda tidak dapat berharap untuk menulis perangkat lunak nontrivial , berkinerja tinggi tanpa menggunakan perangkat keras paralel dan menggunakan konkurensi sebagai teknik penataan program. Tetapi sebagian besar perangkat lunak bersifat sepele dan tidak kritis terhadap kinerja. Aplikasi web tidak menghasilkan banyak angka, dan aplikasi CRUD tidak memiliki batas waktu yang sulit untuk beberapa simulasi dan perangkat lunak medis.
Pengembang game khususnya perlu memperhatikan hal ini, karena game adalah jenis aplikasi yang paling umum dengan persyaratan waktu nyata yang lunak. Masalahnya menonjol pada ponsel, di mana Anda ingin menekan sebanyak mungkin komputasi dan menghasilkan daya dari chip terintegrasi dengan dua core CPU dan GPU berdaya rendah. Itulah alasan lain mengapa begitu banyak pengembang melihat Haskell dan menunggu bahasa seperti Rust matang - kami ingin keamanan dan kinerja perangkat keras modern.
Sejak 2005 kami telah memperoleh alat baru dan lebih baik seperti OpenCL, CUDA, OpenMP, dan set instruksi vektor untuk bekerja dengan konkurensi dan paralelisme data dalam bahasa yang sudah ada. Namun, pendatang baru relatif dirancang sejak awal untuk melakukan banyak hal lebih menarik dengan konkurensi.
Runtime bersamaan Haskell memungkinkan bahasa untuk memberikan dukungan yang kaya untuk paralelisme ringan (percikan) dan abstraksi konkurensi (utas, saluran, dan referensi yang dapat dibagikan bersama). Pergi dan Karat juga menawarkan tugas ringan, Pergi menggunakan saluran dan Karat menggunakan passing pesan.
Sistem ini menawarkan keamanan memori, kinerja runtime, dan perlindungan statis terhadap jenis ras tertentu. Kekekalan Haskell dan Rust yang standar menjadikan konkurensi lebih mudah bagi manusia untuk dikelola. Erlang sudah melakukan ini di tahun 80-an, tetapi kebutuhan perangkat lunak dan pengetahuan kita tentang bagaimana merancang sistem pemrograman juga telah meningkat sejak — syukurlah.
Akhirnya, banyak bahasa yang ada — saya tidak akan menyebut nama — siap ditolak sebagai pilihan yang kredibel untuk menulis perangkat lunak baru. Beban kerumitan dan abstraksi konkurensi yang buruk membuat mereka tidak cocok untuk pertimbangan aplikasi modern. Kami hanya menunggu alternatif matang.
sumber
Berikut adalah beberapa titik data; putuskan sendiri apakah itu dianggap sebagai revolusi.
Perangkat Keras Paralel
Sekitar tahun 2005, baik Intel dan AMD mulai memproduksi desktop 2-core x86 CPU (Pentium D dan Athlon 64), dengan kecepatan clock sekitar 3 GHz.
Pada tahun 2006, PlayStation 3 dirilis, menampilkan prosesor Cell dengan 8 + 1 core pada 3,2 GHz.
Pada tahun 2006, seri GeForce 8 dirilis. Ini terdiri dari sejumlah besar (~ 100) 'stream processor' untuk keperluan umum, yang berlawanan dengan unit khusus grafis. Sekitar 2007, spesifikasi CUDA 1.0 dirilis, memungkinkan beberapa komputasi tujuan umum dijalankan pada perangkat keras NVidia paralel-masif.
Sejak itu, kecenderungan berlanjut.
Katakanlah, sekarang, pada 2013, Intel dan AMD menawarkan CPU 4, 8, dan 16-core, dengan kecepatan clock sedikit di atas 4 GHz. Desain dual-core dan quad-core adalah umum untuk perangkat berdaya rendah, seperti laptop dan smartphone.
Semua ini adalah perangkat keras komputer sehari-hari yang diproduksi secara massal dan berkualitas konsumen.
Perangkat lunak
CUDA dirilis pada 2007, kemudian OpenCL pada 2008, memungkinkan untuk menggunakan GPU paralel-besar-besaran dalam perhitungan umum (non-grafis). Model menjadi populer; banyak perusahaan hosting (misalnya Amazon) menawarkan GPU untuk tugas komputasi umum.
Go dirilis pada 2009, menampilkan utas preemptive yang sangat murah ("goroutine") dan memungkinkan untuk mengekspresikan algoritma yang sangat bersamaan secara efisien.
Akka toolkit dirilis untuk Java dan Scala pada 2009, memungkinkan konkurensi berbasis aktor.
Erlang (bahasa yang sangat konkuren) melihat peningkatan penggunaan.
Konkurensi vs Paralelisme
Perhatikan bahwa untuk menggunakan perangkat keras paralel, seseorang tidak perlu memerlukan konkurensi perangkat lunak , yaitu, menyulap dengan benang eksekusi dalam suatu perhitungan. Banyak masalah diselesaikan dengan paralel , proses yang tidak berinteraksi, di mana setiap proses adalah program sekuensial tradisional.
Pemrosesan paralel dapat menggunakan lebih banyak bahasa tradisional dan kerangka kerja paralel, seperti pengurangan peta atau MPC atau OpenMP. Untuk kerangka kerja seperti itu, keberadaan beberapa core pada kristal CPU yang sama secara konseptual tidak jauh berbeda dengan hanya memiliki lebih banyak CPU di cluster; perbedaannya terutama kecepatan.
Tidak ada makan siang gratis sejauh ini
Kecepatan CPU masih bertahan di sekitar 5 GHz di kelas atas. Dengan teknologi yang lebih baik yang terlihat, seperti transistor graphene, frekuensi mungkin kembali meningkat di masa depan, tetapi mungkin tidak segera.
sumber