Rust part20

■ このスレッドは過去ログ倉庫に格納されています
2023/03/03(金) 00:45:28.73ID:vTVY069B
公式
https://www.rust-lang.org/
https://blog.rust-lang.org/
https://github.com/rust-lang/rust

公式ドキュメント
https://www.rust-lang.org/learn

Web上の実行環境
https://play.rust-lang.org

※Rustを学びたい人はまず最初に公式のThe Bookを読むこと
https://doc.rust-lang.org/book/

※Rustを学ぶ際に犯しがちな12の過ち
https://dystroy.org/blog/how-not-to-learn-rust

※Rustのasyncについて知りたければ「async-book」は必読
https://rust-lang.github.io/async-book/

※次スレは原則>>980が立てること

前スレ
Rust part19
https://mevius.5ch.net/test/read.cgi/tech/1673926892/

ワッチョイスレ
プログラミング言語 Rust 4【ワッチョイ】
https://mevius.5ch.net/test/read.cgi/tech/1514107621/
2023/03/11(土) 12:39:50.82ID:WrUJ3YdB
Rustに限った話ではないがリファクタリングの良し悪しを判断するためには該当箇所を含む関数の全容(特に関数シグニチャ)とその関数を呼び出すコード例が最低限必要
関数シグニチャも呼び出すコードもない例では話にならない

呼び出し側が絶対変更できない前提なら前者だけでもいい場合があるが往々にして部分最適になりがち
>>130の例でも呼び出す側を考慮するとまた違った選択肢が見えてくる
2023/03/11(土) 12:48:32.01ID:Us0DtIzW
コーディング規約で早期リターンが推奨される開発現場であれば
その規約に準拠した表現が書きやすくなったのは良いこと
つうかそのつもりで読んでたから後者のほうが読みやすかったわ
2023/03/11(土) 13:41:29.57ID:+LV0PjS3
>>158
?とOptionとResultの影響があるから
他の言語よりも関数シグニチャーの持つ意味が余計に大きいように思う
2023/03/11(土) 14:09:20.55ID:zozTFx1B
隔離スレでやれ
2023/03/11(土) 20:53:29.08ID:YsMYadXT
https://qiita.com/namn1125/items/ccedf9cc06b8cef71557#let-else文のユースケース
この人が書いてるように?演算子のイディオムを踏襲してればlet-elseの出番は多くはない
逆に本来使うべきでないところでも乱用されやすいから注意が必要
2023/03/11(土) 23:05:55.56ID:ChsfUoNW
>>159
多くのところで言語に関わらずでifネストを深くせずに早期離脱をすることが好まれる
Rustではif let時にそれができなかったためlet else導入まではこうなってしまっていた
let foo = if let Some(foo) {
 foo
} else {
 (早期離脱前の処理があればここ)
 早期離脱
}
これはfooが三重に冗長で不格好
そのためlet else以前は早期離脱をあきらめる本末転倒なことも起きていた

具体的にlet elseが適している早期離脱は「範囲」が広い
・break
・continue
・エラー以外のreturn
・早期離脱前の処理があるエラーreturn

>>162
?が使える「範囲」はlet else より狭く早期離脱前の処理がないエラーreturnのみ
もちろん「量」は多いけどね
2023/03/12(日) 11:57:58.73ID:HouQiurI
カルパッチョ
2023/03/12(日) 12:41:14.42ID:UHnNkdpy
初見

VS code使い始めたんだが、カーソル移動系のショートカットキーの編集ってできないのか?
さくらEditorみたいにカーソル移動・ドラッグ編集を全部キーボードでやりたいんだが
2023/03/12(日) 12:42:40.81ID:C0R72d/J
なぜここできく
2023/03/12(日) 14:07:53.88ID:BVlbavKU
File > Preferences > Keyboard Shortcutsで設定画面開いて
cursorでフィルターかければcursorLeftみたいなコマンド出てくるから大体は変更できると思う
知らんけど
2023/03/12(日) 14:14:14.53ID:C6Uwumzj
vimでもemacsでもrust-analyzer動くよ
2023/03/12(日) 15:10:27.15ID:UHnNkdpy
>>166
プログラム板で一番勢いあるのここだから
2023/03/12(日) 16:06:30.84ID:nONlRGBh
大学生が書いたQiita記事のほうがこのスレの住民より要点おさえてるじゃんw
おまえらも見習えよ
2023/03/13(月) 11:54:44.62ID:38Ewlrdq
Qiitaは秀才だらけだし
5chム板は文字通り住民がrustだし
2023/03/16(木) 07:24:49.76ID:M0AuqK/y
>>162
その記事を読んでみたが漏れもあり
>>163のまとめで十分と思った
2023/03/16(木) 10:05:31.80ID:3ZknUEKY
複オジにいちいち突っ込むのは疲れたよ
>>163見れば素人だとすぐわかる
もう騙される人もいないから注意する必要もない
2023/03/16(木) 10:12:16.89ID:xtobTOZe
具体的に何が問題なの?
2023/03/16(木) 18:23:03.08ID:O0F78LdH
>>174
いつもの自演だろ。
真面目な話題はワッチョイスレにしようぜ。
2023/03/16(木) 18:54:09.77ID:sXsK9Uns
オジおじ言ってたら自演
スレ荒らしが目的
2023/03/17(金) 18:16:56.57ID:XLm6gsUd
こういうコードを書くとエラーになります。
Bar を実装しているのは &T であって T ではないからだというのはわかるのですが、
どういう形で書けばいいのかわかりません。
T そのものではなく &T が Bar を実装しているという制約はどう表現すればよいのでしょうか?

trait Bar {
fn func(&self) {}
}

fn baz<T>(x: &T)
where
T: Bar, // どう書けばいいの?
{
let a = x.func();
}

struct Foo {}
impl Bar for &Foo {}

fn main() {
baz(&Foo {});
}
2023/03/17(金) 19:14:05.96ID:NC4w42Nt
>>177
✕ impl Bar for &Foo {}
○ impl Bar for Foo {}
2023/03/17(金) 19:33:27.88ID:7IpB+MOB
>>178
それは変えられない前提の部分です。
制約の付け方 (where句の書き方) を質問しています。
2023/03/17(金) 19:35:54.06ID:NC4w42Nt
どうしてもimpl Bar for &Foo {}で行きたいなら
こうするしかない

trait Bar: Sized {
fn func(self) {}
}
fn baz<T>(x: T) where T: Bar,
2023/03/17(金) 19:56:30.88ID:TZnQdWAf
いやできるが……
fn baz<'a, T>(x: &'a T) where &'a T: Bar
2023/03/17(金) 19:59:29.44ID:XLm6gsUd
なるほど、寿命を省略できないのですね。
ありがとうございます。
2023/03/17(金) 20:06:51.73ID:kImSYq8C
>>182
Rustコンパイラからのエラーメッセージを見てる?
参照に対してライフタイム付けろと出ているはず
2023/03/17(金) 20:28:03.09ID:VjFaSUfW
寿命!
2023/03/17(金) 21:08:25.10ID:XLm6gsUd
>>183
答えを見たら全く自然なことだということは理解できるんですが
explicit lifetime というのがなんのことかすらぴんと来ない程度なんです……。
2023/03/18(土) 11:19:09.17ID:KAD/gYE9
>>185
Rustを学びたい人はまず最初に”公式”のThe Bookを読むこと
https://doc.rust-lang.org/book/
2023/03/18(土) 11:40:54.04ID:yS+7OZFn
>>186
>>177て”公式”のThe Bookに書いてあったっけ?
2023/03/18(土) 11:42:47.58ID:l9YNpI31
lifetime 周りは書いてあるだろ
2023/03/18(土) 11:53:17.34ID:VtoeVuok
>>188
>>181とかどこだっけ?
2023/03/18(土) 11:57:09.36ID:kHUlERx3
>>185
ライフタイムは全てにあるが省略できることが多い
省略できないときはコンパイラがエラーとし教えてくれるのでライフタイムを付ければいい

>>186
日本語版もある
https://doc.rust-jp.rs/book-ja/
2023/03/18(土) 14:05:24.60ID:PyzwqGcC
>>190
誤訳だらけの粗悪な非公式日本語訳はお勧めしない
簡単なエラーメッセージの意味も分からないような状態なんだからまずは公式The Bookをしっかり読むべき
2023/03/18(土) 16:08:20.29ID:QSo2KHpO
「非公式な日本語訳」を「日本語版」と呼称するのはそれがあたかも公式かのように錯覚させる意図が見えるので優良誤認の疑いがある
2023/03/18(土) 16:13:56.89ID:6WtXixvi
>>187
The Bookはクックブックじゃないからな
特定の方法が書いてるか書いてないかよりも
読んで理解してれば自己解決できる問題かどうかが重要
2023/03/18(土) 17:11:12.32ID:NQWJ1KgL
日本語訳の話題は生産的じゃないのでやめよう
このスレのローカルルールは>>37の通り
195177
垢版 |
2023/03/18(土) 18:27:39.58ID:XgD5JQEe
読んだのは日本語訳のほうの The book ですが、個々の機能はたぶん分かってると思います。
ライフタイムを省略した場合には一定のルールで補われることも知ってました。
ただ、型が満たすべき性質を書くのが where 句なので (エラーメッセージを見てすら!) ライフタイムが必要ということがぴんと来なかったというのと、
引数と同じ記法でライフタイムをここに書けるのだということがわからなかったんです。
2023/03/18(土) 18:38:31.92ID:l9YNpI31
> 引数と同じ記法でライフタイムをここに書けるのだということがわからなかったんです。
英語版でも日本語版でもどっちでもいいけど 10.3 にちゃんと書いてあるよ
2023/03/18(土) 19:09:39.09ID:YhY+O2tk
whereの:の左辺に参照とか書けるのをまず知らなかったんでしょ
the Bookにそんな例無いし
2023/03/18(土) 19:27:58.81ID:sUMBdqo8
日本語版を読まなければこんなことにはならなかった
日本語版を許すな
2023/03/19(日) 04:14:30.76ID:JYAaHQUF
>>183
ラストコンパイラって響きカッコいいな
2023/03/19(日) 13:06:57.80ID:j6t6IVCD
>>193
この場合に必要なのはクックブックだろ。
せめて>>196みたいに誘導しないと。

「読んで理解すれば自己解決できる」とか、そもそも読むところも示していないのにできるわけない。読み手を無視してマウントする自慰行為にしか見えん。
2023/03/19(日) 13:09:44.94ID:E3Ip09fl
そりゃ「個々の機能はたぶん分かってると思います」とか言われたら分かってねーじゃんって言いたくなるだろ
2023/03/19(日) 13:23:44.49ID:6gmOWdI+
>>196
where 句の制約で書いてる事例はないよ。
2023/03/19(日) 14:19:01.09ID:8hEI7b0p
>>200
訳の分からない日本語訳読んでわかったつもりになってるだけだからそう感じるんだよ
つべこべ言わずに全部読め
2023/03/19(日) 14:25:09.74ID:RMEG+oCh
>>202
grepだけじゃ答えは見つからない
読んでないから調べ方もわからない
2023/03/19(日) 20:29:29.27ID:Pq7wYRkP
>>203
順調に日本Rustは錆びているようですね。いや、めでたい。
2023/03/19(日) 20:49:16.05ID:UVlxeYfB
ちゃんとあるじゃん
https://doc.rust-jp.rs/book-ja/ch10-03-lifetime-syntax.html#%E3%83%A9%E3%82%A4%E3%83%95%E3%82%BF%E3%82%A4%E3%83%A0%E6%B3%A8%E9%87%88%E8%A8%98%E6%B3%95
207デフォルトの名無しさん
垢版 |
2023/03/19(日) 21:36:02.67ID:XN9u9qop
Rustはベンチマーク速いから気になってるんだけど
iPhoneやAndroidの開発で将来的に使えるようになる話はないの?
2023/03/19(日) 21:40:34.06ID:C8hzWYTf
ゴミだな
2023/03/19(日) 21:41:36.36ID:/nL/Z/hW
>>207
普通に使えるやろ
2023/03/19(日) 21:48:03.22ID:1LqNQBrB
>>177見て思うんだじぇど
ゆとり教育超大国日本ではゆとり脳な奴が多数になって
エラーがでたよ、でも、エラー内容は書かないようなコミュ力の低い奴が
普通になっているんかな。
2023/03/19(日) 22:05:41.03ID:pmaEpt3C
>>210
いくつか落ち度はあっても>>177は自分の考える最小限の再現可能なコードを提示してるからめっちゃくちゃマシな質問者
質問者としての偏差値63くらい
2023/03/19(日) 22:08:47.66ID:pmaEpt3C
5chでの偏差値ね
Stackoverflowだと47くらい
2023/03/19(日) 22:25:46.74ID:6gmOWdI+
>>207
ネイティブコンポーネントには Rust は使える。
Android の根本設計が Linux+JVM で、 JVM は変に高級な設計だからその高級な機能に噛み合うように設計された言語じゃないとうまくいかない。
LLVM バックエンドで JVM バイトコードを生成するものもあるらしいから無理すりゃ Rust でもなんとかなるかもしれないけど……
それよりも現在の情勢を見ると Android に WASM サブシステムが入るとかのほうがあり得そうな気がするよ。
2023/03/20(月) 00:55:07.77ID:rG0fuScP
自然言語自体に落ち度があると思った方がプログラミング言語の価値が分かりやすい
翻訳にも質問にもChatGPTにも過度の期待をしなくてすむ
2023/03/20(月) 01:31:12.77ID:OPxEUMsA
言語の問題と言語を扱うやつの問題を同一視するアホ
2023/03/20(月) 01:42:28.65ID:+AEvN8jR
正常動作する正規品を期待してたのに
不具合だらけで役に立たないジャンク品でした
2023/03/20(月) 02:15:13.67ID:rG0fuScP
はした金ではジャンク品しか買えない
インフレか
物価の問題と品質の問題のような二つの問題を無関係と考えるのがアホだったんじゃないか?
218デフォルトの名無しさん
垢版 |
2023/03/20(月) 03:09:08.81ID:KC0EWXje
prettierの代替のdprintがRust製だった
普及してるものがRust製に置き換わるってが今後も続くだろうね
2023/03/20(月) 03:46:46.02ID:8+GC48xI
>>217
ところが実際はジャンク品のほうが正規品より高いんだなこれが
正規品に見せかけて売ってるからいわゆるジャンク扱いではなく蓋を開けたらゴミでしたという落ち

でもありがたいことに今は購入前に中身を確認可能なのでよほどの情弱じゃなければ騙されないんだけどね
2023/03/20(月) 10:04:17.69ID:UnL767mB
>>217
物価の意味も知らんのかww
恥ずかしいから辞書引けよ
2023/03/20(月) 10:58:26.51ID:uuArbTr3
このあたりを読んでおけば大丈夫
Advanced Lifetimes
https://doc.rust-lang.org/1.30.0/book/second-edition/ch19-02-advanced-lifetimes.html
2023/03/20(月) 11:08:21.33ID:XflJK2ct
>JVM は変に高級な設計だからその高級な機能に噛み合うように設計された言語じゃないとうまくいかない。

相変わらずいい加減なこと書いてるなぁ
2023/03/20(月) 11:41:00.74ID:rG0fuScP
アプリもコンパイラも動くLinuxが正規品
コンパイラは不要とされアプリしか動かないLinuxがジャンク
2023/03/20(月) 11:59:59.11ID:IoVEULD8
>>223
GNUにケンカ売る気かよ
2023/03/20(月) 14:23:43.87ID:YI144KAX
Iterator<Item = Option>の時
filter(|o| o.is_some()).map(|o| o.unwrap()).map(|x| f(x))を
iflet(|Some(x)| f(x))みたいに1つにまとめてくれるメソッドある?
2023/03/20(月) 17:14:18.78ID:dpT4FG92
flattenとかflat_mapとかfilter_mapとか
2023/03/20(月) 19:58:13.92ID:EBVsuSrE
flat_mapはmap(f).flatten()の順だから無理だな
filter_mapはOption外しに使えるがmap(f)は別途必要
filter_map(|opt| opt).map(f) または参照なら
filter_map(Option::as_ref).map(f)
したがって正解はこれ
flatten().map(f)
228デフォルトの名無しさん
垢版 |
2023/03/20(月) 20:22:03.14ID:9WmeSXDj
flattenのOption/Resultはずし知らんかった
2023/03/20(月) 20:32:22.28ID:45aFG7he
>>227
どれでもできるぞ
初手で一番素直な選択はfilter_map
2023/03/20(月) 20:46:14.12ID:YI144KAX
flattenを使ってできました
let v = vec![None, Some((1, 2)), None, Some((3, 4)), None];
assert_eq!(14, v.iter().flatten().map(|(a, b)| a * b).sum());

>>229
filter_mapを使うと簡単ならば知りたいです
2023/03/20(月) 21:35:03.62ID:adpwtvX/
複オジかよっw
2023/03/20(月) 21:41:30.44ID:EBVsuSrE
前述したようにfilter_map自体のmapではOption外ししかできないので別途map(f)が必要になる
filter_map(|opt| opt).map(f)
あるいは
filter_map(|opt| opt.map(f))
簡単なのはflatten().map(f)
2023/03/20(月) 23:15:03.64ID:dBJpnlWY
flat_mapはfilter_mapを汎用化したものなので
filter_mapは常にflat_mapで書き直せる
flattenと理屈は同じ
2023/03/20(月) 23:20:21.79ID:I3aedYRP
唐突に妙に具体的な質問が飛んできたらあの人だと思ってればいい
2023/03/20(月) 23:20:56.30ID:c1bWUyRU
どの人だよ
2023/03/20(月) 23:49:46.77ID:K17OWm6q
>>234
いやー俺は今回まんまと騙されたわ
自演力と自画自賛力にステ振りすぎとちゃう?
2023/03/21(火) 00:12:49.49ID:lhwbZ9up
>>226 >>233
質問はOption列が対象のようだからflat_mapとfilter_mapは対象外やろ
それらはむしろOptionを作る関数を与えて使う
元から既にOptionになってるのだからflattenが正解
2023/03/21(火) 10:42:06.27ID:El4m1VCp
Someだけ拾って関数をmapすると考えれば
filter_map(|opt| opt.map(f))
だな
元のSome/Noneをそのまま利用するのがトリッキーかもしれないけど
2023/03/21(火) 11:33:54.48ID:aqrydfrP
ところで、ラムダには自由変数というものがありその反対が束縛変数だが
ラムダや自由変数を意識する必要がない文脈で束縛という用語が出ると
その語源を説明する手間がかかるよな
240デフォルトの名無しさん
垢版 |
2023/03/21(火) 13:02:51.29ID:3dx+Qi3k
scalaやっているせいかmatchとか
すごく使いやすいわん
iterator nextなんてJavaでも使わんけど
これ使い人いるの?
2023/03/21(火) 13:17:10.53ID:lhwbZ9up
>>240
nextはIterator全ての基礎
nextだけを定義すれば他のメソッドはnextで作られているので自動的に定義される
for文もnextを使っている
2023/03/21(火) 13:27:49.15ID:gPDO4YWu
>>238
入力から出力までのパイプラインの全体像を見ればトリッキーに感じることはないと思うよ
例えば>>230にあるvec![None, Some((1, 2)), None, Some((3, 4)), None];みたいなのはこれがすでに入力値に対して何かしら関数適用した結果なんだよね
2023/03/21(火) 13:35:41.08ID:lhwbZ9up
>>242
関数適用せずとも
None初期化配列やVecで一部indexにだけ値がSomeは普通によくあるパターン
2023/03/21(火) 14:20:03.57ID:El4m1VCp
元の入力で「値の有無」を表してたOptionをfilter_mapの「要素の残存判定」に転用する形だから
Optionの意味が微妙に変わってて引っ掛かる人もいるかなって思った
2023/03/21(火) 14:35:08.73ID:4Vr7UtW/
昔の言語だと配列に初期値として使っていないことを示すために-1とか0とかnullとかundefinedを入れてしまうことが多かったパターンか
いわゆるデータのnull安全性がなかったことろをRustはOptionのNoneとSome利用でnull安全性が保証
データが0にならならNonZeroを使えばNone時に0が使われて余分なメモリ消費もないしな
2023/03/21(火) 14:39:43.43ID:xxXQcN5m
隔離スレでやれ
https://mevius.5ch.net/test/read.cgi/tech/1677286186/
2023/03/21(火) 14:40:28.73ID:4Vr7UtW/
>>238
そこを出発点として考える場合でも
filter_map(|opt| opt.map(f))
↓ Optionのままmapしても剥がしてからmapしても同じ
filter_map(|opt| opt).map(f)
↓ Optionに対して恒等関数になってるのでflattenと同じ
flatten().map(f)
と辿り着く
2023/03/21(火) 17:23:17.80ID:El4m1VCp
>>247
自分は途中のイテレータ減らしたい派だから一番上で落ち着いてしまう
ラムダ式減らすなら下だろうけどfilter_mapが便利すぎてね…
2023/03/21(火) 18:14:49.79ID:lhwbZ9up
>>244
Optionは常に値の有無を表している
filter_mapも値の有無を残存判定に用いている
Optionの意味が変わることはない
2023/03/21(火) 19:05:07.54ID:Kxmr6Met
>>243
いかにも競プロっぽい考え方だね
現実のプログラムでは最低でも(K, V)で管理するから計算対象の値だけを素のOption配列で管理したりしないよ
2023/03/21(火) 19:18:56.96ID:8T+PSGNQ
>>250
インデックス値で管理できるものま無駄なコストがかかるハッシュマップでを用いる気軽な連想配列な考えこそコスト無視のスクリプト言語な考えだよ
インデックス値で管理できるものはRustでは配列かVecを使う
2023/03/21(火) 21:39:30.39ID:Hb26aB9L
HashMap<K, V>はhash計算コストに加えてkey比較コストがhash衝突回数の分かかるからなー
indexになれる値があって上限が許容されるならVecが有利
2023/03/21(火) 23:56:44.92ID:UIyRFaA6
>>250が経験不足と知識不足で知らなかったんでしょ
2023/03/22(水) 13:00:26.42ID:KFnwa6CM
>>251
おいおいなんで急にハッシュマップが出てくるんだよ
そんなんで大丈夫か?

Vec<Option<V>>みたいなデータがどこからともなく自然発生するわけないんだから全体のパイプラインを考えろって言ってるの
現実的かつ具体的なユースケースで考えような
2023/03/22(水) 18:31:25.27ID:KdbjtxZL
ナイーブなハッシュテーブルをVec<Option<T>>で実装する人はいるかもしれない
2023/03/22(水) 21:00:04.56ID:ax9KtLpr
うちも値域が限定されてる離散値はArrayかVec<Option<T>>使う
2023/03/22(水) 21:30:41.78ID:Bu7rNmu4
マニュアルに書いてるような内容をやたら饒舌に語るとChatGPT感出るね
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

ニューススポーツなんでも実況