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
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
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
【Cyber-sec+】経営層を"動かす"ための考え方
hssh2_bin
0
180
FDE という解 ― 暗黙知と明示知をつなぐ、伴走型エンジニアリング ―
otanet
0
160
LayerXにおけるセキュリティ管理の現在地と次の一手
tosho
0
180
アンオフィシャルな、オフィシャルからのお願い
wyamazak_devrel
0
110
RSA暗号を手計算したくなること、ありますよね?? (20260615_orestudy6_rsa)
thousanda
0
410
日本 Fintech 未来予測レポート 2027〜2028年(オリジナル版)
8maki
0
2.2k
【NRUG vol.18】KubernetesにおけるNew Relicデータ取得量削減の考え方
nrug_member
0
120
On-behalf-of Token exchange with AgentCore Identity
hironobuiga
2
200
フィジカル版Github Onshapeの紹介
shiba_8ro
0
230
Agent Skills設計で柔軟性と硬さのバランスが難しい話
nassy20
0
130
データサイエンスを価値につなげるプロジェクト設計 〜 DS一年目が現場で得た気づき 〜
ysd113
1
240
なぜ Platform Engineering の土台に Kubernetes を選ぶのか
r4ynode
2
640
Featured
See All Featured
Highjacked: Video Game Concept Design
rkendrick25
PRO
1
390
How GitHub (no longer) Works
holman
316
150k
Responsive Adventures: Dirty Tricks From The Dark Corners of Front-End
smashingmag
254
22k
The innovator’s Mindset - Leading Through an Era of Exponential Change - McGill University 2025
jdejongh
PRO
1
200
Become a Pro
speakerdeck
PRO
31
6k
The Illustrated Guide to Node.js - THAT Conference 2024
reverentgeek
1
380
WCS-LA-2024
lcolladotor
0
630
End of SEO as We Know It (SMX Advanced Version)
ipullrank
3
4.2k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
35
3.5k
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
35
2.5k
Redefining SEO in the New Era of Traffic Generation
szymonslowik
1
340
What's in a price? How to price your products and services
michaelherold
247
13k
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