Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Haskellで並行プログラミングの練習
Search
Tomohiko Himura
May 08, 2016
Programming
320
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Haskellで並行プログラミングの練習
LT駆動25
https://github.com/LTDD/Sessions/wiki/LT%E9%A7%86%E5%8B%95%E9%96%8B%E7%99%BA25
Tomohiko Himura
May 08, 2016
More Decks by Tomohiko Himura
See All by Tomohiko Himura
Marpでmermaidは簡単だときいたけど
eiel
1
2.4k
バイナリ読むのにElixirしてみた
eiel
0
110
アジャイルはさておきMake People Awesomeしたい
eiel
0
220
レビューは最優先にするようにしている
eiel
0
350
再考 Fourkeys メトリクス
eiel
2
720
Test mockをSnapshot testする
eiel
0
170
devenvに入門した
eiel
1
170
関数プログラミングの考え方
eiel
1
380
逆コンウェイ作戦はフィードバックループを作るために 逆向きの流れをつくること (5分版)
eiel
0
490
Other Decks in Programming
See All in Programming
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
120
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
330
例外の正しい扱い方 そのエラー try-catchして大丈夫?
jinwatanabe
0
230
Make SRE Operations Easier with Azure SRE Agent
kkamegawa
0
5.8k
Claspは野良GASの夢をみるか
takter00
0
190
Composerを使ったサプライチェーン攻撃の様子を眺めてみる #phpstudy
o0h
PRO
2
250
肥大化するレガシーコードに立ち向かうためのインターフェース分離と依存の逆転 / JJUG CCC 2026 Spring
hirokunimaeta
0
550
[2026年度第1回ORセミナー] 計画最適化ベンチャーと競技プログラミング人材
terryu16
0
260
Honoでのサプライチェーン侵害対策 〜 3つのライブラリに学ぶ
yusukebe
0
150
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
540
Lessons from Spec-Driven Development
simas
PRO
0
190
The NotImplementedError Problem in Ruby
koic
1
770
Featured
See All Featured
Jamie Indigo - Trashchat’s Guide to Black Boxes: Technical SEO Tactics for LLMs
techseoconnect
PRO
0
160
JAMstack: Web Apps at Ludicrous Speed - All Things Open 2022
reverentgeek
1
470
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
37
6.5k
Building Flexible Design Systems
yeseniaperezcruz
330
40k
The Cost Of JavaScript in 2023
addyosmani
55
10k
The Curse of the Amulet
leimatthew05
1
13k
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.7k
Test your architecture with Archunit
thirion
1
2.3k
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
160
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
The Spectacular Lies of Maps
axbom
PRO
1
810
Transcript
HaskellͰ ฒߦϓϩάϥϛϯάͷ࿅श 2016-05-07 LTۦಈ։ൃ25
ͻΉΒ ͱͻ͜ ฒߦ ฒྻ ࢄ ͲΕ͍͠
None
None
言葉にすれば 世界は変えられる
ฒߦϓϩάϥϛϯά Λ͡ΊͯΈΔ
なぜ並行プログラミング
CPUはもう速くならないらしい
速くならないけど 幅は広くなるらしい
コアの数は増える
複数のコアを有効に使わなければ プログラムは速くならない
複数のコアを使って 別々のタスクを実行する
ノンブロッキングI/Oの登場で 効果がでやすい(要出典)
コアの複数化で 効果がでやすい(要出典)
並列処理より入門しやすい
並行処理といえば Go言語らしい
真似をするところから はじめよう
IUUQRJJUBDPNTVJOJUFNTFDCG⒎EGE
None
1秒かかる処理 2秒かかる処理 3秒かかる処理
Go言語では Goルーチンとチャンネル で並行化
1秒かかる処理 2秒かかる処理 3秒かかる処理 終わるの待つ
Goルーチン • 軽量スレッド • 数kbしかつかわない • javaのスレッドは320kbとか使うらしい • 関数呼び出しに goってつけるだけ
たとえば javaで • 1クライアント 1スレッド割り当てる • サーバープロセスを考える • 320kb *
10,000 -> 約3GB
Goルーチンなら いっぱいつくれる
チャネル • Goルーチンがやり取りするのに利用 • メッセージパッシング • 共有メモリではなく • メッセージが入ってくるまで待つ
None
Αʔ͠ HaskellͰͬͯΈΑ͏
None
None
threadDelay マイクロ秒待てる
6秒かかる
(P )BTLFMM ฒߦԽ HP͚ͬͯͭΔ GPSL*0͚ͬͯͭΔ ௨৴ νϟωϧΛ͔ͭ͏ .7BSΛ͔ͭ͏
\
None
> だいたい同じ <
forkIO :: IO () -> IO ThreadId 第1引数を別のスレッドで実行
MVar 値が入ってくる前に 読み込みしようとすると 値が入ってくるまで待つ
予定どおり3秒で実行できた
ॻ͖ࠐΈΛ ผεϨουʹͯ͠ΈΔ
同時に実行すると出力が混ざる
軽量スレッドは プリエンプティブ 短い時間でスレッドが切り替わっている
出力は同一スレッドで やってみる
Control.Concurrent.Chan MVarみたいな無限キュー
Endがやってくるまで Chan を読み続けて 画面に表示 Endがやってきたら finished(MVar)に値を書き込み スレッドの終了を通知
ChanはMVarをつかって 実装されている
軽量スレッドとMVar が並行処理の基本単位
綺麗に表示された
めでたしめでたし
ファイルへの出力より ログの生成が早いと メモリがあふれるので注意
·ͱΊ
並行処理 • Communicating Sequential Processes • ってのが元になっている模様 • erlangやakka •
アクターモデル • そのまま分散できる • どちらもメッセージパッシング
CSP • いままでどおりかけて見通しがよい • 結構いろんな言語で使える模様
まとめ • HaskellでGoのコードは真似られそう • しかし、全く同じように動くわけではない • 正しく違いを理解しないといけない • HaskellはIOが型で分離される •
より良いコードがかけるはず