公式
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 part22
https://mevius.5ch.net/test/read.cgi/tech/1705760500/
ワッチョイスレ
プログラミング言語 Rust 4【ワッチョイ】
https://mevius.2ch.net/test/read.cgi/tech/1514107621/
Rust part23
■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
2024/02/23(金) 17:37:52.13ID:CheDQupm2024/02/25(日) 16:19:05.44ID:5Lw05PSN
2024/02/25(日) 16:21:52.97ID:na8ub8Oh
いや煽ってきたのはお前だろw
何を勘違いしてるんだ
何を勘違いしてるんだ
2024/02/25(日) 16:23:31.57ID:na8ub8Oh
自分が攻撃するのは良くて攻撃されるのは嫌か?
そういうやつには徹底的にやるから覚悟しろよ
俺に攻撃するってことはそういうことだ
そういうやつには徹底的にやるから覚悟しろよ
俺に攻撃するってことはそういうことだ
72デフォルトの名無しさん
2024/02/25(日) 16:24:39.64ID:4fScDWQR 誰やねん
2024/02/25(日) 16:27:11.46ID:LjVpirDf
自分以外が全部同一人物だと思い込んでるアタオカの着火点は意味不明だよな
2024/02/25(日) 16:31:47.21ID:wVCQJTWx
2024/02/25(日) 16:36:11.19ID:sIg5Fob3
>>71 誰も攻撃してないのにこの人怖い、やめてくれませんか
心理的安全性を通り越して身の危険を感じる((((;゚Д゚))))ガクガクブルブル
心理的安全性を通り越して身の危険を感じる((((;゚Д゚))))ガクガクブルブル
76デフォルトの名無しさん
2024/02/25(日) 16:37:37.04ID:4fScDWQR 例の#25860、ジェネリクスとかマクロ生成の裏で意図しないでこのパターン踏んだりしない?
絶対ない?
絶対ない?
77デフォルトの名無しさん
2024/02/25(日) 16:37:39.99ID:muM7k3Ml rustでリファクタリングしながらの開発ってなると多分unsafeを途中経過で入れたりとか
そういうテクニックが必要になると思う。
その辺の整備が進めば割と広まるかもね。
そういうテクニックが必要になると思う。
その辺の整備が進めば割と広まるかもね。
2024/02/25(日) 16:45:35.35ID:wVCQJTWx
79デフォルトの名無しさん
2024/02/25(日) 16:50:17.61ID:4fScDWQR >>78
理由は?
理由は?
2024/02/25(日) 16:51:49.35ID:zhB6NxSY
2024/02/25(日) 16:52:52.76ID:hjrqLcFN
>>77
unsafeは基本的に不要
必要だと思ってもまず標準ライブラリにその機能がないか調べる
次にクレートにその機能がないか調べる
どこにも存在しない場合
unsafeを安全に閉じ込めて安全に使うことができる有用な機能を発見したのならばラッキー
それをクレートとして公開するとよい
unsafeは基本的に不要
必要だと思ってもまず標準ライブラリにその機能がないか調べる
次にクレートにその機能がないか調べる
どこにも存在しない場合
unsafeを安全に閉じ込めて安全に使うことができる有用な機能を発見したのならばラッキー
それをクレートとして公開するとよい
82デフォルトの名無しさん
2024/02/25(日) 17:06:44.48ID:4fScDWQR Rustコンパイラチームは意図せず発生する可能性を否定していない様子
ここのヤツはやっぱりテキトー言ってるだけか
https://hackmd.io/@rust-compiler-team/SkkrA1DCK#Variance
> https://github.com/rust-lang/rust/issues/25860
> root issue of most variance issues
> ⚠🚨⚠ can potentially just happen by accident
ここのヤツはやっぱりテキトー言ってるだけか
https://hackmd.io/@rust-compiler-team/SkkrA1DCK#Variance
> https://github.com/rust-lang/rust/issues/25860
> root issue of most variance issues
> ⚠🚨⚠ can potentially just happen by accident
2024/02/25(日) 17:26:51.68ID:O13egj5J
>>77
同じ構造体の一部を参照しながら別の一部を書き換える大きめのメソッドを
複数のメソッドに分割しようとするとborrow checkerに引っかかる的な話かな
他の言語のクラスと同じ感覚で構造体作るとたまに嵌る
Rustの構造体はRDBのテーブルを正規化する雰囲気で分割した方がいい
同じ構造体の一部を参照しながら別の一部を書き換える大きめのメソッドを
複数のメソッドに分割しようとするとborrow checkerに引っかかる的な話かな
他の言語のクラスと同じ感覚で構造体作るとたまに嵌る
Rustの構造体はRDBのテーブルを正規化する雰囲気で分割した方がいい
2024/02/25(日) 17:30:07.94ID:hjrqLcFN
>>82
Rustのvariance仕様だから発生させることはできるけど
現実に使うコードでは発生しない
意図的にその仕様の狭間をつく現実的でないコードでのみ発生する
そのためその2015年からそのまま放置で誰も困っていない
Rustのvariance仕様だから発生させることはできるけど
現実に使うコードでは発生しない
意図的にその仕様の狭間をつく現実的でないコードでのみ発生する
そのためその2015年からそのまま放置で誰も困っていない
85デフォルトの名無しさん
2024/02/25(日) 17:45:11.19ID:4fScDWQR >>84
by accidentを辞書で引いてこい
by accidentを辞書で引いてこい
2024/02/25(日) 17:51:15.22ID:hjrqLcFN
2024/02/25(日) 17:55:53.01ID:bLJeGl/a
>>81
>unsafeは基本的に不要
>...ラッキー
嘘で始まって運頼みで締めるとはw
信者の心の支えの大手のあそこは
見境なくunsafeを使わざるを得なくなって
Rustでやった意味が無くなってるってよ
>unsafeは基本的に不要
>...ラッキー
嘘で始まって運頼みで締めるとはw
信者の心の支えの大手のあそこは
見境なくunsafeを使わざるを得なくなって
Rustでやった意味が無くなってるってよ
2024/02/25(日) 17:56:42.46ID:m/LZ7YZH
可能性を論じるならお前の頭に隕石が落ちてくる可能性だってあるが、そんなことを心配したことある?
2024/02/25(日) 18:03:36.71ID:c6Ww7brW
RustはVec等のCVE前科があるからなぁ
頭に隕石が落ちたんじゃね?
頭に隕石が落ちたんじゃね?
2024/02/25(日) 18:07:11.51ID:e56nXER6
開発プログラムでunsafeを直接使うことはほとんどない
unsafeが閉じ込められ安全なインターフェースが公開されている形で間接的にのみ用いる
どうしてもunsafeが必要になった場合でもそのように安全な形で分離して用いる
unsafeが閉じ込められ安全なインターフェースが公開されている形で間接的にのみ用いる
どうしてもunsafeが必要になった場合でもそのように安全な形で分離して用いる
91デフォルトの名無しさん
2024/02/25(日) 18:10:03.77ID:4fScDWQR 隕石であれ何であれそれがエンジニアリング可能な対象なら問題を特定して語る意味はあるだろう
2024/02/25(日) 18:19:05.40ID:e56nXER6
>>89
Dropで型がpanicする時にその要素をた用いたVec::from_iter()で二重解放のバグが発見された件か
もちろん他の言語と同様に全ての言語においてライブラリにバグが見つかることは当然ある
Rustはその点でも少ない方なので信頼して使える
Dropで型がpanicする時にその要素をた用いたVec::from_iter()で二重解放のバグが発見された件か
もちろん他の言語と同様に全ての言語においてライブラリにバグが見つかることは当然ある
Rustはその点でも少ない方なので信頼して使える
2024/02/25(日) 18:30:56.08ID:F3hFw1lw
2024/02/25(日) 18:43:22.50ID:hlYoDW1g
Rustの2023年のCVEはCargoで名前をエスケープし忘れた1件のみ
Rustの2022年のCVEは0件
つまりRustコンパイラについて過去2年間でCVEなし
信頼度が高いと言える
Rustの2022年のCVEは0件
つまりRustコンパイラについて過去2年間でCVEなし
信頼度が高いと言える
95デフォルトの名無しさん
2024/02/25(日) 18:49:05.16ID:cAT3nYdz Rust以外のコンパイラってそんな言うほどバグないか?
2024/02/25(日) 19:34:08.90ID:O13egj5J
普通にあるけどみんなで使うから大部分はリリース前に潰される
コンパイラというよりライブラリのバグみたいだけど他の言語より未定義動作にシビアだから
バグ扱いされる事例が増えるのは仕方ない
コンパイラというよりライブラリのバグみたいだけど他の言語より未定義動作にシビアだから
バグ扱いされる事例が増えるのは仕方ない
97デフォルトの名無しさん
2024/02/25(日) 19:46:15.91ID:pvICb5ke2024/02/25(日) 19:49:21.58ID:+aJmKKn5
今となっては未定義動作の多い言語を使うのは悪行だ
Rustを使うべし
Rustを使うべし
2024/02/25(日) 20:11:25.55ID:yYiD0TuW
100デフォルトの名無しさん
2024/02/25(日) 20:15:02.43ID:yYiD0TuW101デフォルトの名無しさん
2024/02/25(日) 20:24:50.38ID:0y8maAN+102デフォルトの名無しさん
2024/02/25(日) 21:16:46.71ID:4fScDWQR 事実を書かれただけで批判だと思っちゃうようじゃ生きづらかろうな
103デフォルトの名無しさん
2024/02/25(日) 21:34:47.98ID:E/2LoMBL >>101
これが矮小化と言うやつか
7割がバグ潰しを「最優先」と回答している事実
直したくても直せないまま何年も経過、unsafe無しでメモリ安全ではない(事実)、Rustの不健全仕様(事実)
(unsound=不健全は数学用語、要は矛盾があるという事)
幸運にもRustが使われなさ過ぎで実害がないように見える(または報告がないだけ)
(良心的に考えてRustが広く使われてない内に)バグ潰しをしとけ、がユーザーの9割の意見(中優先含めて)
週明けのテック記事はどう書くのかな
良い所だけ抜き出してビューが取れるハイプ期間は弱まったと思う
それと飛ばし過ぎるといなくなるorz
これが矮小化と言うやつか
7割がバグ潰しを「最優先」と回答している事実
直したくても直せないまま何年も経過、unsafe無しでメモリ安全ではない(事実)、Rustの不健全仕様(事実)
(unsound=不健全は数学用語、要は矛盾があるという事)
幸運にもRustが使われなさ過ぎで実害がないように見える(または報告がないだけ)
(良心的に考えてRustが広く使われてない内に)バグ潰しをしとけ、がユーザーの9割の意見(中優先含めて)
週明けのテック記事はどう書くのかな
良い所だけ抜き出してビューが取れるハイプ期間は弱まったと思う
それと飛ばし過ぎるといなくなるorz
104デフォルトの名無しさん
2024/02/25(日) 21:37:20.20ID:PFD3HMoN アンチもMozillaが変なことやってるだけで
firefoxに導入できるわけがない一般人が
使えるようになるのは妄想とか
言ってた頃に比べると細かい実装の穴を
ネチネチやるまでになって大変だなあ
firefoxに導入できるわけがない一般人が
使えるようになるのは妄想とか
言ってた頃に比べると細かい実装の穴を
ネチネチやるまでになって大変だなあ
105デフォルトの名無しさん
2024/02/25(日) 22:03:27.18ID:cpTMj4Oj >>103
根本的なことを理解できてないようなので一点だけ
unsafeがプログラム全体に散らばっている他の言語に対して
Rustはunsafeを局所的に閉じ込めて安全なインタフェイスを公開しそれを使ってプログラミングする言語
よく使われる基本機能は標準ライブラリとしてunsafeを閉じ込めてあるが
必要なら自作を含めてunsafeを閉じ込めたライブラリを使ってよい
他の言語と比べてunsafeを局所的に閉じ込めた部分のみ注視すればよいことがRustのメリット
根本的なことを理解できてないようなので一点だけ
unsafeがプログラム全体に散らばっている他の言語に対して
Rustはunsafeを局所的に閉じ込めて安全なインタフェイスを公開しそれを使ってプログラミングする言語
よく使われる基本機能は標準ライブラリとしてunsafeを閉じ込めてあるが
必要なら自作を含めてunsafeを閉じ込めたライブラリを使ってよい
他の言語と比べてunsafeを局所的に閉じ込めた部分のみ注視すればよいことがRustのメリット
106デフォルトの名無しさん
2024/02/25(日) 22:16:32.90ID:uv4EdbLT >>105
unsafeに閉じ込められなかった事実を提示されてるんだが何言ってるんだ?
unsafeに閉じ込められなかった事実を提示されてるんだが何言ってるんだ?
107デフォルトの名無しさん
2024/02/25(日) 22:32:50.41ID:cAT3nYdz Rustコンパイラにバグがあるのはかなりキモくて嫌だけど、Rustの利用をやめるほど致命的かというとな
108デフォルトの名無しさん
2024/02/25(日) 22:47:36.07ID:m/LZ7YZH C++ の未定義を踏んでもおかまいなしってよりは原則として問題は検出する (けどちょっとはバグもある) Rust のほうがだいぶんマシな言語設計ではある。
109デフォルトの名無しさん
2024/02/25(日) 23:03:18.85ID:AXW02Nd1 unsafeなライブラリがRust用の安全なインターフェースを公開することにより保証される安全性とは
もちろん呼び出される側の安全性ではない
呼び出す側だけが検査される
しかも検査が完璧かどうかは実装依存
じゃあ言語仕様により保証されるのは何か
言語仕様は、あとは検査が通るか通らないかを確かめればよいというところまで仕様を確定しなければならない
もちろん呼び出される側の安全性ではない
呼び出す側だけが検査される
しかも検査が完璧かどうかは実装依存
じゃあ言語仕様により保証されるのは何か
言語仕様は、あとは検査が通るか通らないかを確かめればよいというところまで仕様を確定しなければならない
110デフォルトの名無しさん
2024/02/25(日) 23:10:45.79ID:Wz/bOaUk プログラム全体がunsafeなC/C++は使いたくない
未定義な動作も多すぎる
未定義な動作も多すぎる
111デフォルトの名無しさん
2024/02/25(日) 23:49:12.62ID:bSwN5N4x112デフォルトの名無しさん
2024/02/26(月) 00:02:36.23ID:cKYYV9zq 反論できないときは関連するワードを含むRustの宣伝文句をぶつける
いつもの流れです
いつもの流れです
113デフォルトの名無しさん
2024/02/26(月) 00:08:01.38ID:GUFKxV6c 難易度は高くとも増加するユーザー、Rustチーム2023年調査「State of Rust Survey」 難易度は高くとも増加するユーザー、Rustチーム2023年調査「State of Rust Survey」
https://news.mynavi.jp/techplus/article/20240222-2889545/
https://news.mynavi.jp/techplus/article/20240222-2889545/
114デフォルトの名無しさん
2024/02/26(月) 00:10:06.79ID:nyM0yI5t115デフォルトの名無しさん
2024/02/26(月) 05:11:35.79ID:G5weOmRY >>前スレ992
Derefは演算子
・そのためstd::ops::Derefにある (変換std::convert::AsRefと対照的)
・演算子*によりderefされる
・&**へとcoerceされる
Derefは演算子
・そのためstd::ops::Derefにある (変換std::convert::AsRefと対照的)
・演算子*によりderefされる
・&**へとcoerceされる
116デフォルトの名無しさん
2024/02/26(月) 13:22:06.51ID:vLFZOOEE Derefの名前の由来は*演算子(dereference:参照解決)だろうけど
機能は&**へのcoerceを前提にしてて結果的にrefのままだからややこしいな
現状だとInnerRefの方がしっくりくる
機能は&**へのcoerceを前提にしてて結果的にrefのままだからややこしいな
現状だとInnerRefの方がしっくりくる
117デフォルトの名無しさん
2024/02/26(月) 13:34:26.79ID:vLFZOOEE 意味的にはFollowRefの方が自然かな
まあ*演算子で使われるtraitだからDerefでいいんだけど
まあ*演算子で使われるtraitだからDerefでいいんだけど
118デフォルトの名無しさん
2024/02/26(月) 17:12:18.82ID:hotfpUjh 【AI】Stable Diffusion 3発表、Soraで話題の拡散トランスフォーマーを採用 [すらいむ★]
http://egg.5ch.net/test/read.cgi/scienceplus/1708865670/l50
ボイス・トォ・スカるしている者も攻撃を受けるようになりました
http://egg.5ch.net/test/read.cgi/scienceplus/1708865670/l50
ボイス・トォ・スカるしている者も攻撃を受けるようになりました
119デフォルトの名無しさん
2024/02/26(月) 18:21:55.22ID:K4z1iUSz120デフォルトの名無しさん
2024/02/26(月) 19:05:39.95ID:CpQkWMmQ Rustて、演算子と関数を(意味論的に)区別していたっけ?
中間記法によるややこしい結合順の違いがあるぐらいで、構文解析後は等価だから、あんまりこだわっても仕方が無い気が。
中間記法の演算子は人間の算数の記法に配慮しているだけの悪習でしか無いから、積極的に差異をつけないほうが良い気がするけど。
中間記法によるややこしい結合順の違いがあるぐらいで、構文解析後は等価だから、あんまりこだわっても仕方が無い気が。
中間記法の演算子は人間の算数の記法に配慮しているだけの悪習でしか無いから、積極的に差異をつけないほうが良い気がするけど。
121デフォルトの名無しさん
2024/02/26(月) 19:26:28.00ID:pFLZLcAJ Deref に関しては * 演算子として機能する以外に型強制の規則があるという話の文脈。
122デフォルトの名無しさん
2024/02/26(月) 19:44:24.36ID:vLFZOOEE +に対するAdd, &=に対するBitAndAssignと同じ位置づけで
(*T)に対するDerefがstd::opsに入ってるイメージだけど
(*T)自体は
let x: Box<String> = Box::new(String::from("foo"));
let y: String = *x;
みたいに参照先の値を取り出す使い方ができてむしろそっちが本来の意味なのに
それができないtrait DerefがDerefを名乗ってるのが微妙だと思った
(*T)に対するDerefがstd::opsに入ってるイメージだけど
(*T)自体は
let x: Box<String> = Box::new(String::from("foo"));
let y: String = *x;
みたいに参照先の値を取り出す使い方ができてむしろそっちが本来の意味なのに
それができないtrait DerefがDerefを名乗ってるのが微妙だと思った
123デフォルトの名無しさん
2024/02/26(月) 19:45:57.01ID:CpQkWMmQ124デフォルトの名無しさん
2024/02/26(月) 19:57:36.80ID:31wdHwrp125デフォルトの名無しさん
2024/02/26(月) 20:43:46.74ID:YO//rx0m 関数と同じでは困るものといえば && || が有名だけど = が一番やばい
初期化とか代入とかコピーとか移動とか
初期化とか代入とかコピーとか移動とか
126デフォルトの名無しさん
2024/02/26(月) 20:52:21.27ID:isya6kWo127デフォルトの名無しさん
2024/02/26(月) 21:10:51.91ID:ucgwnOih Rustにおける = は心の中でバインド演算子って呼んでるわ
128デフォルトの名無しさん
2024/02/27(火) 01:03:26.56ID:38wv4xDP >>124
>Derefはoperatorなのでstd::opsにある
https://doc.rust-lang.org/std/ops/index.html
ここ見ればわかると思うけど各Traitの説明に”The ~ operator”と書いてるものがoperator
Derefは”Used for immutable dereferencing operations, like *v.”とあるようにDerefそのものはoperatorではない
>Derefでも&T→Tと実装されている
Deref<Target=T> for &Tの実装が提供されてるのは別の役割のため
その実装が実行されて&T→Tになっているのではない
Box<T>→Tなんかも正確に言えば&Box<T>→&T
>Derefによるcoerceは&**となる
全然わからない
何か一つくらい根拠を提示してくださいな
>Derefはoperatorなのでstd::opsにある
https://doc.rust-lang.org/std/ops/index.html
ここ見ればわかると思うけど各Traitの説明に”The ~ operator”と書いてるものがoperator
Derefは”Used for immutable dereferencing operations, like *v.”とあるようにDerefそのものはoperatorではない
>Derefでも&T→Tと実装されている
Deref<Target=T> for &Tの実装が提供されてるのは別の役割のため
その実装が実行されて&T→Tになっているのではない
Box<T>→Tなんかも正確に言えば&Box<T>→&T
>Derefによるcoerceは&**となる
全然わからない
何か一つくらい根拠を提示してくださいな
129デフォルトの名無しさん
2024/02/27(火) 01:17:48.86ID:keoFxKh8 Derefによるcoerceは&**となるのが全然わからないって本気なのかな?
「corece後の参照」= &**「corece前の参照」
となるのがDerefによるcoerceだよ
「corece後の参照」= &**「corece前の参照」
となるのがDerefによるcoerceだよ
130デフォルトの名無しさん
2024/02/27(火) 03:35:57.72ID:Q3TDZDiV READ THE FUCKING MANUAL
https://doc.rust-lang.org/beta/reference/type-coercions.html#coercion-types
https://doc.rust-lang.org/beta/reference/type-coercions.html#coercion-types
131デフォルトの名無しさん
2024/02/27(火) 05:16:27.87ID:2XUMNloz132デフォルトの名無しさん
2024/02/27(火) 08:57:02.46ID:+775Shg6 上の一連の流れ見てるだけでRustしんどそうに見える
133デフォルトの名無しさん
2024/02/27(火) 10:40:40.53ID:90WdzyYj >>129
なるほどそういう風に捉えてるのか
ちょっと独特だね
それはcoercionの動きというよりderefのシグニチャを
内部的にderefを使ってる*演算子で再定義しようとしてるので
循環が気持ち悪いけど一つの見方として頭の隅にしまっておく
ちなみにThe Bookにある一つの例ではderef coercionがなければ*が余計に必要と説明されてる
https://doc.rust-lang.org/book/ch15-02-deref.html#implicit-deref-coercions-with-functions-and-methods
それに&**とは必ずしも等価じゃないからDeref Coercionを説明するのにはあまり勧められないかな
let x = "Hello".to_string();
let y = Box::new(x);
let z = &**y; //zは&strになる
let z:&str = y; //これはcoerceしないのでコンパイルエラー
なるほどそういう風に捉えてるのか
ちょっと独特だね
それはcoercionの動きというよりderefのシグニチャを
内部的にderefを使ってる*演算子で再定義しようとしてるので
循環が気持ち悪いけど一つの見方として頭の隅にしまっておく
ちなみにThe Bookにある一つの例ではderef coercionがなければ*が余計に必要と説明されてる
https://doc.rust-lang.org/book/ch15-02-deref.html#implicit-deref-coercions-with-functions-and-methods
それに&**とは必ずしも等価じゃないからDeref Coercionを説明するのにはあまり勧められないかな
let x = "Hello".to_string();
let y = Box::new(x);
let z = &**y; //zは&strになる
let z:&str = y; //これはcoerceしないのでコンパイルエラー
134デフォルトの名無しさん
2024/02/27(火) 10:44:06.64ID:HDl/V1Sy こんな議論が発生する時点でかなりややこしくて面倒な言語がであることは認めざるを得ない
135デフォルトの名無しさん
2024/02/27(火) 11:23:28.24ID:gx7SRESn そんなことよりDerefの定義の中で参照外ししている↓が無限ループにならない理由でも調べてみたほうが面白いよ
https://doc.rust-lang.org/src/alloc/boxed.rs.html#1927
https://doc.rust-lang.org/src/alloc/boxed.rs.html#1927
136デフォルトの名無しさん
2024/02/27(火) 11:27:25.60ID:90WdzyYj >>135
それが&T→TはDerefの役割ではないという話
それが&T→TはDerefの役割ではないという話
137デフォルトの名無しさん
2024/02/27(火) 11:56:56.99ID:xI+UYr05 rustは使い勝手のために暗黙にokにした構文が逆にわかりづらさを生んでる。
138デフォルトの名無しさん
2024/02/27(火) 12:07:27.17ID:NfALWDmT139デフォルトの名無しさん
2024/02/27(火) 12:18:37.87ID:Q3TDZDiV >>136
*selfはそれでいいけど、**selfはそれじゃ説明付かんぞ
*selfはそれでいいけど、**selfはそれじゃ説明付かんぞ
140デフォルトの名無しさん
2024/02/27(火) 17:59:37.59ID:KfBq61Mu >>139
&T→Tと同じでBox<T>に対する*演算子もコンパイラビルトインだからDerefのimplは使われない
&T→Tと同じでBox<T>に対する*演算子もコンパイラビルトインだからDerefのimplは使われない
141デフォルトの名無しさん
2024/02/27(火) 18:12:58.39ID:lr8nToMg Rustってなんでzipを「簡単」に操作するクレートが一つもないんだ?
Tauriがこなれてきたからそろそろ.NETからアプリをRustにポーティングしようかなと思ったらエコシステムがまるで成長していない・・・
Tauriがこなれてきたからそろそろ.NETからアプリをRustにポーティングしようかなと思ったらエコシステムがまるで成長していない・・・
142デフォルトの名無しさん
2024/02/27(火) 18:13:56.86ID:7nYMkiDR >>133
まず基本を理解しよう
deref coreceは必ず参照から参照へのみ起きる
Box自体は当然deref coreceされない
その例だと
let b = Box::new("Hello".to_string());
まずc0は単なるBox参照
let c0: &Box<String> = &b;
このc1とc2がderef corece
let c1: &String = &b;
let c2: &str = &b;
そのc1とc2を明示的に書くとこうなる
let c1: &String = &**(&b);
let c2: &str = &**(&**(&b));
この暗黙に適用される&**がderef corece
この自動適用のおかげでstrのメソッドが使える
assert!(b.starts_with("He"));
フルに書くとこうでもちろん対象はbではなく&b
assert!(str::starts_with(&b, "He"));
この&bが前述の通り自動的に&**(&**(&b))となり&str型へcoreceされている
まず基本を理解しよう
deref coreceは必ず参照から参照へのみ起きる
Box自体は当然deref coreceされない
その例だと
let b = Box::new("Hello".to_string());
まずc0は単なるBox参照
let c0: &Box<String> = &b;
このc1とc2がderef corece
let c1: &String = &b;
let c2: &str = &b;
そのc1とc2を明示的に書くとこうなる
let c1: &String = &**(&b);
let c2: &str = &**(&**(&b));
この暗黙に適用される&**がderef corece
この自動適用のおかげでstrのメソッドが使える
assert!(b.starts_with("He"));
フルに書くとこうでもちろん対象はbではなく&b
assert!(str::starts_with(&b, "He"));
この&bが前述の通り自動的に&**(&**(&b))となり&str型へcoreceされている
143デフォルトの名無しさん
2024/02/27(火) 18:33:30.42ID:p5E54fv2144デフォルトの名無しさん
2024/02/27(火) 19:01:36.79ID:MCZ6xJKz145デフォルトの名無しさん
2024/02/27(火) 19:26:56.87ID:kSGISY6y Rustもちょっと前の熱狂はなくなってしまった感じ
入込数が減ってると思う
入込数が減ってると思う
146デフォルトの名無しさん
2024/02/27(火) 19:39:57.60ID:ptyRkm62 まあ熱狂系の人は実用言語嫌いそうだし、熱狂系がいなくなったのは良いことでは
147デフォルトの名無しさん
2024/02/27(火) 19:51:34.77ID:gLAGJv50 >>144
発音[US] kouə́ːrʒən | [UK] kouə́ːʃən
カナ[US]コウアァジョン、[UK]コウアーション
参考:https://eow.alc.co.jp/search?q=coercion
自分はコアジョン派
発音[US] kouə́ːrʒən | [UK] kouə́ːʃən
カナ[US]コウアァジョン、[UK]コウアーション
参考:https://eow.alc.co.jp/search?q=coercion
自分はコアジョン派
148デフォルトの名無しさん
2024/02/27(火) 20:18:10.37ID:p5E54fv2 >>144
コアーション派
コアーション派
149デフォルトの名無しさん
2024/02/27(火) 20:23:00.40ID:20aYglde >>147
サンクス。愛してる
サンクス。愛してる
150デフォルトの名無しさん
2024/02/27(火) 21:54:58.65ID:Tx+RemT0 Tのスマートポインタの参照 -> Tの参照
文字の配列の参照 -> 文字のスライス
一連の流れを見るとみんなポインタに熱狂している
文字の配列の参照 -> 文字のスライス
一連の流れを見るとみんなポインタに熱狂している
151デフォルトの名無しさん
2024/02/27(火) 22:22:03.42ID:TDjpaGuA >>150
そこはポインタと参照の根本的な違いを理解しできるかどうかかな
「Boxというスマートポインタ」の参照を扱うから意外に感じているのかもしれないが
「Boxというスマートポインタ」はヒープ領域の解放責任つまり所有権を持つ
したがってBox自体を他の関数などへ渡してしまってはmoveしてしまい継続して使えなくなる
だからスマートポインタの参照を渡すことになる
一見するとこれはポインタのポインタで無駄な間接参照に感じるかもしれない
しかし参照=ポインタではなく参照は抽象的なものなのだ
そこはポインタと参照の根本的な違いを理解しできるかどうかかな
「Boxというスマートポインタ」の参照を扱うから意外に感じているのかもしれないが
「Boxというスマートポインタ」はヒープ領域の解放責任つまり所有権を持つ
したがってBox自体を他の関数などへ渡してしまってはmoveしてしまい継続して使えなくなる
だからスマートポインタの参照を渡すことになる
一見するとこれはポインタのポインタで無駄な間接参照に感じるかもしれない
しかし参照=ポインタではなく参照は抽象的なものなのだ
152デフォルトの名無しさん
2024/02/27(火) 22:43:38.35ID:NfALWDmT Rust の参照は借用規則に関わることを除けばポインタとそんなに差はないし普通にオブジェクトの一種なんだよな。
C++ の参照はオブジェクトではなく参照の参照もとれないし参照のポインタもないし、
参照のサイズも取得できないというのに比べたら Rust の参照は実体のあるものとして感じられてしまう。
C++ の参照はオブジェクトではなく参照の参照もとれないし参照のポインタもないし、
参照のサイズも取得できないというのに比べたら Rust の参照は実体のあるものとして感じられてしまう。
153デフォルトの名無しさん
2024/02/27(火) 22:57:53.18ID:FQe9Y4YD その橋渡し役がDeref coercion
&Box<T>はそのままだとTのポインタを持つBoxへのポインタとなってしまうが
Box<T>→TのDerefがあるため
&Box<T>→&TとDeref coercionが適用できる
静的にコンパイル時点で行われるため実行時コストはかからない
&Box<T>はそのままだとTのポインタを持つBoxへのポインタとなってしまうが
Box<T>→TのDerefがあるため
&Box<T>→&TとDeref coercionが適用できる
静的にコンパイル時点で行われるため実行時コストはかからない
154デフォルトの名無しさん
2024/02/27(火) 23:09:15.00ID:xLBlGeUv155デフォルトの名無しさん
2024/02/27(火) 23:37:04.57ID:IkmURqSK >>142
>deref coreceは必ず参照から参照へのみ起きる
&**との違いを認識してもらうための例を出したんだけど伝わらなかったみたいだね
それは別にいいんだけど書いてる内容を見る限り
Deref Coercionの動きを単に擬似的に再定義しようとして&**になると言ってるだけじゃなく
実際に&**が適用されると思ってるみたいに感じるね
だとしたらそれは完全な間違い
derefの実装の中で*演算子が使われることはあってもDeref Coercion自体は*演算子とは関係ないんだよ
Boxのderef実装だって*演算子を使わずself.ptr.as_ref()的な実装で実現してもいいわけだし
>deref coreceは必ず参照から参照へのみ起きる
&**との違いを認識してもらうための例を出したんだけど伝わらなかったみたいだね
それは別にいいんだけど書いてる内容を見る限り
Deref Coercionの動きを単に擬似的に再定義しようとして&**になると言ってるだけじゃなく
実際に&**が適用されると思ってるみたいに感じるね
だとしたらそれは完全な間違い
derefの実装の中で*演算子が使われることはあってもDeref Coercion自体は*演算子とは関係ないんだよ
Boxのderef実装だって*演算子を使わずself.ptr.as_ref()的な実装で実現してもいいわけだし
156デフォルトの名無しさん
2024/02/27(火) 23:45:58.16ID:Tx+RemT0 とにかく、間接参照から直接参照を得る演算の名前はderefでいいんだよね
157デフォルトの名無しさん
2024/02/27(火) 23:58:10.03ID:cJjIIFX3 Derefは*
Deref coercionは&**
前者は明示が必要な点が違い
x: &Box<T> とすると
*x: Box<T> (by Deref &T→T)
**x: T (by Deref Box<T>→T)
&**x: &T (xのDeref coercion結果)
x: &Vec<T> とすると
*x: Vec<T> (by Deref &T→T)
**x: [T] (by Deref Vec<T>→[T])
&**x: &[T] (xのDeref coercion結果)
x: &String とすると
*x: String (by Deref &T→T)
**x: str (by Deref String→str)
&**x: &str (xのDeref coercion結果)
Deref coercionは&**
前者は明示が必要な点が違い
x: &Box<T> とすると
*x: Box<T> (by Deref &T→T)
**x: T (by Deref Box<T>→T)
&**x: &T (xのDeref coercion結果)
x: &Vec<T> とすると
*x: Vec<T> (by Deref &T→T)
**x: [T] (by Deref Vec<T>→[T])
&**x: &[T] (xのDeref coercion結果)
x: &String とすると
*x: String (by Deref &T→T)
**x: str (by Deref String→str)
&**x: &str (xのDeref coercion結果)
158デフォルトの名無しさん
2024/02/28(水) 00:29:07.11ID:ZZ90UZAT >>157
とりあえずDerefの定義が
pub trait Deref {
type Target: ?Sized;
// Required method
fn deref(&self) -> &Self::Target;
}
(https://doc.rust-lang.org/std/ops/trait.Deref.html)
でderef()の戻り値には自動的に&がつくから
*x: Box<T>
*x: Vec<T>
*x: String
はDeref traitと関係ないことを抑えておこう
そこに(by Deref…)を書かれると話がおかしくなる
*Tができることの一部をDeref traitではできない
正確な表現かは分からないけどDerefは&の向こう側でしか*を適用できない
とりあえずDerefの定義が
pub trait Deref {
type Target: ?Sized;
// Required method
fn deref(&self) -> &Self::Target;
}
(https://doc.rust-lang.org/std/ops/trait.Deref.html)
でderef()の戻り値には自動的に&がつくから
*x: Box<T>
*x: Vec<T>
*x: String
はDeref traitと関係ないことを抑えておこう
そこに(by Deref…)を書かれると話がおかしくなる
*Tができることの一部をDeref traitではできない
正確な表現かは分からないけどDerefは&の向こう側でしか*を適用できない
159デフォルトの名無しさん
2024/02/28(水) 00:41:03.68ID:PK7EwTQ6 こうだろ
x: &Box<T> とすると
*x: Box<T> (by Dereference)
**x: T (by Deref Box<T>→T)
&**x: &T (xのDeref coercion結果)
x: &Vec<T> とすると
*x: Vec<T> (by Dereference)
**x: [T] (by Deref Vec<T>→[T])
&**x: &[T] (xのDeref coercion結果)
x: &String とすると
*x: String (by Dereference)
**x: str (by Deref String→str)
&**x: &str (xのDeref coercion結果)
x: &Box<T> とすると
*x: Box<T> (by Dereference)
**x: T (by Deref Box<T>→T)
&**x: &T (xのDeref coercion結果)
x: &Vec<T> とすると
*x: Vec<T> (by Dereference)
**x: [T] (by Deref Vec<T>→[T])
&**x: &[T] (xのDeref coercion結果)
x: &String とすると
*x: String (by Dereference)
**x: str (by Deref String→str)
&**x: &str (xのDeref coercion結果)
160デフォルトの名無しさん
2024/02/28(水) 00:49:10.38ID:ZZ90UZAT なんかゲシュタルト崩壊してきたんだがw
関係ないけど微積のdxとかdyを思い出してしまった
関係ないけど微積のdxとかdyを思い出してしまった
161デフォルトの名無しさん
2024/02/28(水) 01:22:37.90ID:0HAFGBLs C/C++書いてる者からすると勝手に変換してくれて楽ちんだなあって感じ
162デフォルトの名無しさん
2024/02/28(水) 01:32:01.63ID:upo0sX/6 Deref coercion &**のうち
右側の*は参照に対する参照外しで
左側の*はDerefで定義(実装)されてるものなのね
右側の*は参照に対する参照外しで
左側の*はDerefで定義(実装)されてるものなのね
163デフォルトの名無しさん
2024/02/28(水) 04:46:46.07ID:EOw65cJZ let s = String::from("xyz");
let x: &str = &s;
let x: &str = &&s;
let x: &str = &&&s;
これ全てコンパイル通ってderef coercionされるから
『by Deref &T→T』も適用されていると思うぞ
let x: &str = &s;
let x: &str = &&s;
let x: &str = &&&s;
これ全てコンパイル通ってderef coercionされるから
『by Deref &T→T』も適用されていると思うぞ
164デフォルトの名無しさん
2024/02/28(水) 11:30:56.58ID:eNJqE6SH165デフォルトの名無しさん
2024/02/28(水) 17:44:48.30ID:8gSKFNHr >>156
演算の名前はdereference
derefはDerefトレイトに定義してあるメソッドの名前
>>157
>Derefは*
違う
Derefはトレイト
*はdereference operator
>Deref coercionは&**
違う
Deref Coercionとはcoercionが行われる場合に「&Tを&<T as Deref>::Target」にcoerceすること
Deref Coercionと*などの演算子は全く別の独立したものとして扱われている
それぞれの処理の一部で必要に応じてDerefに定義されたderefメソッドを活用してるというだけ
片方がもう片方に依存してたりもしない
Deref Coercionの処理の一部として呼び出されるderefメソッドを
演算子で擬似的に再定義しようとすれば&**になるというの話はかろうじて理解できるが
前述のように定義が循環してるだけでなく再定義する価値を見いだせない
演算の名前はdereference
derefはDerefトレイトに定義してあるメソッドの名前
>>157
>Derefは*
違う
Derefはトレイト
*はdereference operator
>Deref coercionは&**
違う
Deref Coercionとはcoercionが行われる場合に「&Tを&<T as Deref>::Target」にcoerceすること
Deref Coercionと*などの演算子は全く別の独立したものとして扱われている
それぞれの処理の一部で必要に応じてDerefに定義されたderefメソッドを活用してるというだけ
片方がもう片方に依存してたりもしない
Deref Coercionの処理の一部として呼び出されるderefメソッドを
演算子で擬似的に再定義しようとすれば&**になるというの話はかろうじて理解できるが
前述のように定義が循環してるだけでなく再定義する価値を見いだせない
166デフォルトの名無しさん
2024/02/28(水) 18:08:21.49ID:8fminEVJ なるほどね。勉強になるわ。
167デフォルトの名無しさん
2024/02/28(水) 18:17:32.89ID:8gSKFNHr >>164
&&T→&Tの場合もreference用のビルトインderefが先に動いてDeref for &Tの実装コードは動いてない可能性ない?
&&T→&Tの場合もreference用のビルトインderefが先に動いてDeref for &Tの実装コードは動いてない可能性ない?
168デフォルトの名無しさん
2024/02/28(水) 18:20:50.27ID:nghz9NTX >>164
Deref coercionの定義を理解しよう
Deref T→Uが実装されている時に
(つまり*TがUとなる時に)
&T→&UのDeref coercionが自動適用される
&String→&str (by Deref String→str)
&Vec<T>→&[T] (by Deref Vec<T>→[T])
&Box<T>→&T (by Deref Box<T>→&T)
&&T→&T (by Deref &T→T)
これらはすべてDeref coercion
Deref coercionの定義を理解しよう
Deref T→Uが実装されている時に
(つまり*TがUとなる時に)
&T→&UのDeref coercionが自動適用される
&String→&str (by Deref String→str)
&Vec<T>→&[T] (by Deref Vec<T>→[T])
&Box<T>→&T (by Deref Box<T>→&T)
&&T→&T (by Deref &T→T)
これらはすべてDeref coercion
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 小野田紀美・経済安保担当相「何か気に入らないことがあればすぐに経済的威圧をする国への依存はリスク」 ★2 [Hitzeschleier★]
- 日本行き空路49万件キャンセル 中国自粛呼びかけ 日本行きチケット予約の約32%に相当 ★2 [ぐれ★]
- 【中国局長】両国関係に「深刻な影響」 首相発言の撤回要求 [蚤の市★]
- 外務省局長は無言で厳しい表情…日中の高官協議終了か 高市首相“台湾”発言で中国が強硬対応 発言撤回求めたか…★3 [BFU★]
- 【インバウンド】中国人観光客の日本での消費額は年間約2兆円超…中国政府は公務員の出張取り消し [1ゲットロボ★]
- 【維新】吉村知事「中国人観光客だけに頼るビジネスモデル変えていかないといけない」「高市総理の発言は撤回する必要はない」 [Hitzeschleier★]
- 【実況】博衣こよりのえちえち歌枠🧪
- 【高市速報】日本人の3割「中国への武力行使に踏み切る必要がある」ANN世論調査 [931948549]
- 外務省局長、よくわからないまま帰国へ [834922174]
- 【速報】51歳まで自衛隊になれるように法改正ww [347751896]
- (´・ω・`)おいそこ。そこの貴様だ。へらへらするな。
- 中国外務省「日中関係の悪化は高市早苗首相が原因」と名指しで強く非難。キタ━(゚∀゚)━! [153490809]
