Rust part17

■ このスレッドは過去ログ倉庫に格納されています
2022/10/06(木) 22:43:13.96ID:Re0G7B20
公式
https://www.rust-lang.org/
https://blog.rust-lang.org/
https://github.com/rust-lang/rust

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

日本語の情報
https://rust-jp.rs/

※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 part16
2022/10/11(火) 19:16:08.16ID:Bl5ahscm
moveがmemcpy呼び出しになるかどうかはあくまでも実装の話で
move自体のセマンティクスはデータのコピーを要求しないということが言いたいのでは

最適化offにして構造体サイズ大きくするとmemcpy呼び出されるから、memcpy起きないというのは嘘だけど
2022/10/11(火) 19:23:40.64ID:61VrJvDY
>>110
あくまでもRustの言語レベルでの抽象的なレベルではムーブはムーブであってビットコピーの保証はそこには一切ない
そして我々は抽象的な概念に基づいてプログラミングすればよい
生成コードはムーブという抽象的な概念だけを保証して最適化される
だからこそ生成コードではムーブでビットコピーが消え得る
2022/10/11(火) 19:29:43.10ID:61VrJvDY
>>111
memcpyはたまたまムーブの最適化なしのデフォルト状態で行われる可能性のあるコードにすぎないね
Rustの言語としてはmemcpyが必ず行われることなんて全く保証しない
ムーブはもっと上位の概念であってRustが保証するのはその上位の概念のみだね
2022/10/11(火) 19:51:08.13ID:Bl5ahscm
>>113
はいはい、>>111は誤読されかねない表現でしたね
(常に)memcpy起きないというのは嘘
と読み替えておいてください

元々の>>94のRefCellやMutexの方が効率的かという質問については、そういう場合もある、というのが答えで良いですよね

生成されるコードがどうなるかは最適化レベルや周囲のコードに依存するわけで、必ずどちらかが効率が高いと言えるようなものではない
感覚的には格納するデータサイズが大きい方がRefCell/Mutexが有利に、小さければCellが有利になりそうだけど、
ちゃんと測定したわけではないので実際のところは分からない
2022/10/11(火) 20:23:10.29ID:iRs2n6UT
>>114
実はRefCell構造体のメンバーにCellが使われている(現状)

使用されるメモリサイズ
Cell<T> ← Tと同じサイズ
RefCell<T> ← Tのサイズに加えてborrow管理のために内部で使用するCellサイズ分加算

動作コスト
Cell<T> ← (利用後すぐset()すれば)Tと同じコスト
RefCell<T> ← Tのコストに加えてborrow管理のために内部で使用するCellの読み書き操作コスト分加算
2022/10/11(火) 21:44:42.19ID:P/g9+OyI
ホント笑っちゃうくらい嘘を散りばめてくるよねw
117デフォルトの名無しさん
垢版 |
2022/10/11(火) 21:58:52.19ID:lchMb24F
>>114
RefCellやMutexの方が効率的かという質問については
代用として使うならばそれらの方が遅いでしょう
RefCellはボローチェック処理が必ず入ります
Mutexは排他的ロック処理が入るのでさらに遅いです
2022/10/11(火) 22:06:38.86ID:Bl5ahscm
>>115
動作コストはT全体を置き換える場合だよね
TがVecで、一要素追加する場合のコストも計算してみてよ

>>117
ボローチェック処理が最適化で消えないことは保証されてるの?
ボローチェックや排他処理のコストはCellで発生するデータコピーより必ず高コストになるの?
2022/10/12(水) 14:10:22.75ID:IRDyECLz
ムーブ元の変数が使われないことがわかってるんだから
その変数の領域を使い回せばよいだけでしょ?
普通に考えてコピーとか起きないと思うんだが
2022/10/12(水) 18:26:20.15ID:R7/twQcO
自称分かってる人同士のケンカ
2022/10/12(水) 21:47:16.08ID:TdLmkMrU
RefCell使うのはアロケーションを避けたいからでしょ
2022/10/12(水) 23:29:45.96ID:MmGzrhE7
Cell<T>もTもメモリ領域は同じサイズで性質が異なるだけなのね

Cell<T>の更新はこうなるから
(1) メモリ→value読み出し // take()その1
(2) メモリ←default-value書き込み // take()その2
(3) valueを更新してnew-value
(4) メモリ←new-value書き込み // set()
コンパイラがまともなら(2)の部分はムダと判断して無くせそうね

さらにvalueの更新内容によっては (例えば足し算など算術の場合など)
その後にLLVMが最適化でメモリに対して直接実行する命令コードにするだろうから読み出し書き込みも消えるわけね
2022/10/13(木) 01:04:10.25ID:v9vBAx/l
CopyじゃないStringやVecで&mut selfとるメソッドを試せば違いが分かるよ
2022/10/13(木) 02:00:58.56ID:m/K7Pbd2
Copyを実装しない適当な構造体
#[derive(Default)]
struct Foo {
 inner: i32,
}
の &Cell<Foo> と &mut i32 の両方のケースで
>>122の最適化により同じ生成コードとなるから
Copyを実装してるか否かは関係ないみたい
2022/10/13(木) 03:36:21.71ID:Oo+uXzBV
>>124
それだと簡単にインライン化出来るからね
アロケーションが必要な型という意味でCopyじゃないStringやVecと言ったんだけど
Dropと言ったほうがよかったのかな
2022/10/13(木) 04:02:18.88ID:cMF4wuqy
アロケーション発生しなくても(i32, i32)とかにするだけでもう生成アセンブリ同じじゃなくなるね
2022/10/13(木) 08:01:16.32ID:wSzwAK9q
コンパイラが>>122
(2) メモリ←default-value書き込み
を削除する最適化をすれば
Copy実装なかろうがヒープを使おうが
生成コードは同じになるんじゃね?
2022/10/13(木) 15:12:31.34ID:FWxI+s/s
>>126
Copyにしてget/setにすれば同じになるかも
2022/10/13(木) 15:31:24.77ID:WZ96xtHr
macOSにおけるFirefoxのパフォーマンスを劇的に改善した方法とは?
メモリアロケーター「jemalloc」を独自にカスタマイズしたアロケーターを用いてメモリ管理を行っています。Firefoxのアロケーターでは並列処理時のロックを効率的に行うためにOSごとにネイティブなAPIを使用しているとのこと。このロックAPIとして、macOSではOSSpinLockが用いられていました。
https://gigazine.net/news/20221011-firefox-macos/

これって、Rustのメモリアロケーターがjemallocを基にしたRust実装になってるってことだよね?大昔はjemallocだったという話で
2022/10/13(木) 16:10:29.83ID:PFF+OL8h
>>129
現在の Rust はデフォルトではシステム標準のアロケータを使うはず。
一時期は Jemalloc (のバインディング) を使っていたけどだいぶん前にやめてる。
やりたければアロケータの差し替えは簡単に出来るので
大きなプロジェクトだと (必要な性質にあわせて) 専用のアロケータを持っていることはあるかも。
2022/10/13(木) 16:44:36.94ID:7pqOU2dm
>>129
この記事はrustまったく関係ないよ
Firefoxはすべてがrustで書かれているわけではない
2022/10/13(木) 17:51:45.20ID:Fb+ro4ZF
>>129
Rustでは1.32.0(2019/01/17)から jemalloc がデフォルトでなくなりましたが、理由はjemallocのほうがマルチスレッドでは
微妙に低負荷で速いですが、コンパイルバイナリで300kB追加されるのとjemalloc自体のバグなどで問題が出ていたから。

Firefoxは恐らく、Cargo.tomlでアロケターをjemalloc系(多分tikv-jemallocator)に変えていて速度を稼いでるのでは?
(完全に想像だけど・・・)

Rust で jemalloc を使ったら並列処理が速くなった
https://zenn.dev/hankei6km/articles/using-jemalloc-in-rust-speeds-up-parallelism
2022/10/13(木) 20:45:15.45ID:7pqOU2dm
>>132
C++とのinteropあるからrust側はC++のallocator呼び出しているだけで
独自に(オリジナルの)jemallocをリンクすることはしてないと思うよ
2022/10/13(木) 23:11:21.07ID:Fb+ro4ZF
>>133
元記事見ると、jemallocそのものを一部、リプレースして書き換えてるみたいね。firefoxのレタリングエンジン自体はservoで
tikv-jemallocatorを使ってるみたいだけど、リンクしてるのはその通りオリジナルではなく書き換えたjemallocになってるみたい
https://github.com/servo/servo/blob/master/components/allocator/Cargo.toml
https://searchfox.org/mozilla-central/source/memory/replace/logalloc/README
2022/10/13(木) 23:14:01.26ID:Fb+ro4ZF
いや動的リンクはしてないのかな?jemallocソースをリプレースして実行ファイルに組み込んでる
2022/10/13(木) 23:25:53.83ID:cMF4wuqy
Firefoxはservo使ってない定期
2022/10/14(金) 01:05:31.38ID:2gl6G2n+
>>127
コンパイラはそんなに賢くないってことじゃね?
2022/10/14(金) 10:36:15.19ID:P+TQoSXr
複オジの嘘をまともに相手してたらキリが無いよ
2022/10/14(金) 11:07:41.50ID:t+3JDnfr
おじさんなんで最近こっちにいるの?
隔離スレが機能しなくなったのとリンクしてるのが面白い
2022/10/14(金) 21:09:01.17ID:iCatm8xv
>>136
シッタカも出来ないかまってちゃん不定期
https://searchfox.org/mozilla-central/search?q=servo%2F&path=&case=false®exp=false
2022/10/15(土) 00:38:51.20ID:ZRY2KlKK
>>140
servoを構成するコンポーネントのうちfirefoxに取り込まれたstyloしか登場してないように見えるが
2022/10/15(土) 10:12:30.40ID:kho15VFl
複オジにマジレスしても意味ないよ
2022/10/15(土) 21:19:13.19ID:Sue68NiD
お前の主張は「Firefoxはservo使ってない」であって「styloしか登場してない」では無い、そもそもstyloだけじゃない
途方もなく低い技術力でマウント取りたいことが生きがいの薄汚いオッサン
2022/10/16(日) 01:52:37.08ID:xR2EqnpB
servoは独立したレンダリングエンジンだからservoを使うと言えるのはgeckoを丸々置き換えた場合では
というかallocatorの話はどうなったんだ
2022/10/16(日) 13:06:47.08ID:I4ihc4bO
「Firefoxはservo使ってない」定期、顔真っ赤の話しそらしオジサン、geckoを丸々置き換えた場合とか言い出したw
「styloしか登場してない」も消えたwww
あんたはアロケーターなんて興味ないだろwww
したけりゃしろ。自分からは詳しい技術的な話何もできない、マウントしたいだけ、業界にいる寄生虫
2022/10/16(日) 16:22:20.12ID:xR2EqnpB
>>134
firefoxのレンダリングエンジンはservoじゃなくてgeckoのままだよ
servoは次世代ブラウザ向けのレンダリングエンジンの実装を模索するための実験プロジェクトで、geckoを置き換えることを意図したものではないよ
servoの一部のコンポーネントは完成度が高くgeckoに取り込まれてはいたので、
servoが発展していったらgecko全体がservoで置き換えられる未来もありえたけど、
mozillaがservoの開発者レイオフしちゃったのでその可能性もなくなっちゃったかと

動的ライブラリや静的ライブラリとして他のアプリケーションにリンクするcrateの場合、リンク先のアプリケーションバイナリに含まれる(または、動的リンクされる)allocatorを利用するのが普通なので、
geckoのservo由来のrustコードもそうなっていて独自にallocatorを定義することはしていないんじゃないかな
2022/10/16(日) 18:59:51.30ID:qTG+zV4j
rust関係ないけどjemallocを日本語で読む時
ジェ-マロック派?それともジェム-アロック派?
2022/10/16(日) 20:24:24.45ID:xR2EqnpB
Json Evans mallocだからジェーイーマロックって呼んでる
2022/10/16(日) 22:45:33.29ID:SvF0Fhwf
それを言うなら malloc が (たぶん) memory allocate の略なんだから
ジェーイーエムアロックと呼ぶのが筋というものでは……。

俺はそもそも口頭で読み上げる機会がないから考えたこともなかった。
2022/10/16(日) 23:11:22.79ID:sz/XVYMu
開発者本人の動画見るとジェイ・マロックに聞こえるが
ジェイ・イー・マロックが短くなってるだけかなこれ
https://youtu.be/RcWp5vwGlYU?t=79
2022/10/17(月) 18:50:40.32ID:q3uOCHzu
>>146
servoじゃなくてgeckoのままは言い過ぎです、現にベクター系の2Dや、Canvasなどに使用するレンダラーはservo由来の
レンダラーが使用されます。その他はその通りでしょう
2022/10/17(月) 19:52:15.71ID:gBqRn20s
>>151
geckoを構成するコンポーネントの入れ替わりはあったけど
firefoxのレンダリングエンジンは生まれたときからずっとgeckoだよ
逆にgeckoじゃなかったら何なんだ
2022/10/17(月) 19:58:16.39ID:gBqRn20s
>>151
FirefoxにRustのコンポーネントを多く導入したQuantumプロジェクトの説明でも、ServoのコンポーネントをGeckoに取り込むと言っていて、
Geckoを置き換えるとは言っていない
https://wiki.mozilla.org/Quantum
2022/10/17(月) 21:29:09.32ID:MqsTBCMt
Rust関係ないからFirefoxスレでどうぞ
2022/10/17(月) 22:43:40.85ID:GuOtjDmV
もうその話題はいいよ
しつこいな
156デフォルトの名無しさん
垢版 |
2022/10/18(火) 10:08:56.84ID:1nhFYrk9
しつこくやって『Cell<T>はTと同じコスト』(真っ赤な嘘)を流したかったんでしょw
2022/10/18(火) 11:26:14.64ID:f2tKHPpy
termuxのrustずっとバージョン不整合で動かないな
rustupじゃそもそもインストール出来ない
158デフォルトの名無しさん
垢版 |
2022/10/18(火) 12:14:53.29ID:PMaXG0c3
>>157 俺は普通に動いてる
一応聞きたいんだけど、TermuxはF-Droidから入れたよね?
Play Store版はもうメンテナンスされてないから色々バグると思う
2022/10/18(火) 12:23:43.08ID:lAl7R2Of
>>153
あー、それ見てワカッタ風吹かしてんのな。「Rustのコンポーネントを多く導入」と言ってる時点で、styloだけじゃないし
2DレタリングのwebrenderもservoからのRust製だわ。”誰も”Geckoを置き換える=Geckoが無いなんて言ってない
https://github.com/servo/webrender
2022/10/18(火) 14:03:11.76ID:f2tKHPpy
>>158
F-Droidから入れてる
何故かlibllvm-14.soのリンクが出来ないと怒られてしまう
で入ってるllvmのバージョンが更新で15に上がってしまってる状態
俺環かも知れんね
161デフォルトの名無しさん
垢版 |
2022/10/18(火) 14:27:25.95ID:jB7ekv9R
あんまり自信がある訳じゃないんだけど、カーネルが64bitでユーザーランドが32bitみたいな環境だったりしない?
2022/10/18(火) 14:27:28.03ID:SAVTW7Pl
>>159
Geckoのコンポーネントを置き換える

Geckoを置き換える
は全然意味が違うでしょ

まあ日本語の問題で意図してるところは食い違ってないから反応するのはこれで終わりにするわ
2022/10/18(火) 14:32:25.86ID:JxWDHfdB
グーグル、Rustで書かれたセキュアなOS「KataOS」を発表
https://japan.zdnet.com/article/35194751/
2022/10/18(火) 15:37:54.47ID:f2tKHPpy
>>158,161
すまぬ色々やってる中で入れたnightlyの影響だった
お騒がせした
2022/10/19(水) 03:30:17.24ID:cvhlJCwu
fucsia「僕はいらない子なの?」
2022/10/19(水) 07:05:26.07ID:CJepXKVA
>>163
昔「おおっ!!!あのグーグルがまた何か新しいことを始めたぞ!すごそうだ!」
今「まぁーーたはじまったよ・・・」
2022/10/19(水) 11:11:44.42ID:H7L8/zfi
Googleが立ち上げては潰してきたサービス一覧「Killed by Google」
killedbygoogle.com
2022/10/19(水) 11:23:33.38ID:iHEkpSLR
何も産まないよりは健全よね
2022/10/19(水) 11:35:06.09ID:Dqx/r4FW
役に立つかどうかわからんものに手を出せる余裕が
個別の結果に関わらず
部分的な成果の積み上げで会社をブーストさせるんよ
2022/10/19(水) 11:38:58.17ID:Sj+PYk/j
まあ堅そうな名前ではあるな
2022/10/19(水) 12:24:59.02ID:j2B3ovC/
IoT向けOSって言ってるし組み込みOSなんて元々百花繚乱だろ。
組み込み機器の脆弱性対応なんて大変だし、そもそもその手の脆弱性が入り込みにくい言語を採用するのは合理的だと思う。
2022/10/19(水) 12:46:33.84ID:xwPbcXKV
日本ってやらない理由、出来ない理由並べる奴が多いよな
多くの日本企業よりGoogleの方が多く生み出しているし世の役に立っている
2022/10/19(水) 12:48:40.76ID:aUvB23KT
南朝鮮ってやらない理由、出来ない理由並べる奴が多いよな 多くの南朝鮮企業よりGoogleの方が多く生み出しているし世の役に立っている
2022/10/19(水) 13:00:38.45ID:xwPbcXKV
Rust Foundationへの参加はNECやFUJITSUよりSamsungの方が早いんじゃないかなぁ
国内大手で積極的にRustを推していこうなんて所はなさそうに見えるし
組み込みのRenesasとかもやる気なさそうだしな
2022/10/19(水) 19:58:52.34ID:+MAum9P/
出来ない理由を考えるのではなく!
176デフォルトの名無しさん
垢版 |
2022/10/19(水) 21:32:43.94ID:mHa4T+cl
日本が後進国になってきたのは政治の責任が大きいけど
IT分野で遅れてるのは総じて教育水準が低いからだよ
2022/10/19(水) 22:51:58.05ID:owfoFln4
民主主義国は政治の責任=有権者の責任
178デフォルトの名無しさん
垢版 |
2022/10/19(水) 23:03:48.16ID:kLmY2FYt
>>177
利権差配と中抜きしか考えない国賊を礼讃して
統一創価売国与党に投票し続けたやつの責任だろ
2022/10/20(木) 00:02:58.60ID:ce/AQgdF
まったく読むに値しないクソ書き込みの羅列の中で
>>170 だけが唯一価値ある輝きをはなっている
2022/10/20(木) 13:00:10.90ID:Px+TgmX7
在日だらけ。IT分野で遅れてるのは米国(英語圏)・中国の人口差だし、日本の人口減でもある。
世界中で、歴史上、移民以外で人口減を解決した国は1つもない
そういう意味では韓国などはでは優れたソフトウエアは1つもない。馬鹿な半島はAndoridのOSを
握ろうとTizenなどというゴミを掲げたが、食いついたのはNTTドコモぐらい
いま韓国で起こってるのはソフトウエアサービスの””ガラパゴス化””であり、GoogleやAmazon
Apple Payなどに対して参入障壁を作り防御するような、大昔の古臭い日本あった不公正貿易。
民主党政権時代だって3年あったわけだが、利権と中抜きしかしてない。やったことは仕分けだが
1つも役に立たないどころか、地方医療を崩壊させ、気象変動へ対処できるインフラ投資を
一時的止めた害悪しかなかった。その他にも野田政権による執拗な消費税増税もあった。
今彼らは英国が減税を匂わせただけで大混乱していることを見ずに、消費税ゼロを掲げている。

卑劣にも矛先を反らし、リベラルなのに移民反対派で、リベラルなのに「国賊、売国」などという言葉を使い、
まるで戦争前夜か、共産主義や社会主義のような物言いをするアホが出る時点で若い人の人材不足といえる。
2022/10/20(木) 16:07:13.38ID:zGrDbuOl
英国が減税しただけで、支持率が7% になったw
米国の金利上昇で、韓国の金利も0.5% 上がったw

なのに、借金が1千兆円もある日本の金利が、0%w

狂った世界中の経済学者達が、日本は不正をしている。
日本国債は破綻しなければおかしいと言ってるw

外人が幾ら日本国債を売っても、金利が上がらない。
破綻しないw

いい加減、借金が1千兆円もあるという財務省の嘘に気付け!w

YouTube で勉強しろ。
【TVじゃ絶対言えない話】国の借金は嘘!?中田敦彦が解説
2022/10/21(金) 19:45:15.15ID:xXJwtueL
WEB+DB PRESS、何度目のRust入門なんだい?
183デフォルトの名無しさん
垢版 |
2022/10/21(金) 20:10:13.59ID:HoCfXQGg
Rust入門は初めて
2022/10/21(金) 21:22:06.02ID:2TP3mE4K
pythonとrustを一通り試してみた
for文の入れ子で外側のforをbreakできるとか、数値を1_000_000と表現できるとか、
そんなところでrustのほうが行き届いている感じがした

ただpythonのリスト内包表記、添え字の-1で配列の一番最後を表すとかそんなのは便利だな
2022/10/21(金) 21:26:14.55ID:gnp0h5uN
Rust入門という感じではないな
Rustを使ったWeb入門という感じ
186デフォルトの名無しさん
垢版 |
2022/10/21(金) 22:25:35.46ID:YCtBy6Lb
>>185
Web+DB Press読者は簡単なWebアプリ開発はいろんな言語で経験済みで理解しやすいだろうからチュートリアルの対象に選んだだけでは?
2022/10/22(土) 13:19:56.51ID:OES5lhv+
>>186
普段読まないけどRustなので買ってみた
なかなかわかりやすかった
基本文法の解説が明らかに足りないけど
サンプルを理解するだけならこの程度で良いのか
面倒な部分が表に出ないようにうまくサンプルを調整してるし
2022/10/22(土) 21:03:49.60ID:Vp6sRBIs
借用がどうGCに関係するのかよくわからない
うまく説明しているサイトはないですか?
2022/10/22(土) 21:38:11.55ID:OES5lhv+
まずスタックとヒープを理解せよ
これは口を酸っぱくして言ってる
でないとRustは理解できない
190デフォルトの名無しさん
垢版 |
2022/10/22(土) 21:39:04.07ID:PO/EA+oY
とりあえずThe Bookの4章
https://doc.rust-lang.org/book/ch04-02-references-and-borrowing.html

Rustをそれなりに習得しようと思うなら
The Bookとオライリー本を読むのが一番近道
2022/10/22(土) 23:56:07.88ID:OES5lhv+
両方とも初心者には辛いよなあ
わかりやすい入門書が待たれる
2022/10/23(日) 00:22:18.48ID:LnniM1YV
借用するときにデータをスタックに積む
スコープを抜けるときに一気にpopするので
GCがいらない、つまり、早い
heapだとGCのときにデータの移動が必要になる
ので遅い
この理解であってる?
193デフォルトの名無しさん
垢版 |
2022/10/23(日) 00:29:31.67ID:jNoMv4k0
ポインタとか参照とか他の言語で扱ったことない?
2022/10/23(日) 00:44:57.32ID:h/oZflgJ
heapが遅いの要因は、メモリの割り当て解放処理があるから処理量が多いとか、
割り当てた領域がバラバラになることでキャッシュ効率がさがることとかかと
195デフォルトの名無しさん
垢版 |
2022/10/23(日) 13:47:22.46ID:/F23RQvw
ページング処理みたいなのが、ヒープだと2重に行われるんじゃないの?
2022/10/23(日) 14:14:22.62ID:ioVOctq2
>>192
Rustでのその辺のメモリの動きはオライリー本に詳しく書いてあった気がするから読むべし
197デフォルトの名無しさん
垢版 |
2022/10/23(日) 15:30:09.10ID:t4UBj2/5
>>192
>>195
お前ら、具体的にどうされてるからスタックだと速いかわかって無いだろ、、、
2022/10/23(日) 18:33:19.09ID:QEVtmAwk
>>192
そんなに物事が単純なら良かったのに...
”スコープを抜けるときにGCがいらない、つまり、早い”、これは間違いでもある。インライン展開されるような高階関数なら良いが
ループ中でアロケーションしてしまうような記述をすると、その度に確保・解放されるので非効率になりかねないし、借用による
メモリーの管理ではないが、参照カウントを使用するSwiftでは、ループでボトルネックになることはある。
このためRustでは高階関数で書く事が一般的に(分かり易く)良い事とされる。あとスタックでどの言語も大体はスコープ外で
消えるのでヒープとスタックの区別は付けましょう

独立したGCスレッドが動く言語だと、スコープ外れでGCするとは限らないので、速い場合がある。一方で、高負荷な環境では
GCスレッドがありで、回収などインターラプトが入るのでRustが有利になる(=※こちらのほうがRustが重要視される理由)
いわゆるSTOP THE WORLD(DIO様風)だ。ただ、これが無ければ良いということではなく、循環参照などを作らなければ
問題ないという話で循環参照を作ってしまうのであれば、独立したGCスレッドは便利でもある

”GCのときにデータの移動が必要”になるかどうかは、GCのアルゴリズム次第であり、厳密には”データの移動が必要”になるのは
メモリーのフラグメント解消つまりコンパクション処理によるところが大きい。これは、近代的なOSでは似たような事を行っていて
これ自体が速度に大幅に影響を及ぼすとは言い難い
2022/10/23(日) 19:03:12.25ID:NZM9O6ur
>>198
> ループ中でアロケーションしてしまうような記述をすると
アホなコードで議論する必要あるの?
2022/10/23(日) 20:51:00.62ID:h/oZflgJ
一体何と何を比較しているのだ
2022/10/23(日) 22:09:39.72ID:HOBBKeJ+
なんかすごい早口で支離滅裂なこと言ってるけど
頭を整理した方が良いよ
2022/10/24(月) 16:50:56.92ID:SgELnO58
スコープを抜けるときにGCがいらない、つまり、早い

これが間違っている理由を教えてください
2022/10/24(月) 18:09:05.87ID:VKX4Fsrh
ヒープメモリの管理はそれなりに重い処理だというのが論旨のように見える。

GC を使った場合のように不要なオブジェクトの判別をしていくコストは Rust では生じないが
それを除けば空いてる箇所と使用中の箇所を上手いこと管理する実行時コストは
GC (に付随するメモリ割り当て) でやってるのとたぶんそんなに差はないんじゃね。
204デフォルトの名無しさん
垢版 |
2022/10/24(月) 18:49:41.29ID:8+UVFZyO
>>202
>スコープを抜けるときにGCがいらない、つまり、早い

確保したメモリはいつ解放するんだよバカ。
2022/10/24(月) 19:05:34.14ID:Off49nvS
文法で制約したら、書き手もコンパイラも
変数の寿命を厳密に特定することができて便利だろって事で、
どこにどう確保すると速いとか、そういう話とは別では
2022/10/24(月) 19:14:17.25ID:FdEAHzhz
GCがないので速い←わかる
スコープを抜けたらpopするだけなので速い←わかる
スコープを抜けるときにGCがいらない←スコープとGCは何の関係もないよね
2022/10/24(月) 20:07:47.96ID:rCA25jH/
まあGCは常に動く可能性があるからな
逆に全く動かない可能性もある
そこはGCのアルゴリズムによりけり
2022/10/24(月) 21:01:10.53ID:SgELnO58
スタックを使っているから
pop すればそのままメモリが解放されるという意味では?
209デフォルトの名無しさん
垢版 |
2022/10/24(月) 21:39:23.30ID:UxIqfb1a
何と何を比べて何が速いと思ってるのか整理しなよ
話はそれからだ
210デフォルトの名無しさん
垢版 |
2022/10/24(月) 22:49:30.31ID:c7GaYtEs
>>208
動的データ全部スタックに積むのか。すげーな。
2022/10/24(月) 22:54:45.01ID:9jOSWWIs
そんなことよりコンパイルの遅さマジでテコ入れろYO、非力なCeleronでactix-webのコンパイルしたら10分とかふざけてんのか?
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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