Mozilla発のRust言語のスレ
公式
https://www.rust-lang.org/
https://blog.rust-lang.org/
https://github.com/rust-lang/rust
Web上の実行環境
https://play.rust-lang.org
前スレ
Rust Part6
http://mevius.5ch.net/test/read.cgi/tech/1532714678/
Rust Part7
■ このスレッドは過去ログ倉庫に格納されています
2019/07/14(日) 23:31:47.54ID:PySyhRf9
481デフォルトの名無しさん
2019/10/18(金) 15:26:11.27ID:/rPuRJSX482デフォルトの名無しさん
2019/10/18(金) 17:46:16.42ID:lmpJOwiE mut を マットって読んでる人いる?
コアチーム含めミュート派が大勢なのは知ってるけど
eがないとミュートって読むのは不自然だし、時々eをタイプしそうになるから
マット派になろうかと思ってるんだが
コアチーム含めミュート派が大勢なのは知ってるけど
eがないとミュートって読むのは不自然だし、時々eをタイプしそうになるから
マット派になろうかと思ってるんだが
483デフォルトの名無しさん
2019/10/18(金) 17:52:26.42ID:+uRRCvkS おれはミューツ派
484デフォルトの名無しさん
2019/10/18(金) 17:55:14.75ID:uhy/qlU/485デフォルトの名無しさん
2019/10/18(金) 17:59:19.15ID:G0LYzWL6 どう見てもムッと
486デフォルトの名無しさん
2019/10/18(金) 18:12:40.01ID:7Ocq1iZd むーと
487デフォルトの名無しさん
2019/10/18(金) 18:29:52.38ID:lmpJOwiE 結構いろんな読み方してんのね
マット派いたから安心して転向するわ
ちなみにドイツ語ではムートって読んで勇気って意味らしい
マット派いたから安心して転向するわ
ちなみにドイツ語ではムートって読んで勇気って意味らしい
488デフォルトの名無しさん
2019/10/18(金) 20:27:28.69ID:4X7KT/ZF Rustの単語のセンスだけはどうも好きになれん
489デフォルトの名無しさん
2019/10/18(金) 20:30:24.39ID:uhy/qlU/ わかる
fnとかpubとかunwrapとか普通にわかりにくい
fnとかpubとかunwrapとか普通にわかりにくい
490デフォルトの名無しさん
2019/10/18(金) 21:57:09.28ID:lmpJOwiE pubはまあわかるけど
fnとunwrapは他言語でもあるし普通にわかりやすいと思ってたわ
IntoIteratorとかは素直にIterableでいいのにとは思う
fnとunwrapは他言語でもあるし普通にわかりやすいと思ってたわ
IntoIteratorとかは素直にIterableでいいのにとは思う
491デフォルトの名無しさん
2019/10/19(土) 00:46:14.72ID:ZEJ60z1R しかしRustでOS作ったらCより性能悪かったという記事があったはず
新しくOS用のプログラミング言語を作った方が良いのでは
RustはOS開発を主眼にしてるわけじゃないだろう
新しくOS用のプログラミング言語を作った方が良いのでは
RustはOS開発を主眼にしてるわけじゃないだろう
492デフォルトの名無しさん
2019/10/19(土) 01:22:54.66ID:+gqAFVgo OSの性能って曖昧過ぎて何測ってるのかわからん
493デフォルトの名無しさん
2019/10/19(土) 04:43:06.59ID:VYVT60v2 Redoxめっちゃマッハやった
494デフォルトの名無しさん
2019/10/19(土) 07:34:16.56ID:uIADZHgb Rustは配列の境界値チェックがあるから普通に使うとCよりちょっと遅いよ
495デフォルトの名無しさん
2019/10/19(土) 13:01:40.81ID:sh4W9dNy >>494
分岐予測があるので理由はそこじゃない
分岐予測があるので理由はそこじゃない
496デフォルトの名無しさん
2019/10/19(土) 13:28:05.60ID:a3cu9K9L は?
497デフォルトの名無しさん
2019/10/19(土) 13:43:06.95ID:ZEJ60z1R OS組もうとするとRustの言語概念を無視するような書き方をしなきゃいけない
みたいに書いてあったんだけど
みたいに書いてあったんだけど
498デフォルトの名無しさん
2019/10/19(土) 13:44:39.15ID:xHh5MvNF 「Rust」言語はCよりも遅いのか、研究者がベンチマーク結果を解説
ttps://www.atmarkit.co.jp/ait/articles/1909/13/news133.html
このソースは
A high-speed network driver written in C, Rust, Go, C#, Java, OCaml, Haskell, Swift, Javascript, and Python
ttps://github.com/ixy-languages/ixy-languages
これかな
ttps://www.atmarkit.co.jp/ait/articles/1909/13/news133.html
このソースは
A high-speed network driver written in C, Rust, Go, C#, Java, OCaml, Haskell, Swift, Javascript, and Python
ttps://github.com/ixy-languages/ixy-languages
これかな
499デフォルトの名無しさん
2019/10/19(土) 17:05:59.60ID:xnS8qN86500デフォルトの名無しさん
2019/10/19(土) 18:07:21.38ID:Xn59Im0u いや普通にOSソース見ればそらrust向いてねーわってなるよ。
杓子定規にrust使おうってほうが気が狂ってるわ。
杓子定規にrust使おうってほうが気が狂ってるわ。
501デフォルトの名無しさん
2019/10/19(土) 18:16:31.77ID:JHoWAbaJ Rustを使わないからそうなっているのかもしれんぞ
どこでRustだと不利なのか説明してくれ
どこでRustだと不利なのか説明してくれ
502デフォルトの名無しさん
2019/10/19(土) 18:58:13.46ID:VwkXsBh7 ストレージからプロセスを読んで起動する、とか
そもそもコンテキストスイッチングの処理とかは所有権の概念(データの寿命が入れ子)から外れてくる
気がするが、別にunsafeにせねばならないほどでもないキモス
他に何かある?
そもそもコンテキストスイッチングの処理とかは所有権の概念(データの寿命が入れ子)から外れてくる
気がするが、別にunsafeにせねばならないほどでもないキモス
他に何かある?
503デフォルトの名無しさん
2019/10/19(土) 19:38:38.55ID:fKOzCfED その昔はlispやforthでもos書いたりしたんだからrustで書けないことないだろう。
504デフォルトの名無しさん
2019/10/20(日) 00:31:55.71ID:huwBBQor redoxがあるけど。
505デフォルトの名無しさん
2019/10/20(日) 11:39:50.17ID:Q377Ee/+ それで実際Rustはバグ発生率低いの?
506デフォルトの名無しさん
2019/10/20(日) 12:22:34.24ID:f+d3Kcps バグ発生率ってどうやってカウントするのが一般的なんやろか?
完全にただの思いつきで無意味な比較だけどgithubのgoとrustで総issue数/contributor数だと1人あたり2倍ぐらいgoのが多いね
完全にただの思いつきで無意味な比較だけどgithubのgoとrustで総issue数/contributor数だと1人あたり2倍ぐらいgoのが多いね
507デフォルトの名無しさん
2019/10/20(日) 13:14:08.41ID:Df2Q09El issueってバグじゃないだろ。
機能要望とか議論とかあるじゃん。
機能要望とか議論とかあるじゃん。
508デフォルトの名無しさん
2019/10/20(日) 23:15:26.37ID:ADDbXmaX 小さめのサイズの本で、初心者向けの本が出た!
Rustプログラミング入門、酒井 和哉、2019/10/13
Rustプログラミング入門、酒井 和哉、2019/10/13
509デフォルトの名無しさん
2019/10/20(日) 23:22:23.45ID:ADDbXmaX >>506
バグ発生率は、バスタブ曲線だろ。
初期によくバグる
土方をやってると、バグを多く出さないと、客に提出できないw
漏れは、平均的なIQ レベルより、間違いが少ないから、
いつも、アホみたいなバグを、わざと自分で作って、バグ発生数を増やしていたw
あらかじめ勉強している人は、滅多に間違わないから、バグ発生数基準だと困るw
一方、全く勉強していない香具師は、バグが多い
バグ発生率は、バスタブ曲線だろ。
初期によくバグる
土方をやってると、バグを多く出さないと、客に提出できないw
漏れは、平均的なIQ レベルより、間違いが少ないから、
いつも、アホみたいなバグを、わざと自分で作って、バグ発生数を増やしていたw
あらかじめ勉強している人は、滅多に間違わないから、バグ発生数基準だと困るw
一方、全く勉強していない香具師は、バグが多い
510デフォルトの名無しさん
2019/10/21(月) 03:46:22.99ID:15XQsNX7 俺は世界で一番この本を待ってた!!!!!
511デフォルトの名無しさん
2019/10/21(月) 13:21:09.04ID:c9dhXgWB 仕様書にバグが多いのはあれわざと仕込んでるのかなるほど
512デフォルトの名無しさん
2019/10/22(火) 20:56:02.71ID:pBzGAt4J ネストした構造体のコンストラクトパターンみたいなやつはもっとチュートリアルで
説明した方がいいんでないのとは思う。
多分めんどくさい書き方にしかならんからやらんのだろうけれど。
説明した方がいいんでないのとは思う。
多分めんどくさい書き方にしかならんからやらんのだろうけれど。
513デフォルトの名無しさん
2019/10/23(水) 15:46:33.91ID:/ejQejyx ?の便利さに感動している
514デフォルトの名無しさん
2019/10/23(水) 16:06:56.63ID:77J5IX+m え、なに?
文字化けしてますよ
文字化けしてますよ
515デフォルトの名無しさん
2019/10/23(水) 17:55:49.61ID:GdFoVnvN 三項演算子は便利だったなぁ、と他言語を思い出して感動してるってことかな
516デフォルトの名無しさん
2019/10/23(水) 18:12:17.77ID:AT7YtDx+ 普通にResultの話じゃなくて?
517デフォルトの名無しさん
2019/10/23(水) 20:07:35.94ID:r6mLYpNF 組み込みもネットワークツールもほとんどc以上の生産性を出すことないしな。。
一番有効な領域ってデバッガーじゃねーの?とは思う。
一番有効な領域ってデバッガーじゃねーの?とは思う。
518デフォルトの名無しさん
2019/10/23(水) 20:47:39.59ID:/ejQejyx Bookを6章まで読んだ俺が >>224 で書いたのが
https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=dc60559b7af47298d305be80b340ee98
?の便利さに気づいた俺が書いたのが
https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=308e7fe634f1e539c1f936c3989022f0
https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=dc60559b7af47298d305be80b340ee98
?の便利さに気づいた俺が書いたのが
https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=308e7fe634f1e539c1f936c3989022f0
519デフォルトの名無しさん
2019/10/23(水) 21:06:25.79ID:5Hzic27k .file_name()?.to_str()?.to_string()
Rustだっさ
Rustだっさ
520デフォルトの名無しさん
2019/10/23(水) 21:12:36.43ID:s8yqv2t4 公式に呼びやすい名前をつけないのがよくない
question mark operatorじゃわかりにくいから
error propagating operatorかerror handling operatorで
question mark operatorじゃわかりにくいから
error propagating operatorかerror handling operatorで
521デフォルトの名無しさん
2019/10/23(水) 21:26:40.40ID:AT7YtDx+ ダサいかどうかとかどうでもよすぎる
性能、書きやすさ、読みやすさ、安全性がすべて
性能、書きやすさ、読みやすさ、安全性がすべて
522デフォルトの名無しさん
2019/10/23(水) 21:31:02.23ID:5Hzic27k 性能 境界チェックのせいでだいぶおそい
書きやすさ 地獄
読みやすさ 悪夢
安全性 噂ではあるらしい
?まみれになるぐらいだったらヌルポで落ちても変わらんやん
どうせ無理に回復とかしないほうがいい類のだろ
書きやすさ 地獄
読みやすさ 悪夢
安全性 噂ではあるらしい
?まみれになるぐらいだったらヌルポで落ちても変わらんやん
どうせ無理に回復とかしないほうがいい類のだろ
523デフォルトの名無しさん
2019/10/23(水) 22:05:27.50ID:B/jcGWye ぬるぽで落ちるのは運が良かっただけで何でも起きうるし最悪スーパーハカーの餌食になる
?はちゃんとエラーで終了してくれる
って理解でおk?
?はちゃんとエラーで終了してくれる
って理解でおk?
524デフォルトの名無しさん
2019/10/23(水) 22:31:31.88ID:xt74prfP ヌルポって、javaのあれのこと?
シンタックスだけ比較して意味あんのかな
シンタックスだけ比較して意味あんのかな
525デフォルトの名無しさん
2019/10/23(水) 23:02:51.06ID:5Hzic27k526デフォルトの名無しさん
2019/10/23(水) 23:10:47.86ID:5Hzic27k モナドだろうがなんだろうがNullはNullだ
へたに回復してしまうとほかに影響が波及して大惨事につながりやすい
むしろ最初からNullにならないことを保証してくれる方がうれしい
なのになんでOKで帰ってきた結果からfileNaeme取るのまで?つけさせられとんじゃ
へたに回復してしまうとほかに影響が波及して大惨事につながりやすい
むしろ最初からNullにならないことを保証してくれる方がうれしい
なのになんでOKで帰ってきた結果からfileNaeme取るのまで?つけさせられとんじゃ
527デフォルトの名無しさん
2019/10/24(木) 00:25:03.31ID:M5uvwdA8 まあNULLで潔く死んでくれた方がってのは確かにあるわな。
528デフォルトの名無しさん
2019/10/24(木) 00:39:21.69ID:1+d2lllL エラーかどうかのチェックは、NULLかどうかのチェックとは違う
ここ大事なところなので間違えちゃダメ
ここ大事なところなので間違えちゃダメ
529デフォルトの名無しさん
2019/10/24(木) 01:03:58.72ID:LM2wjPr+ 潔く死んで欲しいなら明示的にunwrapなりexceptなりすればよい
バグなのか想定されたエラーなのかを区別して明示的にコーディングできるのがrustの利点では
バグなのか想定されたエラーなのかを区別して明示的にコーディングできるのがrustの利点では
530デフォルトの名無しさん
2019/10/24(木) 05:35:47.09ID:nklp1qoa OptionとかResultにケチつけてるのは加齢臭キツすぎる
531デフォルトの名無しさん
2019/10/24(木) 06:50:04.06ID:G12eboer 下手に回復して大惨事になるのは、下手だからでしょ
file_nameに?付けてるのはディレクトリの場合無いからでしょ
なんでそんなことが疑問になるのか分からない
file_nameに?付けてるのはディレクトリの場合無いからでしょ
なんでそんなことが疑問になるのか分からない
532デフォルトの名無しさん
2019/10/24(木) 09:03:26.66ID:M5uvwdA8 Optionとか中途半端でたちわりーわ。
てかrustみたいにライフタイム意識する言語の場合、あんまり役割ない気がするけどね。
てかrustみたいにライフタイム意識する言語の場合、あんまり役割ない気がするけどね。
533デフォルトの名無しさん
2019/10/24(木) 12:28:38.87ID:8vd5prrh メソッドチェーンの中で「owned -> borrowed -> owned」するのはアンチパターンだと思うんだよね
不必要な処理が入るし可読性も下がるのでいいことない
fn main() -> Result<(), std::io::Error> {
let path = std::env::current_exe()?;
let file = path.file_name().unwrap();
println!("{:?}", file);
Ok(())
}
不必要な処理が入るし可読性も下がるのでいいことない
fn main() -> Result<(), std::io::Error> {
let path = std::env::current_exe()?;
let file = path.file_name().unwrap();
println!("{:?}", file);
Ok(())
}
534デフォルトの名無しさん
2019/10/24(木) 12:51:50.95ID:1+d2lllL そもそものお題がこちら
>187 デフォルトの名無しさん2019/08/26(月) 20:55:57.18 ID:hNXwMePN >>206>>214>>224
>https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=8c44bed658726ada0deff031799664b7
>1. std::env::current_exe()で実行ファイルのフルパスを得る
>2. file_name()でファイル名だけにする
>3. to_str()で&strにする
>4. 途中でErrやNoneが返ってきた場合はデフォルトの値"foo"を使う
>
>ということをやりたいのですが、エラーでビルドできません。
>どのように書けばいいでしょうか?
>187 デフォルトの名無しさん2019/08/26(月) 20:55:57.18 ID:hNXwMePN >>206>>214>>224
>https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=8c44bed658726ada0deff031799664b7
>1. std::env::current_exe()で実行ファイルのフルパスを得る
>2. file_name()でファイル名だけにする
>3. to_str()で&strにする
>4. 途中でErrやNoneが返ってきた場合はデフォルトの値"foo"を使う
>
>ということをやりたいのですが、エラーでビルドできません。
>どのように書けばいいでしょうか?
535デフォルトの名無しさん
2019/10/24(木) 20:32:12.47ID:8vd5prrh >>534
お題があったのね
referenceを受け取ってreferenceを返す関数に抽出すればto_ownedやto_stringは不要
use std::path::PathBuf;
fn main() {
let path = std::env::current_exe().ok();
let file = file_name(path.as_ref()).unwrap_or("foo");
println!("{}", file);
}
fn file_name(path: Option<&PathBuf>) -> Option<&str> {
path?.file_name()?.to_str()
}
お題があったのね
referenceを受け取ってreferenceを返す関数に抽出すればto_ownedやto_stringは不要
use std::path::PathBuf;
fn main() {
let path = std::env::current_exe().ok();
let file = file_name(path.as_ref()).unwrap_or("foo");
println!("{}", file);
}
fn file_name(path: Option<&PathBuf>) -> Option<&str> {
path?.file_name()?.to_str()
}
536デフォルトの名無しさん
2019/10/24(木) 21:22:39.45ID:1+d2lllL 勉強になりました
let file = {|| Some(path.as_ref()?.file_name()?.to_str()?)}()
.unwrap_or("foo");
でも動くようですけど関数に抽出した方が良いですか?
let file = {|| Some(path.as_ref()?.file_name()?.to_str()?)}()
.unwrap_or("foo");
でも動くようですけど関数に抽出した方が良いですか?
537デフォルトの名無しさん
2019/10/24(木) 21:41:02.37ID:7Zw0jZ/m それ関数作って呼んでるのとほぼ同じだし名前がついてるかどうかの違いだから好きにせえ
538デフォルトの名無しさん
2019/10/24(木) 21:55:47.24ID:8vd5prrh Someで囲ったOptionalチェーンを返すクロージャってのが
Rustのイディオムとして認知されて来ればそういうやり方も有りかもだけど
俺は関数に抽出したほうが型が見えて読みやすいので良いんじゃないかと思う
Rustのイディオムとして認知されて来ればそういうやり方も有りかもだけど
俺は関数に抽出したほうが型が見えて読みやすいので良いんじゃないかと思う
539デフォルトの名無しさん
2019/10/24(木) 22:25:03.94ID:LM2wjPr+ try blockを待て
540デフォルトの名無しさん
2019/10/25(金) 20:57:15.75ID:ZeSKDyBG これまではto_string()がチェーン末尾だったからSomeに入れてたけど
末尾がto_str()になってOption返すから必要なかった
let file = {|| path.as_ref()?.file_name()?.to_str()}().unwrap_or("foo");
なぜ昨日は気が付かなかったんだろう……
末尾がto_str()になってOption返すから必要なかった
let file = {|| path.as_ref()?.file_name()?.to_str()}().unwrap_or("foo");
なぜ昨日は気が付かなかったんだろう……
541デフォルトの名無しさん
2019/10/25(金) 21:01:12.42ID:d+xtEa5D try block
ずっと待ってるあなたのことを
意味もなくクロージャで囲む日々
ずっと待ってるあなたのことを
意味もなくクロージャで囲む日々
542デフォルトの名無しさん
2019/10/25(金) 21:29:24.66ID:JK+efETy モナド早くきてくれー
543デフォルトの名無しさん
2019/10/25(金) 21:51:56.35ID:AfveIyxL モナドられると、ややこしい人が顔出してくるんでノーセンキュー
544デフォルトの名無しさん
2019/10/26(土) 06:18:18.43ID:ajDsHp6T 関数型信者がうるさくなった言語は衰退する
545デフォルトの名無しさん
2019/10/26(土) 09:43:29.54ID:eCInqrX9 関数型ことごとくすたれてない?
546デフォルトの名無しさん
2019/10/26(土) 10:13:18.36ID:ERKSSgX1 モナド(高階型)来てもいいんじゃない?OptionとResultで同じようなことやってるし
547デフォルトの名無しさん
2019/10/26(土) 13:48:16.66ID:3B/2CauT オプショナルチェーンを矛盾なく繋げるモナドが入れば覇権だと思う
正直それだけできれば小難しい理論はいらないし
正直それだけできれば小難しい理論はいらないし
548デフォルトの名無しさん
2019/10/26(土) 14:36:55.83ID:SyjizfQh チェーンは滅んでほしい
549デフォルトの名無しさん
2019/10/26(土) 14:53:14.83ID:z1scFH36 チェーンってひとくくりにするなよ。メソッドチェーンは糞だが。
550デフォルトの名無しさん
2019/10/26(土) 15:11:41.74ID:eCInqrX9 チェーン評価ってのも聞いたことがあるな
551デフォルトの名無しさん
2019/10/26(土) 16:45:06.90ID:ZMkO6rZZ552デフォルトの名無しさん
2019/10/26(土) 19:08:07.88ID:2tVQRscY この板で否定的な言い分を魔に受けないほうがいい
冗談で言ってるか、冗談みたいな馬鹿の言い分だから
冗談で言ってるか、冗談みたいな馬鹿の言い分だから
553デフォルトの名無しさん
2019/10/26(土) 23:02:43.13ID:JvDQOGiO おっぱい好きだけど爆乳は好きじゃない。
554デフォルトの名無しさん
2019/10/26(土) 23:16:28.89ID:yM1vAjNy 奇乳きらい
556デフォルトの名無しさん
2019/10/27(日) 20:10:25.95ID:M2w7+A6p π
557デフォルトの名無しさん
2019/10/27(日) 21:47:29.52ID:29EcE5aV 雄π
558デフォルトの名無しさん
2019/10/28(月) 07:30:15.50ID:JN5lVu+u ちっぱいだいすき
559デフォルトの名無しさん
2019/10/28(月) 11:04:07.07ID:24j/k5v2 たかが乳ですら意見割れてるのに関数型の話がまとまるわけないな
560デフォルトの名無しさん
2019/10/29(火) 22:37:06.24ID:mgVguoQK うまいことドメイン駆動設計をオブジェクト指向から切り離せないかな?
Javaでアーキテクチャを考えると、「このコードはどこに書くべきか」がずっと分からなくなる
関数のシグネチャ読めばそれがMなのかCなのか業務ロジックなのか入出力なのか、全部分かるように書けないものか
Javaでアーキテクチャを考えると、「このコードはどこに書くべきか」がずっと分からなくなる
関数のシグネチャ読めばそれがMなのかCなのか業務ロジックなのか入出力なのか、全部分かるように書けないものか
561デフォルトの名無しさん
2019/10/29(火) 23:45:32.33ID:2LlnWJID スレチ? それどもRustで考えてるのかな
JavaでもC#でもシグニチャ読めばMなのかCなのかくらいはわかるように書けると思うが
それはいいとしてDDDの本質はOOとは関係ないよ
Functional DDDの本がScalaとF#を例にしたのがそれぞれ出てるから読んでみるといいかも
F#のほうの著者のサイトみればRustのEnumでも同じような事できるのがわかるはず
https://fsharpforfunandprofit.com/ddd/
JavaでもC#でもシグニチャ読めばMなのかCなのかくらいはわかるように書けると思うが
それはいいとしてDDDの本質はOOとは関係ないよ
Functional DDDの本がScalaとF#を例にしたのがそれぞれ出てるから読んでみるといいかも
F#のほうの著者のサイトみればRustのEnumでも同じような事できるのがわかるはず
https://fsharpforfunandprofit.com/ddd/
562デフォルトの名無しさん
2019/10/30(水) 00:09:30.97ID:FUp1HJ0i はえ〜
563デフォルトの名無しさん
2019/11/01(金) 14:20:55.93ID:uczmPzhO Vulkanが公式でRustをサポートしてくれればRust製のゲームとかもっと出てくるのかなぁ
564デフォルトの名無しさん
2019/11/01(金) 15:16:52.33ID:tfmUKGIE enumの配列はメモリやばい?
https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=0eeab60af9f7385db00275b2d168ac2c
https://play.rust-lang.org/?version=stable&mode=debug&edition=2018&gist=0eeab60af9f7385db00275b2d168ac2c
565デフォルトの名無しさん
2019/11/01(金) 15:49:15.26ID:zrbJp7o3 >>564
enum MyEnum {
Foo,
Bar(i32),
Baz(i32, i32, i32, i32, i32),
}
今のRustはEnumの一番大きいvariantに合わせてメモリを確保する
Baz(i32, i32, i32, i32, i32)が、4バイト x 5 = 20バイト
どのvariantかを示すTagバイトで+1バイトと パディングで+3バイト=24バイト
配列の要素数が3なら24 x 3 = 72バイト
enum MyEnum {
Foo,
Bar(i32),
Baz(i32, i32, i32, i32, i32),
}
今のRustはEnumの一番大きいvariantに合わせてメモリを確保する
Baz(i32, i32, i32, i32, i32)が、4バイト x 5 = 20バイト
どのvariantかを示すTagバイトで+1バイトと パディングで+3バイト=24バイト
配列の要素数が3なら24 x 3 = 72バイト
566デフォルトの名無しさん
2019/11/01(金) 19:25:13.98ID:+nuKsb5/ 現職エントリ()のドワンゴや
タイ全裸Wantedlyの推してる言語って時点で使う気起きなくなるよね
タイ全裸Wantedlyの推してる言語って時点で使う気起きなくなるよね
567デフォルトの名無しさん
2019/11/01(金) 19:29:17.10ID:CgKHPMXI タイ全裸って?
568デフォルトの名無しさん
2019/11/01(金) 21:28:00.41ID:/XSkjXU3569デフォルトの名無しさん
2019/11/01(金) 21:55:41.28ID:/XSkjXU3 どんなに「こんなに素晴らしい機能がある言語!」とか言われても
「でもあの個人情報お漏らし泥箱や現職エントリ()ドワンゴとかDMCA乱用のWantedlyとかが推してる時点で……」ってなるのが
正しい社会人としてのあり方
「でもあの個人情報お漏らし泥箱や現職エントリ()ドワンゴとかDMCA乱用のWantedlyとかが推してる時点で……」ってなるのが
正しい社会人としてのあり方
570デフォルトの名無しさん
2019/11/01(金) 22:09:13.26ID:tfmUKGIE >>565
つまりどんなenum作るでもたくさん値を持たせないほうが余計なメモリ使わずベストってことか
つまりどんなenum作るでもたくさん値を持たせないほうが余計なメモリ使わずベストってことか
571デフォルトの名無しさん
2019/11/01(金) 22:57:41.39ID:RJfnLfVj アンチドワンゴがみんなC言語使ってると思うと抜ける
572デフォルトの名無しさん
2019/11/01(金) 22:57:51.68ID:RJfnLfVj ↑思うとワロタ
573デフォルトの名無しさん
2019/11/02(土) 02:27:34.58ID:lY37zOLC まあ正直、いまだにえんじにゃーのファッションって部分がでかいわな。
574デフォルトの名無しさん
2019/11/02(土) 07:38:49.45ID:m1PoQplx 他人がなに使ってのかチラチラ伺いながら自分の使うもの決めるのか
小物すぎるだろ
小物すぎるだろ
575デフォルトの名無しさん
2019/11/02(土) 13:57:08.64ID:uxGQ1L3w >>574
つっても現職エントリ様やタイ全裸と一緒にされたくはねえしなあ
つっても現職エントリ様やタイ全裸と一緒にされたくはねえしなあ
576デフォルトの名無しさん
2019/11/02(土) 14:20:09.97ID:m1PoQplx 同じ言語使ってるだけで同一視すんのはお前だけだよ
577デフォルトの名無しさん
2019/11/02(土) 14:32:51.71ID:ygDc/lgM それらの企業はRustなんか採用する前からボロボロだっただろ。
578デフォルトの名無しさん
2019/11/02(土) 15:40:16.76ID:lY37zOLC んでもって一発逆転をねらって水物のに飛びつくっていうアンチパターンね。
579デフォルトの名無しさん
2019/11/02(土) 20:44:05.92ID:J/DFBFnF あそこは一人が有名なだけだと思うがな
580デフォルトの名無しさん
2019/11/02(土) 22:56:34.85ID:VM95VN5u https://github.com/woboq/qmetaobject-rs
このcrateの中で"rust!"というマクロが使われてるんですがクレート内や依存するクレートの中を探してみても定義してる箇所が見つかりません
どこで定義してるのかわかる方いませんか?
このcrateの中で"rust!"というマクロが使われてるんですがクレート内や依存するクレートの中を探してみても定義してる箇所が見つかりません
どこで定義してるのかわかる方いませんか?
581デフォルトの名無しさん
2019/11/02(土) 23:31:33.69ID:t8MMHk4t■ このスレッドは過去ログ倉庫に格納されています
ニュース
- 空自機レーダー照射、音声データ公開 中国 ★2 [蚤の市★]
- 中国とロシアの爆撃機、日本周辺で共同飛行 [少考さん★]
- 「中国側も日本機のレーダーを感知していた」 中国メディアが報道 [♪♪♪★]
- 【YouTuber】バイク事故で入院のゆたぼん、振込で「お見舞金」募る [muffin★]
- 堀江貴文、キャッシュレス非対応の店にモヤッ 『PayPay』立ち上げの人物にまさかの直談判「現金決済しかできないんだけど…」 [冬月記者★]
- 高市早苗首相、消費税減税に後ろ向き 足かせはレジシステム? 「責任ある積極財政」期待高いが [蚤の市★]
- 防衛省、中国を完全論破www 「事前通告があったのは海自であって空自ではない」 高市早苗勝利 [175344491]
- 【悲惨】中国軍が自衛隊に「事前通告」し自衛隊も返答した音声が公開されてしまうwwwこれは高市チェックアウトゕ★4 [597533159]
- 【悲報】JA「全然米が売れなくて倉庫を圧迫してる。助けて!」米卸売り業者「安売りしたら赤字になる…助けて!」 [802034645]
- 元統合幕僚長「演習通告の音声は公開されたが、レーダー照射時のものではない」高市政府「www」 [834922174]
- 韓国政府、高市早苗の「竹島領土」発言にブチギレwwwwwwwwwwwwwwww [834922174]
- 【急募】佐藤健(37)さんが急にバカにされ始めた理由WWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWWW
