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
wasmって何? WebAssemblyはじめての方へ
Search
nako@9時間睡眠
October 19, 2022
Programming
0
220
wasmって何? WebAssemblyはじめての方へ
こちらの会の発表資料です
ElixirImp#25:はじめてのWebAssembly+Elixir
https://fukuokaex.connpass.com/event/262073/
nako@9時間睡眠
October 19, 2022
Tweet
Share
More Decks by nako@9時間睡眠
See All by nako@9時間睡眠
Elixir国内コミュニティと アンチパターン回避
nako_sleep_9h
3
120
「推し」について話すLT〜NOKIA、Elixir〜
nako_sleep_9h
0
110
YouTubeライブ対談からのエッジコンピューティング入門
nako_sleep_9h
1
170
piyopiyo.ex#15 春のElixir入学式
nako_sleep_9h
0
120
おすすめエンジニアコミュニティ
nako_sleep_9h
0
190
ElixirDesktopを楽しむための前説
nako_sleep_9h
0
390
Livebookを楽しむための前説
nako_sleep_9h
0
240
Nx、Axonを楽しむための前説
nako_sleep_9h
0
210
会社員プログラマから見たzackyさんの研究活動がすごいという話
nako_sleep_9h
0
300
Other Decks in Programming
See All in Programming
フロントエンドのmonorepo化と責務分離のリアーキテクト
kajitack
2
110
Flutter로 Gemini와 MCP를 활용한 Agentic App 만들기 - 박제창 2025 I/O Extended Seoul
itsmedreamwalker
0
140
Webinar: AI-Powered Development: Transformiere deinen Workflow mit Coding Tools und MCP Servern
danielsogl
0
130
Honoアップデート 2025年夏
yusukebe
1
330
대규모 트래픽을 처리하는 프론트 개발자의 전략
maryang
0
120
兎に角、コードレビュー
mitohato14
0
130
令和最新版手のひらコンピュータ
koba789
14
7.8k
LLMは麻雀を知らなすぎるから俺が教育してやる
po3rin
3
2.1k
GitHub Copilotの全体像と活用のヒント AI駆動開発の最初の一歩
74th
7
2.9k
Claude Code と OpenAI o3 で メタデータ情報を作る
laket
0
130
20250808_AIAgent勉強会_ClaudeCodeデータ分析の実運用〜競馬を題材に回収率100%の先を目指すメソッドとは〜
kkakeru
0
180
レガシープロジェクトで最大限AIの恩恵を受けられるようClaude Codeを利用する
tk1351
2
140
Featured
See All Featured
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
36
2.5k
Building Better People: How to give real-time feedback that sticks.
wjessup
367
19k
Adopting Sorbet at Scale
ufuk
77
9.5k
Typedesign – Prime Four
hannesfritz
42
2.8k
Side Projects
sachag
455
43k
Product Roadmaps are Hard
iamctodd
PRO
54
11k
Principles of Awesome APIs and How to Build Them.
keavy
126
17k
jQuery: Nuts, Bolts and Bling
dougneiner
64
7.8k
The Language of Interfaces
destraynor
160
25k
We Have a Design System, Now What?
morganepeng
53
7.7k
Connecting the Dots Between Site Speed, User Experience & Your Business [WebExpo 2025]
tammyeverts
8
460
JavaScript: Past, Present, and Future - NDC Porto 2020
reverentgeek
50
5.5k
Transcript
wasmって何? WebAssemblyはじめての方へ 2022/10/19 nako
自己紹介 • nako@9時間睡眠 • Elixir/Phoenix初心者コミュニティ 『piyopiyo.ex』オーガナイザー • 会社員。Webサービスのサーバサイ ドエンジニア •
Elixir10周年のお祝いにSnapCamera エフェクトを作りました:D
WebAssemblyとは?
WebAssemblyとは? • WebAssembly(略称:Wasm)は、 ブラウザでプログラムを高速実行するための 「ブラウザ上で動くバイナリコードの新しいフォーマット(仕様)」です。 • WebAssemblyの開発はMozilla、マイクロソフト、Google、Appleといった主要ブラ ウザの開発者により行われています。
WebAssemblyを利用したサービスが出来るまで C/C++/Rustなどで記述されたソースコードをコンパイルし、 wasmコードを生成する。 生成したwasmコードをWebアプリとして アップロードする。 JavaScriptコードから呼び出したり、 wasmコードからJavaScriptコードを呼び出す ことができる。 C/C++/Rust などの
ソースコード コンパイラ wasm コード Webアプリケーション wasm コード Java Script HTML CSS
Google Earthを開発ツールで 見てみると、wasmファイルが あることがわかります。
WebAssemblyの歴史 2015年6月17日 開発開始を公式にアナウンス 2016年3月15日 主要ブラウザ (Firefox, Chromium, Google Chrome, Microsoft
Edge) 上で UnityによるAngry Botsというデモが行われた 最初の目標としてCとC++からのコンパイルをサポートすることを目指し、 Rust がバージョン1.14以降で、Goがバージョン1.11以降で、Kotlin/Nativeがバー ジョン0.4以降で対応するなど、他のプログラミング言語のサポートも進められ た 2017年3月7日 WebAssemblyに標準対応した初のブラウザとなる Firefox 52.0がリリースされ た 2017年11月 MozillaはSafariとEdgeがWebAssemblyに対応したと発表し、すでに対応して いるChromeとFirefoxを含め、主要なブラウザすべてでサポートされることに なった 2019年12月5日 W3C勧告「WebAssembly Core Specification」が策定され、WebAssemblyは 正式なウェブ標準に認定された
WebAssemblyが使えるプログラミング言語 https://github.com/appcypher/awesome-wasm-langs より 🥚進行中、🐣不安定だが使える、🐥本番環境で使える 🐥 .Net、🐥 AssemblyScript、🥚 Ballerina、🐥 Brainfuck、🐥 C、🐥
C#、🐥 C++、🐣 C4wa、🐥 Clean、🥚 Co、🐥 COBOL、🥚 Crystal、🐣 D、🐣 Eel、🐣 Elixir、 🐥 F#、🥚 Faust、🥚 Forest、🐥 Forth、🐥 Go、🥚 Grain、🥚 Haskell、🐣 Java、 🐣 JavaScript、🥚 Julia、🐣 Kotlin/Native、🥚 Kou、🐣 Lisp、🐥 Lobster、🐥 Lua、 🐣 Lys、🐥 Never、🥚 Nim、🥚 Ocaml、🐣 Pascal、🐣 Perl、🐣 PHP、🥚 Plorth、🐣 Poetry、🐣 Python、🐣 Prolog、🐣 Ruby、🐥 Rust、🐣 Scheme、🐣 Scopes、🐣 Swift、🐥 TypeScript、🥚 Wase、🐥 WebAssembly、🥚 xcc、🐥 Zig
WebAssemblyでよく使われる言語 よく使われる言語は • Rust • C++ • AssemblyScript が多いようです。 ※調査は2021年6月、196カ国
(米国21.8%、ドイツ9.1%、 中国9.1%など)に分散した 250人のITエンジニアが回答
WebAssemblyとElixir • Wasmex ◦ https://github.com/tessi/wasmex ◦ Wasmexは、Elixirのための高速で安全なWebAssemblyとWASIランタイム ◦ 2020年に開発開始 ◦
定期的にバージョンアップがあり、開発が進んでいる • Firefly ◦ https://github.com/GetFirefly/firefly ◦ BEAM言語用の新しいコンパイラとランタイム ◦ 2018年に開発開始
WebAssemblyが 使われているプロダクト
WebAssemblyが使われているプロダクト 『Made with WebAssembly』というサイトで確認できます。 https://madewithwebassembly.com/ Google Earth、 Unity、Figmaといった WebAssemblyを使った サービスが確認できます。
国内事例:VKET CLOUD • 自社の所有する仮想空間でサービス展開を可能にするVRエンジン • Webリンクからの簡単なアクセス、3Dアバターを使った音声とチャットによるコミュ ニケーション、美しい仮想空間での様々なサービス展開が可能です
国内事例:メルカリレンズβ • メルカリレンズβでは、カメラの入力をサーバーに送信せず、デバイス内で高速に機 械学習に関連する処理を実行 • 物体検出の数値計算のバックエンドにWebAssemblyを用いている。 • https://engineering.mercari.com/blog/entry/20211222-mercari-lens/ より •
2021/12/16公開
ご清聴ありがとう ございました!