公式
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:CheDQupm552デフォルトの名無しさん
2024/04/04(木) 18:59:50.97ID:mbQWc9lN >>551
滑ってるぞ
滑ってるぞ
553デフォルトの名無しさん
2024/04/04(木) 19:04:00.82ID:mNkWQBjH 感じてるから違和「感」だからね
要は頭痛が痛いと同じ
要は頭痛が痛いと同じ
554デフォルトの名無しさん
2024/04/04(木) 19:08:09.03ID:v0TcrcAn 違和感がある。これでどうだ
555デフォルトの名無しさん
2024/04/04(木) 19:17:51.63ID:v7LceGlx556デフォルトの名無しさん
2024/04/04(木) 20:07:49.07ID:xDxHg+AD >>542
embedded 対応アーキ少なくね?
embedded 対応アーキ少なくね?
557デフォルトの名無しさん
2024/04/04(木) 23:05:07.77ID:94OMF7T7 >>553
「違和感を感じる」は「頭痛が痛い」とは違って重言ではないよ
https://togetter.com/li/2067771
https://www.nhk.or.jp/bunken/research/kotoba/20240101_4.html
「違和感を感じる」は「頭痛が痛い」とは違って重言ではないよ
https://togetter.com/li/2067771
https://www.nhk.or.jp/bunken/research/kotoba/20240101_4.html
558デフォルトの名無しさん
2024/04/04(木) 23:18:56.70ID:94OMF7T7559デフォルトの名無しさん
2024/04/05(金) 00:09:35.95ID:Lw8p7kTG560デフォルトの名無しさん
2024/04/05(金) 00:21:09.11ID:dub3Z8tI 後発言語?
561デフォルトの名無しさん
2024/04/05(金) 00:50:16.55ID:Lw8p7kTG 少し前まで次世代言語と言われてた程度には後発。
鯖向け言語で終わると思ってたら、マジでC/アセンブラの牙城を崩し始めるとは思わんかった。
むしろ崩し始めることすら無理だと思ってた。
鯖向け言語で終わると思ってたら、マジでC/アセンブラの牙城を崩し始めるとは思わんかった。
むしろ崩し始めることすら無理だと思ってた。
562デフォルトの名無しさん
2024/04/05(金) 05:07:52.53ID:CPVE6BHF563デフォルトの名無しさん
2024/04/05(金) 08:11:28.72ID:Lw8p7kTG Rust知ってれば安全性の高いシステム組めますと言うアピールになるし、C++にもその安全性のための知見は役立つ。
複数言語使えますってだけでもアピールになるしね。
Rustは多分仕事自体はまだ多くない。
これからアピールして増やしていく感じなので、両方使えてた方がいい。
複数言語使えますってだけでもアピールになるしね。
Rustは多分仕事自体はまだ多くない。
これからアピールして増やしていく感じなので、両方使えてた方がいい。
564デフォルトの名無しさん
2024/04/06(土) 22:48:03.64ID:4i1Gvjc8 rustというものがありながらなぜ大部分のコードはC言語なのかを知るために現場に行くのもアリ
565デフォルトの名無しさん
2024/04/06(土) 23:06:32.76ID:7kpWL/Du Rustが実用的になったのは2020年
それ以降の新規案件はRustになっている
それ以降の新規案件はRustになっている
566デフォルトの名無しさん
2024/04/07(日) 01:26:10.29ID:Hmt7T+4v Rustへの移行は始まったばかりだからまだまだCが残っているのは当たり前
567デフォルトの名無しさん
2024/04/07(日) 10:55:29.15ID:QD1FKAnH 絶壁の学習曲線。
貧弱なライブラリと人材。
早すぎる最適化。
しばらくは既存コード置き換えが中心だし、今後もプロジェクト初期のプロトタイピングで使われることは無いだろう。
貧弱なライブラリと人材。
早すぎる最適化。
しばらくは既存コード置き換えが中心だし、今後もプロジェクト初期のプロトタイピングで使われることは無いだろう。
568デフォルトの名無しさん
2024/04/07(日) 14:17:46.28ID:vzw88H1n P系言語の糞思考に染まっていない初心者こそ
最初にRustを学ぶべき
最初にRustを学ぶべき
569デフォルトの名無しさん
2024/04/07(日) 18:04:59.36ID:Sj2oLPpI >>567
移植なんて無駄な作業はどの言語間でも行われることが少なく
移植なんて無駄な作業はどの言語間でも行われることが少なく
570デフォルトの名無しさん
2024/04/07(日) 18:05:33.79ID:nD4MmBKu 初手Rustは冗談抜きで2024以降だと選択肢に入るんじゃないか
571デフォルトの名無しさん
2024/04/07(日) 18:09:00.76ID:Sj2oLPpI572デフォルトの名無しさん
2024/04/07(日) 18:16:09.73ID:TV6Dkj8m573デフォルトの名無しさん
2024/04/08(月) 02:24:45.08ID:BHlkyWwA574デフォルトの名無しさん
2024/04/08(月) 03:09:59.48ID:BqmMXmQi 単なる感想を必死にウソ扱いして何がしたいんだコイツw
575デフォルトの名無しさん
2024/04/08(月) 11:48:22.86ID:hzcejt90 ライブラリはPythonと比べると流石に貧弱
特に数値計算とか物理・機械学習系
簡単な数値計算の時点でnumpy•scipyのようなデファクトがなく、雑魚が乱立している
もっと高度な計算系ではもっと雑魚が乱立しているか、そもそもない
特に数値計算とか物理・機械学習系
簡単な数値計算の時点でnumpy•scipyのようなデファクトがなく、雑魚が乱立している
もっと高度な計算系ではもっと雑魚が乱立しているか、そもそもない
576デフォルトの名無しさん
2024/04/08(月) 12:32:47.46ID:64QjhTLf >>575
キチガイアンチ
すべての分野でライブラリが充実している言語は存在しない
ある分野で一番充実している言語を棍棒にしたら他のすべての言語が負けるのは当たり前
そういう無意味なことをして叩いて楽しいか?
キチガイアンチ
すべての分野でライブラリが充実している言語は存在しない
ある分野で一番充実している言語を棍棒にしたら他のすべての言語が負けるのは当たり前
そういう無意味なことをして叩いて楽しいか?
577デフォルトの名無しさん
2024/04/08(月) 13:16:14.61ID:JoalanBl578デフォルトの名無しさん
2024/04/08(月) 14:02:16.22ID:7wfBslr8 >>576
そこは「Rustなら〇〇分野のライブラリがどの他言語より充実している」と反論するところだろ。
そこは「Rustなら〇〇分野のライブラリがどの他言語より充実している」と反論するところだろ。
579デフォルトの名無しさん
2024/04/08(月) 14:10:54.87ID:7wfBslr8580デフォルトの名無しさん
2024/04/08(月) 14:43:36.67ID:IC0NBj1d Crypto分野はRustが他言語よりも充実してるかもね
581デフォルトの名無しさん
2024/04/08(月) 15:06:06.34ID:rjHvzTUw ライブラリの多さってイコールでユーザの多さなんだよ
更にいうとその言語開発者の意欲の表れでもある
ライブラリが少ないという事はユーザが少ない
更に少ないユーザの中でも意欲の有る人間は少数って証明なんだよね
更にいうとその言語開発者の意欲の表れでもある
ライブラリが少ないという事はユーザが少ない
更に少ないユーザの中でも意欲の有る人間は少数って証明なんだよね
582デフォルトの名無しさん
2024/04/08(月) 15:43:54.88ID:JoalanBl いやまあ数はあるんよ数は
意欲のある人はいるっぽいんだけど、デファクトとるようなライブラリってやっぱりそれなりの人数でちゃんと資金とって作られてるんだよな
資金取るのは個人の意欲だけじゃなくて、お金のある人を納得させる理屈が必要で、少し前までのRustは少なくとも数値計算の分野でそれが出来る言語ではなかったと思う
意欲のある人はいるっぽいんだけど、デファクトとるようなライブラリってやっぱりそれなりの人数でちゃんと資金とって作られてるんだよな
資金取るのは個人の意欲だけじゃなくて、お金のある人を納得させる理屈が必要で、少し前までのRustは少なくとも数値計算の分野でそれが出来る言語ではなかったと思う
583デフォルトの名無しさん
2024/04/08(月) 16:39:42.51ID:9qnuy4NE てかrustユーザーってnvidiaのcudaサポートの酷さにガチギレするような奴ばっかでしょ。
そんなんで数値計算ライブラリが入るわけがない。
そんなんで数値計算ライブラリが入るわけがない。
584デフォルトの名無しさん
2024/04/08(月) 17:11:27.78ID:7wfBslr8 初心者向けのSimplified Rustと、
c/c++ライブラリバインドを強化したAdaptor Rustあたりは欲しいなぁ。
Safe Rustじゃ難しそうだし。
c/c++ライブラリバインドを強化したAdaptor Rustあたりは欲しいなぁ。
Safe Rustじゃ難しそうだし。
585デフォルトの名無しさん
2024/04/08(月) 17:54:43.90ID:JoalanBl ゼロからプログラム書くならSafe rustが一番簡単だよ
こいつに従っているだけで割と見通しが良くてバグりにくいコードが書ける
まあGoto 多用しているようなFortran おじいちゃんとは相性が悪いかもしれんが
こいつに従っているだけで割と見通しが良くてバグりにくいコードが書ける
まあGoto 多用しているようなFortran おじいちゃんとは相性が悪いかもしれんが
586デフォルトの名無しさん
2024/04/08(月) 19:05:28.67ID:ifgKIXku C++を完全に理解した者のための言語それがRust
故に誰も
故に誰も
587デフォルトの名無しさん
2024/04/08(月) 20:39:36.28ID:cqL1RV99 C++を使ったことないけど
Rustで困ったことないな
Rust理解で必要なことはポインタとスタックとヒープとRAIIくらいかな
所有権は単なるヒープ解放責任だから大したことではない
所有権を他へ譲渡しないとRAIIによって自動解放されるというだけの話
非常にシンプル
Rustで困ったことないな
Rust理解で必要なことはポインタとスタックとヒープとRAIIくらいかな
所有権は単なるヒープ解放責任だから大したことではない
所有権を他へ譲渡しないとRAIIによって自動解放されるというだけの話
非常にシンプル
588デフォルトの名無しさん
2024/04/08(月) 21:02:11.65ID:YkdU7kgc 所有権を複製するとか間違った事を言い続けてる人が良く言うわw
589デフォルトの名無しさん
2024/04/09(火) 00:09:53.71ID:pItuq1gX >>588
それは俺じゃないぞ
それは俺じゃないぞ
590デフォルトの名無しさん
2024/04/09(火) 02:45:12.09ID:hsAXyuRl >>589
誰だよお前。
誰だよお前。
591デフォルトの名無しさん
2024/04/09(火) 09:16:17.69ID:OXfvzIgi 今のところ>>458が一番面白い
592デフォルトの名無しさん
2024/04/09(火) 10:16:36.65ID:Po0ZJOeT 昭和ギャグ?
ちょっと意味がわかりません
ちょっと意味がわかりません
593デフォルトの名無しさん
2024/04/09(火) 11:01:29.74ID:cj+QXWpg 今どきイジりを面白いとか、イジメ肯定派かよ。
594デフォルトの名無しさん
2024/04/09(火) 13:18:19.32ID:9AcR/8+u 進化論肯定派じゃないの
人を淘汰することを志している
人を淘汰することを志している
595デフォルトの名無しさん
2024/04/09(火) 17:18:23.86ID:+rnauHt3 カチョー「???」じゃなくて
カチョー「で?」なら共感できたかも
カチョー「で?」なら共感できたかも
596デフォルトの名無しさん
2024/04/10(水) 01:14:02.81ID:/k7xUJZy rustだいぶ分かってきたつもりだけど
ライフタイムとジェネリクスとクロージャが一斉に襲いかかってくると無理
好きな言語だけど世の中にはプログラミング言語に強い興味を示す奴が稀なので厳しいなぁと感じる
ライフタイムとジェネリクスとクロージャが一斉に襲いかかってくると無理
好きな言語だけど世の中にはプログラミング言語に強い興味を示す奴が稀なので厳しいなぁと感じる
597デフォルトの名無しさん
2024/04/10(水) 08:03:56.89ID:ltqciZ07598デフォルトの名無しさん
2024/04/10(水) 11:01:40.54ID:5Js//1cu >>596
moonbit くらいならどうかな?
moonbit くらいならどうかな?
599デフォルトの名無しさん
2024/04/10(水) 11:35:35.51ID:AS+TZoYk >>596
それぞれ理解していれば組み合わさって困ることはないんじゃないかな
Rust特有のライフタイム注釈は構造体なら「参照を持ってるよ」の印で関数なら「この引数の参照は返り値の参照に対応するよ」の印であとは有効期間を満たすだけなど
それぞれ理解していれば組み合わさって困ることはないんじゃないかな
Rust特有のライフタイム注釈は構造体なら「参照を持ってるよ」の印で関数なら「この引数の参照は返り値の参照に対応するよ」の印であとは有効期間を満たすだけなど
600デフォルトの名無しさん
2024/04/10(水) 16:55:22.63ID:yZA7mDLP Rustってfunctionをfnって略すくらい気が短いのに、なんでメソッド定義時にはわざわざselfみたいなPython臭いの入力しないとだめなんですか?めんどいんですけど
601デフォルトの名無しさん
2024/04/10(水) 17:30:31.18ID:Fk7YBwaR メソッドをそうでない普通の関数と区別するためにはなんらかのマークは要るじゃろ。
602デフォルトの名無しさん
2024/04/10(水) 17:38:51.91ID:t7JkSWKp self/ mut self/&self/&mut selfの区別もいるしな
self自体これ以上短くしてもよくわからん単語になるしまぁ妥当では
self自体これ以上短くしてもよくわからん単語になるしまぁ妥当では
603デフォルトの名無しさん
2024/04/10(水) 17:52:25.08ID:5Js//1cu C++ の ref-qualifier とか無理のある文法だもんな。
そこに書くんか!? という変な驚きがある。
引数の一種ということにしたほうがかなり単純でよい。
実際、 C++ でも C++23 から this を明示的な引数に取れる文法が追加された。 (deducing this)
そこに書くんか!? という変な驚きがある。
引数の一種ということにしたほうがかなり単純でよい。
実際、 C++ でも C++23 から this を明示的な引数に取れる文法が追加された。 (deducing this)
604デフォルトの名無しさん
2024/04/10(水) 17:58:48.34ID:Q64PiueS RustでPython実装すりゃ良いんじゃね
605デフォルトの名無しさん
2024/04/10(水) 18:34:01.75ID:3h5gXXiJ606デフォルトの名無しさん
2024/04/10(水) 19:34:40.80ID:8DE+tVvz selfより短ければ良いのか、それともC++みたいに省略できてしまってどこで定義されてるのかようわからんくなるのが好きなのか
607デフォルトの名無しさん
2024/04/10(水) 19:44:04.66ID:y0DX5npz ぜひとも >>605 の考える最高にイケてる構文を教えてほしい
Rustを今から変えるのは無理でも、後継言語に採用されるかもしれんし
Rustを今から変えるのは無理でも、後継言語に採用されるかもしれんし
608デフォルトの名無しさん
2024/04/10(水) 19:47:55.68ID:IjfZ+vUr609デフォルトの名無しさん
2024/04/10(水) 20:06:03.20ID:AS+TZoYk610デフォルトの名無しさん
2024/04/10(水) 21:28:15.02ID:8DE+tVvz selfじゃくてthisならC++マニアも納得
611デフォルトの名無しさん
2024/04/10(水) 21:34:35.54ID:6SjCdg5T >>608
nimを知らないけど、Rustのassociated functionもその二種類の呼び出し方法がとれる点は同じだね
Vec::push(&mut vec, 123);
(&mut vec).push(123);
vec.push(123);
この&mutを省略できてRust便利
nimを知らないけど、Rustのassociated functionもその二種類の呼び出し方法がとれる点は同じだね
Vec::push(&mut vec, 123);
(&mut vec).push(123);
vec.push(123);
この&mutを省略できてRust便利
612デフォルトの名無しさん
2024/04/10(水) 21:37:52.75ID:Mpv09JwO thisはたまにselfの代理で使われてるな
Rc::into_innerとか
Rc::into_innerとか
613デフォルトの名無しさん
2024/04/10(水) 23:19:28.12ID:AS+TZoYk deref後のinto_inner適用と区別のため
敢えてself使わないことでメソッド呼び出し形式をできなくして
明示的にRc::into_inner呼び出しさせるパターンだね
敢えてself使わないことでメソッド呼び出し形式をできなくして
明示的にRc::into_inner呼び出しさせるパターンだね
614デフォルトの名無しさん
2024/04/10(水) 23:45:41.84ID:Fk7YBwaR メソッドを呼び出すことと関数の第一引数に渡すことを同一視する構文は
LISP 用に作られたオブジェクトシステム new flavors でやってた。
LISP 用に作られたオブジェクトシステム new flavors でやってた。
615デフォルトの名無しさん
2024/04/11(木) 02:11:03.37ID:4f6XcC0j それは同一視というか構文が1つしかないだけでは
616デフォルトの名無しさん
2024/04/11(木) 02:14:15.06ID:7FNbL3Xb 呼び出し時には与えない引数って紛らわしくね?
617614
2024/04/11(木) 02:45:03.24ID:C4qhk0zm >>615
メッセージを送る構文と関数呼出しの構文の両方があって構文糖として扱える仕組みになってたという話。
new flavors の前に flavors というのがあって、それはメッセージを送る構文しかなかったのだけど
new flavors で改良 (かどうかわからんけど) された。
メッセージを送る構文と関数呼出しの構文の両方があって構文糖として扱える仕組みになってたという話。
new flavors の前に flavors というのがあって、それはメッセージを送る構文しかなかったのだけど
new flavors で改良 (かどうかわからんけど) された。
618デフォルトの名無しさん
2024/04/11(木) 04:57:52.23ID:r6y9Ju0a >>616
むしろ逆かな
target.method(arg1, arg2, ...)という
targetへのメソッドコールを実現するのを関数で表すと
method(target, arg1, arg2, ...)とする言語が多い
Rustでも同じでこのtargetをselfと書く
targetは送る側から見た視点
selfは受け取った側から見た視点
各実装は受け取った側でなされるためself
むしろ逆かな
target.method(arg1, arg2, ...)という
targetへのメソッドコールを実現するのを関数で表すと
method(target, arg1, arg2, ...)とする言語が多い
Rustでも同じでこのtargetをselfと書く
targetは送る側から見た視点
selfは受け取った側から見た視点
各実装は受け取った側でなされるためself
619デフォルトの名無しさん
2024/04/11(木) 08:24:38.80ID:McLA6Ner UFCSは第一引数を1つ目だからというだけの理由で特別扱いするのが気持ち悪いんだよな
レシーバとして扱われるなら構文上も特別であってほしい
レシーバとして扱われるなら構文上も特別であってほしい
620デフォルトの名無しさん
2024/04/11(木) 08:39:59.21ID:UjbgXeUt >>619
何が気持ち悪いのかさっぱりわからない
まず、全ては関数呼び出しになりそれ以外の方法はない、というのはいいよね?
次に、その関数呼び出しでのレシーバの渡し方は最初の引数になる、というのも自然だよね?
ほとんどの言語がこの方式なのに何を気持ち悪がっているのだろう
何が気持ち悪いのかさっぱりわからない
まず、全ては関数呼び出しになりそれ以外の方法はない、というのはいいよね?
次に、その関数呼び出しでのレシーバの渡し方は最初の引数になる、というのも自然だよね?
ほとんどの言語がこの方式なのに何を気持ち悪がっているのだろう
621デフォルトの名無しさん
2024/04/11(木) 08:49:57.16ID:azFLg2co 言うほどほとんどの言語がこれか?
pythonは後付けでOOPぶっこんだからただの関数の引数にSelfなんだ
これがPythonいまいちだなって思うところ
c++も似た様な理由でstaticでthis
後発で考慮する余裕あるのにそれを引っ張ってる
pythonは後付けでOOPぶっこんだからただの関数の引数にSelfなんだ
これがPythonいまいちだなって思うところ
c++も似た様な理由でstaticでthis
後発で考慮する余裕あるのにそれを引っ張ってる
622デフォルトの名無しさん
2024/04/11(木) 09:02:17.34ID:NXydgA7G >>621
君の感性がおかしいんじゃね?
NimもZigもRustもPythonと同じ標準方式
foo(receiver, arg1, arg2, ..)
または
receiver.foo(arg1, arg2, ..)
君の感性がおかしいんじゃね?
NimもZigもRustもPythonと同じ標準方式
foo(receiver, arg1, arg2, ..)
または
receiver.foo(arg1, arg2, ..)
623デフォルトの名無しさん
2024/04/11(木) 09:02:43.98ID:7FNbL3Xb >>618
なるほどちょっと納得した
なるほどちょっと納得した
624デフォルトの名無しさん
2024/04/11(木) 09:11:33.28ID:azFLg2co >>622
実質Pythonフォロワーを含めて言われても…
実質Pythonフォロワーを含めて言われても…
625デフォルトの名無しさん
2024/04/11(木) 09:14:09.83ID:azFLg2co C言語のときはOOPじゃなくてただの関数の第一引数に構造体を指定してた
それがOOP言語になって指定不要になった
それがまたC言語時代に逆戻り
それがOOP言語になって指定不要になった
それがまたC言語時代に逆戻り
626デフォルトの名無しさん
2024/04/11(木) 09:15:22.73ID:NXydgA7G627デフォルトの名無しさん
2024/04/11(木) 09:17:05.47ID:azFLg2co あらかじめ書いておくけどreceiver.Foo()じゃないメソッドがあるのは
receiverがNullの可能性がある場合でそう設計されてただけ
receiverがNullの可能性がある場合でそう設計されてただけ
628デフォルトの名無しさん
2024/04/11(木) 09:20:43.92ID:NXydgA7G 代案を出せないってことはRustに言いがかりをつけてるだけだな
629デフォルトの名無しさん
2024/04/11(木) 09:24:05.56ID:azFLg2co 別に他のOOP言語のように関数にマークつけてこれはこのインスタンスのメソッドですよと言えばいいだけ
その表記は時間をかけて考えたらいい
その表記は時間をかけて考えたらいい
630デフォルトの名無しさん
2024/04/11(木) 09:30:34.30ID:cvuvfjXO >>625
レシーバは必ず必要
Goでも
func (receiver ReceiverType) Foo(引数…) {
return receiver.xxx + receiver.yyy
}
と書く
レシーバ指定不要という主張は理解できない
レシーバは必ず必要
Goでも
func (receiver ReceiverType) Foo(引数…) {
return receiver.xxx + receiver.yyy
}
と書く
レシーバ指定不要という主張は理解できない
631デフォルトの名無しさん
2024/04/11(木) 09:45:56.75ID:gYo8nOa5 レシーバの名前を自由につけられると人によってバラバラで読みづらいんだよな
selfなら必ず揃うし予約語としてシンタックスハイライトされるのもいい
selfなら必ず揃うし予約語としてシンタックスハイライトされるのもいい
632デフォルトの名無しさん
2024/04/11(木) 09:51:28.66ID:azFLg2co いやいやw
無知って怖いねとしか…
無知って怖いねとしか…
633デフォルトの名無しさん
2024/04/11(木) 09:52:17.20ID:azFLg2co634デフォルトの名無しさん
2024/04/11(木) 10:19:57.47ID:UmgPKlgb635デフォルトの名無しさん
2024/04/11(木) 10:33:59.60ID:Nlu6ipA3636デフォルトの名無しさん
2024/04/11(木) 11:00:57.82ID:azFLg2co IDころころお爺さんは明らかに話を理解できないな
637デフォルトの名無しさん
2024/04/11(木) 11:23:46.71ID:CaCoKmZ3 Rustは小文字selfが値、大文字Selfが型を示していて使いやすいよな
型指定にSelfやSelf::Itemなど使えるだけでなく
Self::CONSTANT_NAMEやSelf::function_without_self()などの呼び出しもできる
Selfによって自分自身であるとわかりコードが読みやすい
型名変更の影響も受けず読みやすいメンテしやすい
ダメな言語だと以下のダメなパターンがある
・Selfの代わりに型名を書かなくてはいけない言語 (自分自身だとわかりにくくメンテ性も悪い)
・Selfの代わりにself(やthis)を用いてしまう言語 (値と型の区別がつかない)
・Selfを使わずに名前空間の区別がない言語 (間違いが起きやすく自分自身だとわかりくくメンテ性が悪い)
型指定にSelfやSelf::Itemなど使えるだけでなく
Self::CONSTANT_NAMEやSelf::function_without_self()などの呼び出しもできる
Selfによって自分自身であるとわかりコードが読みやすい
型名変更の影響も受けず読みやすいメンテしやすい
ダメな言語だと以下のダメなパターンがある
・Selfの代わりに型名を書かなくてはいけない言語 (自分自身だとわかりにくくメンテ性も悪い)
・Selfの代わりにself(やthis)を用いてしまう言語 (値と型の区別がつかない)
・Selfを使わずに名前空間の区別がない言語 (間違いが起きやすく自分自身だとわかりくくメンテ性が悪い)
638デフォルトの名無しさん
2024/04/11(木) 11:57:27.19ID:17a5lmDN 関係ない長文でごまかすフェーズに入ってるってことは内心恥ずかしくて死にそうになってるんやろうな……
639デフォルトの名無しさん
2024/04/11(木) 11:57:34.08ID:6x2Zth+c 複オジは見えてる範囲が狭過ぎる
だから長文になればなるほど勘違い度や害悪度が高まる
だから長文になればなるほど勘違い度や害悪度が高まる
640デフォルトの名無しさん
2024/04/11(木) 12:47:47.10ID:ZruVErXu 自分が使ってきた特殊な仕様の言語に慣れ親しんでいると
一般的なの仕様のRustに違和感を感じて文句をつけたくなる気持ちはわからんでもない
Rustを叩く前に視野を広く持つべきだな
Rustの仕様はよく考えられ機能的に洗練されている
一般的なの仕様のRustに違和感を感じて文句をつけたくなる気持ちはわからんでもない
Rustを叩く前に視野を広く持つべきだな
Rustの仕様はよく考えられ機能的に洗練されている
641デフォルトの名無しさん
2024/04/11(木) 12:59:00.66ID:AZdBjU6j >>640
Rustに無いからといってUFCS叩くのはさすがにアホかと。
Rustに無いからといってUFCS叩くのはさすがにアホかと。
642デフォルトの名無しさん
2024/04/11(木) 13:15:55.80ID:4f6XcC0j そんなことよりError::sourceの戻り値に'static要求されるのってなんでなん
643デフォルトの名無しさん
2024/04/11(木) 15:57:20.01ID:R8LZpbjl >>642
エラー返す時に参照してるリソースをつかんだままにしたくないからじゃない
エラー返す時に参照してるリソースをつかんだままにしたくないからじゃない
644デフォルトの名無しさん
2024/04/11(木) 15:59:23.14ID:v1XXdeLJ くだらないレスは頻繁にするのにまともな質問が来ると急に黙るの面白い
645デフォルトの名無しさん
2024/04/11(木) 16:41:03.54ID:KhnNkcJ8 まともな質問にいつものノリで適当に答えて嘘だったら良くないしね
646デフォルトの名無しさん
2024/04/11(木) 17:01:08.25ID:TWMZ6q+3 そっか
俺の答えも間違ってたしな
正しくはdowncastのために必要らしい
詳しくはfix_errorのRFC見て
俺の答えも間違ってたしな
正しくはdowncastのために必要らしい
詳しくはfix_errorのRFC見て
647デフォルトの名無しさん
2024/04/11(木) 17:41:58.72ID:McIjmFt1 Playgroundがwebsocket接続のタイムアウトエラー(504:Gateway Time-out)で全然動かないんだが俺環?
648デフォルトの名無しさん
2024/04/11(木) 17:48:38.15ID:McIjmFt1649デフォルトの名無しさん
2024/04/11(木) 18:55:11.06ID:4f6XcC0j downcastなんて別にしないからいらねーよって思ったけど
そういえば内部で似たようなことやってるあれがあったな、どっちかっていうとあれのためか
ヒントありがとう
そういえば内部で似たようなことやってるあれがあったな、どっちかっていうとあれのためか
ヒントありがとう
650デフォルトの名無しさん
2024/04/11(木) 19:06:32.42ID:VFM//2+p 複おじはc++も使ってなかったんだな
651デフォルトの名無しさん
2024/04/11(木) 20:25:23.50ID:81s1BzdD >>641
UFCSはメソッド名空間の汚染であるため、まともな言語では採用されていない。
RustはUFCSを採用しないだけでなく、更に厳しく孤児ルールによってメソッド名空間の汚染を防いでる。
Rustでのメソッド追加拡張は、そのための新たなトレイトを用意することで、その利用空間に限定して安全に行うことができる。
UFCSはメソッド名空間の汚染であるため、まともな言語では採用されていない。
RustはUFCSを採用しないだけでなく、更に厳しく孤児ルールによってメソッド名空間の汚染を防いでる。
Rustでのメソッド追加拡張は、そのための新たなトレイトを用意することで、その利用空間に限定して安全に行うことができる。
■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 小野田紀美・経済安保担当相「何か気に入らないことがあればすぐに経済的威圧をする国への依存はリスク」 ★2 [Hitzeschleier★]
- 日本行き空路49万件キャンセル 中国自粛呼びかけ 日本行きチケット予約の約32%に相当 ★2 [ぐれ★]
- 【中国局長】両国関係に「深刻な影響」 首相発言の撤回要求 [蚤の市★]
- 外務省局長は無言で厳しい表情…日中の高官協議終了か 高市首相“台湾”発言で中国が強硬対応 発言撤回求めたか…★3 [BFU★]
- 日経平均の下落率3%超す、財政懸念で長期金利上昇 ★2 [お断り★]
- 【インバウンド】中国人観光客の日本での消費額は年間約2兆円超…中国政府は公務員の出張取り消し [1ゲットロボ★]
- 【実況】博衣こよりのえちえち歌枠🧪
- 【高市速報】日本人の3割「中国への武力行使に踏み切る必要がある」ANN世論調査 [931948549]
- 【雑談】暇人集会所part18
- 高市早苗「支持者の理解を得られないので台湾発言を撤回できない」 [931948549]
- 外務省局長、よくわからないまま帰国へ [834922174]
- 中国外務省「日中関係の悪化は高市早苗首相が原因」と名指しで強く非難。キタ━(゚∀゚)━! [153490809]
