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
Rust + WebAssemblyで広がるWebの未来
Search
Yosuke Onoue
November 24, 2018
Technology
6.9k
16
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
Rust + WebAssemblyで広がるWebの未来
FRONTEND CONFERENCE 2018(
https://2018.kfug.jp/)の登壇資料です
。
Yosuke Onoue
November 24, 2018
More Decks by Yosuke Onoue
See All by Yosuke Onoue
ネットワーク可視化の世界
likr
8
7k
Think About Front-end Web Development with Rust
likr
2
590
Yewにおけるoff-the-main-thread
likr
1
850
行政事業レビューデータの可視化 / Visualization of Japan's National Budget with JUDGIT!
likr
1
270
モダンJavaScript再入門 / Re-introduction to Modern JavaScript
likr
24
12k
Web-based Data Visualization with Rust and WebAssembly
likr
4
6.2k
Introduction to Graph Drawing
likr
0
550
20190707Ionic_Meetup.pdf
likr
0
490
About the end of the web
likr
2
570
Other Decks in Technology
See All in Technology
現地で盛り上がった WWDC26 Keynote
zozotech
PRO
1
270
インシデントレスポンス演習 I / Incident Response Exercise I
ks91
PRO
0
100
ぼっちではじめた登壇が「51名」「241件」の発信に化けた
subroh0508
1
280
【2026年版】 ベクトル検索とEmbedding最前線
mocobeta
23
6.6k
AI-DLCを “そのまま導入しなかった”話 ~組織に合わせてアジャストした 私たちの実践共有~
hiroramos4
PRO
1
310
GitHub Copilot app最速の発信の裏側
tomokusaba
1
220
徹底討論!ECS vs EKS!
daitak
3
1.2k
IaC コードを資産へ:AWS CDK 社内ライブラリと横断展開 / aws-summit-japan-2026
gotok365
10
1.4k
いまさら聞けない「仕様駆動開発入門」 〜AI活用時代の開発プロセスを考える〜
findy_eventslides
2
170
サイバーエージェントにおけるAI推進戦略と変革への取り組み
shotatsuge
0
330
攻撃者視点で考えるDetection Engineering
cryptopeg
3
2k
iOS アプリの「これって不具合ですか?」を AI に調べてもらう
miichan
0
120
Featured
See All Featured
Thoughts on Productivity
jonyablonski
76
5.2k
From π to Pie charts
rasagy
0
220
Building an army of robots
kneath
306
46k
Breaking role norms: Why Content Design is so much more than writing copy - Taylor Woolridge
uxyall
0
320
A brief & incomplete history of UX Design for the World Wide Web: 1989–2019
jct
2
400
Side Projects
sachag
455
43k
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.7k
Exploring anti-patterns in Rails
aemeredith
3
420
Max Prin - Stacking Signals: How International SEO Comes Together (And Falls Apart)
techseoconnect
PRO
0
190
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
Building Flexible Design Systems
yeseniaperezcruz
330
40k
Imperfection Machines: The Place of Print at Facebook
scottboms
270
14k
Transcript
͓ͷ͏͑ 3VTU 8FC"TTFNCMZͰ͕Δ 8FCͷະདྷ '30/5&/%$0/'&3&/$& ݄
ࣗݾհ w ඌ্༸հ :PTVLF0OPVF w ຊେֶจཧֶ෦ใՊֶՊॿڭ w OHLZPUPΦʔΨφΠβʔ w
ใՄࢹԽɺཧ࠷దԽɺҙࢥܾఆࢧԉͷݚڀ w ՄࢹԽγεςϜͷ։ൃʹ8FCϑϩϯτΤϯυٕज़Λ༻
લճ·Ͱͷ͋Β͢͡
2015/08/22 グランフロントエンド asm.jsとWebAssemblyって実際なんなの? おのうえ (@_likr) !4
フリーランチの終焉 ✤ フロントエンド開発への要求は⾼まる ✤ ハードウェア、JSエンジンの性能向上の恩恵を知らな いうちに受けていた時代は終わるかもしれない? ✤ フロントエンドエンジニア(JSプログラマ)が JavaScriptプログラムの速度に負う責任が増す !5
まとめ ✤ asm.jsを効果的に使えば、これまでWebでできなかっ た種類のアプリケーションが実現できる ✤ WebAssemblyによる順当な進化に期待 ✤ なんでも速くなる魔法ではないので、 ⽤法⽤量を守って正しくお使いください !6
プログラミング⾔言語Rust おのうえ@_likr Grand Frontend Osaka 2016 2016年年8⽉月27⽇日
まとめ • Rustはいいぞ • WebAssemblyの実装は着実に進んでいる • RustでWebの部品を作れる未来はそう遠くない(かも • 未来に備えよう •
たまにはWebの未来を考えてみるのはいかが?
ͦͯͦ͠ͷޙ
IUUQTXFCBTTFNCMZPSH
IUUQTXFCBTTFNCMZPSH 8FC"TTFNCMZIBTTIJQQFE JONBKPSCSPXTFSFOHJOFT ݄
8FC"TTFNCMZʢXBTNʣʁ w 8FCϒϥβ্Ͱಈ࡞͢ΔόΠφϦϑΥʔϚοτݴޠ w ଞݴޠ͔ΒίϯύΠϧͯ͠ੜ͢Δͷ͕Ұൠత w $$ ɺ3VTUɺ(Pɺ"TTFNCMZ4DSJQUɺʜ IUUQTHJUIVCDPNBQQDZQIFSBXFTPNFXBTNMBOHT w
ߴੑೳͰল༰ྔ w 4*.%ɺϚϧνεϨου wωΠςΟϒॲཧͱ8FCͷΪϟοϓΛຒΊΔ
&NTDSJQUFO w IUUQFNTDSJQUFOPSH w $$ UPBTNKT8FC"TTFNCMZίϯύΠϥ w .P[JMMB͕த৺Ͱ։ൃ w --7.ϕʔε
w MJCDɺMJCD ʢ ЋʣͷޓϨΠϠʔ w ϑΝΠϧγεςϜɺ$(ɺήʔϜΤϯδϯɺFUD
(FUUJOH4UBSUFEXJUI&NTDSJQUFO $ emcc -s EXTRA_EXPORTED_RUNTIME_METHODS='["ccall", "cwrap"]' \ -s EXPORTED_FUNCTIONS='["_twice"]' \
-s MODULARIZE=1 -s -o example.js example.c $ node main.js 4.4 1 double twice(double value) { 2 return value * 2; 3 } FYBNQMFD 1 const wasm = require('./example') 2 3 wasm().then((Module) => { 4 const twice = Module.cwrap('twice', 'number', ['number']) 5 console.log(twice(2.2)) 6 }) NBJOKT
$$ ʁ w ϝϦοτ w ߴ w ϨΠϠʔͷૢ࡞ w աڈͷࢿ࢈ͷ׆༻
w σϝϦοτ w ҆શੑ w पลπʔϧͷෆࡏ #FUUFS$ ͱͯ͠ͷ3VTU
3VTUʹΑΔ8FC"TTFNCMZͷग़ྗ w XBTNVOLOPXOFNTDSJQUFO w &NTDSJQUFOΛܦ༝ w &NTDSJQUFOͷϥϯλΠϜΛར༻Ͱ͖Δ w +BWB4DSJQUϒϥβ"1*ͱͷ࿈ܞ wXBTNVOLOPXOVOLOPXO
w ϥϯλΠϜͳ͠ʢܰྔ͕ͩ࠷খݶͷػೳ͚ͩʣ
4FUVQ $ curl https://sh.rustup.rs -sSf | sh $ source ~/.cargo/env
$ rustup default nightly $ rustup target add wasm32-unknown-unknown
Ϗϧυ $ cargo new --lib example $ cd example $
cargo build --target wasm32-unknown-unknown 1 [package] 2 name = "example" 3 version = "0.1.0" 4 authors = ["Yosuke Onoue <
[email protected]
>"] 5 6 [dependencies] 7 8 [lib] 9 crate-type = ["cdylib"] $BSHPUPNM 1 #[no_mangle] 2 pub fn twice(value: f64) -> f64 { 3 value * 2.0 4 } TSDMJCST
࣮ߦ 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta
charset="utf-8"/> 5 <title>Rust + WebAssembly Example</title> 6 </head> 7 <body> 8 <script> 9 fetch('./target/wasm32-unknown-unknown/debug/example.wasm') 10 .then((response) => response.arrayBuffer()) 11 .then((buffer) => WebAssembly.instantiate(buffer)) 12 .then(({ instance }) => { 13 const { twice } = instance.exports 14 console.log(twice(2.2)) 15 }) 16 </script> 17 </body> 18 </html> JOEFYIUNM
8FC"TTFNCMZ+4"1* w XBTNϑΝΠϧΛಡΈࠐΜͰ8FC"TTFNCMZJOTUBOUJBUF ʹ͢ w "SSBZ#V⒎FSΛ௨ͨ͡ϨΠϠʔͳૢ࡞ w /VNCFSʢɺϙΠϯλʣɺ5ZQFE"SSBZΛ ѻ͏ؔͷݺͼग़͠ͷΈ 9
fetch('./target/wasm32-unknown-unknown/debug/example.wasm') 10 .then((response) => response.arrayBuffer()) 11 .then((buffer) => WebAssembly.instantiate(buffer)) 12 .then(({ instance }) => { 13 const { twice } = instance.exports 14 console.log(twice(2.2)) 15 })
XBTNCJOEHFO w IUUQTSVTUXBTNHJUIVCJPXBTNCJOEHFO w 3VTUΦϒδΣΫτͱ+BWB4DSJQUΦϒδΣΫτͷ ૬ޓมϨΠϠʔΛఆٛͯࣗ͠ಈੜ w KTTZTɺXFCTZTʹΑΔ+BWB4DSJQUɺϒϥβ"1*ͷૢ࡞ w &NTDSJQUFOෆཁ
w XFCQBDLͰྑ͍ײ͡ʹಡΈࠐΈՄೳ DBSHPJOTUBMMXBTNCJOEHFODMJ
Ϗϧυ 1 extern crate wasm_bindgen; 2 3 use wasm_bindgen::prelude::*; 4
5 #[wasm_bindgen] 6 pub fn twice(value: f64) -> f64 { 7 value * 2.0 8 } TSDMJCST 1 [package] 2 name = "bindgen-example" 3 version = "0.1.0" 4 authors = ["Yosuke Onoue <
[email protected]
>"] 5 edition = "2018" 6 7 [dependencies] 8 wasm-bindgen = "0.2" 9 10 [lib] 11 crate-type = ["cdylib"] $BSHPUPNM $ wasm-bindgen --out-dir . target/wasm32-unknown-unknown/debug/bindgen_example.wasm
࣮ߦ 1 import('./bindgen_example').then(({ twice }) => { 2 console.log(twice(2.2)) 3
}) JOEFYKT 1 const path = require('path') 2 3 module.exports = { 4 entry: './index.js', 5 output: { 6 path: path.resolve(__dirname), 7 filename: 'bundle.js' 8 } 9 } XFCQBDLDPOpHKT 1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="utf-8"/> 5 <title>wasm-bindgen Example</title> 6 </head> 7 <body> 8 <script src="bundle.js"></script> 9 </body> 10 </html> JOEFYIUNM
ଞʹͰ͖Δ͜ͱ 15 #[wasm_bindgen] 16 pub struct Screen { 17 bytes:
Vec<u8>, 18 #[wasm_bindgen(readonly)] 19 pub width: usize, 20 #[wasm_bindgen(readonly)] 21 pub height: usize, 22 } 23 24 #[wasm_bindgen] 25 impl Screen { 26 #[wasm_bindgen(constructor)] 27 pub fn new(width: usize, height: usize) -> Screen { 28 Screen { 29 bytes: create_buffer(width, height), 30 width, 31 height, 32 } 33 } 34 42 43 pub fn resize(&mut self, width: usize, height: usize) { 44 self.bytes = create_buffer(width, height); 45 self.width = width; 46 self.height = height; 47 } 48 }
+BWB4DSJQUΫϥεͷੜ w 3VTUͷߏମɺUSBJU͔Β+BWB4DSJQUΫϥεΛੜ 1 const mod = import('mandelbrot') 2 const
bg = import('mandelbrot/mandelbrot_bg') 3 Promise.all([mod, bg]).then(([{ mandelbrot, Screen }, { memory }]) => { 4 const canvas = this.display.nativeElement; 5 const screen = new Screen(canvas.width, canvas.height); 6 7 const bytes = new Uint8ClampedArray(memory.buffer, screen.pointer(), screen.size()); 8 const image = new ImageData(bytes, screen.width, screen.height); 9 mandelbrot(screen, -3, -2, 0.01, 100); 10 11 const ctx = canvas.getContext('2d'); 12 ctx.putImageData(image, 0, 0); 13 })
XBTNQBDL w IUUQTSVTUXBTNHJUIVCJPXBTNQBDL w DBSHPͷUBSHFUՃɺϏϧυͷ࣮ߦɺOQNύοέʔ δͷੜɺ·ͰΛࣗಈԽ DBSHPJOTUBMMXBTNQBDL XBTNQBDLCVJME XBTNQBDLQVCMJTI
ͬͯΈͨ
ωοτϫʔΫՄࢹԽʹ͓͚Δར༻ w ωοτϫʔΫՄࢹԽʹ͏ܭࢉॲཧΛ8FC"TTFNCMZԽ %KTͷഒͷੑೳΛୡ w େنͳωοτϫʔΫͷՄࢹԽ8FCͰ࣮ݱʂ IUUQTFHSBQIMJLSMBCDPNHSPVQJOBCPY
"OHVMBS*POJDͱ͏
"OHVMBS *POJDͰͷϚϯσϧϒϩू߹ͷඳը IUUQTJPOJDXBTNNBOEFMCSPUMJLSMBCDPN
8FC"TTFNCMZͷࠓޙ
8FC"TTFNCMZͷࠓޙ w 1PTU.71'FBUVSFT w 5ISFBET w 4*.% w (BSCBHF$PMMFDUPS*OUFHSBUJPO w
FUD w πʔϧαϙʔτͷॆ࣮ w TPVSDFNBQQJOH
8FCͷύϑΥʔϚϯεΛٻ͢Δҙຯ ཁٻύϑΥʔϚϯε ԸܙΛड͚ΔϢʔβʔͷ ωΠςΟϒ σεΫτοϓΞϓϦ ͕Ͱ͖Δ͜ͱ ίϯϐϡʔλͷੑೳ্ ˍཧͷൃల 8FC͕Ͱ͖Δ͜ͱ -B[Z-PBEJOHɺ
ΦϑεϨουॲཧ ".1ɺ18" 8FC"TTFNCMZɺ ฒྻॲཧ ύϑΥʔϚϯεͷٻ͕ 8FCͷՄೳੑΛ͛Δ
·ͱΊ w ීٴஈ֊ʹਐΉ8FC"TTFNCMZ w 3VTUͰ҆શ͔ͭߴͳ8FC։ൃΛ͢Δ࣌ͷ౸དྷ w ύϑΥʔϚϯε͕8FCͷՄೳੑΛ͛Δʂ w ศརͳपลπʔϧΛੋඇνΣοΫʂ w
IUUQTSVTUXBTNHJUIVCJPXBTNCJOEHFO w IUUQTSVTUXBTNHJUIVCJPXBTNQBDL