プログラミング言語 Rust 4

■ このスレッドは過去ログ倉庫に格納されています
1デフォルトの名無しさん
垢版 |
2017/10/14(土) 17:38:14.04ID:uWD69LeP
Mozilla発のプログラミング言語「Rust」のスレです

公式
https://www.rust-lang.org/
https://blog.rust-lang.org/
https://github.com/rust-lang/rust

前スレ
プログラミング言語 Rust 3
https://mevius.5ch.net/test/read.cgi/tech/1495343069/
2017/11/26(日) 02:37:39.20ID:8lbYkPLC
昔の一部の組み込み系では製品の安定を求めるために
コンパイラのバージョンアップすら信用しない(=古いバージョンを使用し続ける)ことがあったなー
2017/11/26(日) 02:50:50.14ID:FcDi9KjV
『"(Rustが売りにしてるような部分に関して)良いコード"を書きたいと思っているh人』にとっては素晴らしい言語となる可能性の高い言語がRust
『"良いコード"の定義が違う人』にとっては
『"良いコード"を書きたいと思っているわけではない人』にとっては
2017/11/26(日) 02:52:44.07
Rustがコケると得するのは誰か
2017/11/26(日) 03:23:13.42ID:FoFKguj9
>>269
目的より手段を優先する日本じゃ無理だろw
どうしてもやりたいなら自分で立ち上がるしかないんじゃないか
2017/11/26(日) 03:57:56.67ID:2SXqucAT
>>273
rustが使いたいからその仕事を立ち上げるって明らかに手段と目的が入れ替わってますよね
2017/11/26(日) 09:03:05.51ID:d0SJzNDY
>>272
世界中のプログラマ
モジラのクソ提灯で言語未満の自称言語がひとつ減る訳だから
2017/11/26(日) 09:09:55.82ID:4gwTKbSY
この糖質「提灯」って言葉に執着してるね。
277デフォルトの名無しさん
垢版 |
2017/11/26(日) 11:03:05.21ID:2p4Fc6MR
>>276
執着というより単に語彙力がないだけかと。
コイツいつも大体同じようなことしか言ってないよ。
278デフォルトの名無しさん
垢版 |
2017/11/26(日) 11:11:18.98ID:d1Efc0fJ
>>263
ガウディ本とかで計算モデルを理解してれば、慣れてるという理由で合わない用途に無理矢理押し込もうとしないんだろうけどね。
2017/11/26(日) 11:35:06.02ID:chAORxhD
当人は必死だけどすっかり珍獣扱い
2017/11/26(日) 16:10:47.30ID:F1AvYoB1
少なくともswiftに採用しようとしてる機能を先行実装しているだけでも価値ある
2017/11/26(日) 22:44:13.85ID:mC/sVuBh
Rustが成功したから真似されたんじゃw
Apple信者さすがの言い草
2017/11/26(日) 22:54:59.36ID:hn9uvYDF
>>281
成功?成功ってなんだっけ?
2017/11/26(日) 23:15:44.20ID:4gwTKbSY
Swift の仕様変更と比べると、Rust のアップデートはかなり大人しいよな。
2017/11/26(日) 23:36:42.57ID:BDpjXZu3
>>282
Rustのメモリ管理の仕組みが破綻してないことを証明しただろ!
しかも実務にも耐えてる
これが成功でないわけがない
2017/11/27(月) 01:38:36.80ID:A6Q33Aj/
>>284
循環グラフとか動的計画法とか書けない言語のどこが破綻がないのかいってみろ工作員
2017/11/27(月) 01:55:07.26
RustでDPできないの?
2017/11/27(月) 02:01:44.73ID:Kmvld91s
出来ない人がいるだけ
2017/11/27(月) 07:36:56.24ID:30J1+TRs
簡単にwasmコンパイルできる環境が整ってきたな
https://twitter.com/badboy_/status/934742946754244613
今、試したけど、Windowsでも動いた。
cargo-wa は動かんかったけど。
2017/11/27(月) 16:32:30.04ID:UGzoAGct
このエラーメッセージ、表示されるときと(当該箇所の修正をしていないのに)も関わらず表示されないときがある
Why?

error[E0605]: non-primitive cast: `{integer}` as `f64`

= note: an `as` expression can only be used to convert between primitive typ
es. Consider using the `From` trait


このエラーメッセージが表示されるのは
このエラーメッセージの示す箇所と全然無縁な箇所でコンパイルエラーが出たときに同時に表示される
そしてその他所であるコンパイルエラーを解消するとこのエラーメッセージも同時に消える
2017/11/27(月) 22:23:59.13ID:0avMxfTz
言語構文とツーリングを改善したRust 1.21
https://www.infoq.com/jp/news/2017/11/rust-1-21-released


「Rust 1.22」リリース
2017年11月27日17:00
https://mag.osdn.jp/17/11/27/170000
2017/11/27(月) 22:38:51.64ID:zgUQvI9i
>>270
実際、g++ なんかはバージョン違うと相当挙動違うけどね。
2017/11/28(火) 01:05:16.27ID:oL6iYiK7
>>289 エラー時には情報足りなくてusize等に推論してるから、かなあ
構文チェック -> 型推論&チェック -> ボローチェッカーって順番でエラー出してる感じだけど、
関係無い場所でのエラーのせいでas f64してるローカル変数の型推論が不十分な可能性がある
型推論は重い処理だから何らかの最適化のせいでエラー時の挙動が分からないのではないか
293デフォルトの名無しさん
垢版 |
2017/11/28(火) 01:05:23.35ID:YEKXo1x2
Rustでイミュータブルに拘る人は何なの?ミュータブル使えよ
2017/11/28(火) 01:26:37.66ID:9rdMMleK
ミュータブルなんて怖いもの使えないよ〜><
295デフォルトの名無しさん
垢版 |
2017/11/28(火) 01:38:14.99ID:YEKXo1x2
ミュータブルにする必要のない箇所をイミュータブルにする
基本はミュータブルで使え、ミュータブルしてなかったらコンパイラが教えてくれる、そのときイミュータブルに変更すればいい
2017/11/28(火) 02:15:45.91ID:OnNJR7WO
ID:YEKXo1x2
完全に頭おかしいな
2017/11/28(火) 05:26:38.97ID:9EzjspMa
Rustでイミュータブルに拘るのは、TypeScriptで型付けることに拘るようなもん
2017/11/28(火) 06:36:09.88ID:oe1VgQrD
いミューダブルって、Cellの話をしているの?
2017/11/28(火) 06:49:49.21ID:WfYnw+8u
最近勉強し始めたんだけど、デフォでイミュータブルなのに思いのほかmutキーワード使う局面が多くて面食らってる。
2017/11/28(火) 06:56:41.60ID:9EzjspMa
イミュータブルに拘ると、Scalaとかでもそうだが、コピーだらけになる
コピーを恐れてるとイミュータブルを徹底できないよ
2017/11/28(火) 06:59:54.84ID:bNHGW3XK
コピーってmut並みに最適化してくれんの?
2017/11/28(火) 07:35:10.58ID:oe1VgQrD
あ、そういうこと。むりやりイミュータブルにする人たちがいるのか
2017/11/28(火) 09:28:24.80ID:L9vMnZgT
静的型付け初めてなんだけどいきなりRustは敷居高いだろうか
2017/11/28(火) 10:02:32.22ID:hv4LFVGU
>>300
> イミュータブルに拘ると、コピーだらけになる
> コピーを恐れてるとイミュータブルを徹底できない

例出してみ
2017/11/28(火) 12:38:41.40ID:Q+QzpY2X
イミュータブルとかメモリを富豪的に使うだけで性能はなんら上がらない、いかにもお偉いさんが机の上だけで考えたクソ手法だろ
なんでFortranやCが現役なのか考えたこともないやつがイミュータブルをもてはやす
2017/11/28(火) 12:59:41.96ID:ZfJDlsQ3
メモリが富豪的って、それお前の設計が悪いだけやで
2017/11/28(火) 13:02:27.70ID:318e3gj2
それは言い過ぎだろ

なんでもイミュータブルにするべきとは思ってないが、
並列性が必要なプログラムではイミュータブルは重要視しているよ

並列性が性能に直結しない(難しい)のは残念な話だけど……
2017/11/28(火) 13:47:27.77ID:Q+QzpY2X
>>306
値変えないならコピーするしかないだろ。それが富豪的でなくてなんなんだ?

>>307
並列計算で必要なのはイミュータビリティじゃなくて、変数スコープ分離と外部依存性の無いアルゴリズムだ

大方MPIすら使ったことないんだろうが、
共有リソースにアクセスしなきゃいけない並列プログラム組んでる時点で
設計が破綻してるとみなせると思うがそこんとこどう考える?
2017/11/28(火) 14:14:02.57ID:hv4LFVGU
このバカ、コンパイラが良きに計らうってことを知らんのか?
2017/11/28(火) 14:26:19.19ID:GpBjXyhn
>>292
thx
なるほど、コンパイル途中でエラーすると一部の推論に失敗してしまうのか
2017/11/28(火) 14:42:06.12ID:LCKhcLzq
const に異常にこだわるくせに異常に長い関数書く馬鹿は見たことあるな。
その前に関数切り出せと。
たぶん Rust が一般に広まるとボローイングルールをまともに理解できなくて
コンパイルできないから関数に切り出さないバカが増えると思われる。
2017/11/28(火) 15:17:40.57
イミュータブルにすることでコンパイラによる最適化の余地が増えるんでないの?

ミュータブル派とイミュータブル派の宗教戦争勃発なの?
2017/11/28(火) 15:25:32.16ID:Q+QzpY2X
コンパイラが善きに計らうって、
つまりconstついてた(mut非指定の)変数がレジスタ割り当ての結果変更され得る最適化が起こるってことか?
さすかにそんな最適化は聞いたこと無いがソースあるのか?
即値展開ならわからんでもないが、それと並列は関係ないし
2017/11/28(火) 16:00:32.21ID:lii/QdBe
アマゾンでオライリーのProgramming Rust出てるのな
アーリー版じゃ無い完全版かな?

どうでも良いけど蟹座の俺が心惹かれる表紙
2017/11/28(火) 16:21:14.75ID:318e3gj2
>>308
「使ったことない」って人を判断したがるのは使ったことを自慢したいから?
ある数学上の問題を高速に解くために 2000年ぐらいにMPI を数ヶ月触ったことある程度で
以降は関わってないけど、それはなんか関係あるのか?

設計が破綻しているかどうかは問題によるだろ
どんなに考えても共有リソースにアクセスしなきゃいけない並列プログラムなんて山ほどある

共有リソースへのアクセス削減なんてみんな取り組んでる
そのための一ツールとしてイミュータビリティは重要な概念だろJK

> 並列計算で必要なのはイミュータビリティじゃなくて、変数スコープ分離と外部依存性の無いアルゴリズムだ
「重要視」と言ってるのに「必要」と解釈するのか……
変数スコープ分離という用語は知らん
2017/11/28(火) 18:02:39.24ID:wSmX/jVF
>>314
kindle版の話か

紙版を注文しちゃってるんだが
2017/11/28(火) 18:17:27.07ID:oL6iYiK7
ガーガー言うほど文句が出るもんでも、全力擁護すべきもんでもないと思うがね>デフォルトでimmutable
Haskellほどやり方が変わるわけでもない、C/C++のconstより明快、letとvarで分けるほど使い心地が違うものにはならない、
https://rust-lang-ja.github.io/the-rust-programming-language-ja/1.6/book/box-syntax-and-patterns.html
↑にあるようなBoxを使って大きい構造体を関数に渡すのはRustじゃ悪手ってとこだけ知ってればいい
2017/11/28(火) 18:18:12.38ID:Q+QzpY2X
>>315
MPIは不変性は並列化に必ずしも必要じゃないって話の例に出しただけだから、
さわった上で不変性が必要って主張するならまあそうなんだろう

データを不変にして触るノードの分だけコピーすりゃそりゃデータ競合は起きないだろうが、
その分ノードへの転送量だってかかるし、メモリも食う
だから富豪的で、額面上の並列度は上がっても性能には寄与しないと言ってる

俺が知らないだけでもっと良い最適化が不変変数にかかるなら完全に俺が無知晒したでめでたしなんだが
2017/11/28(火) 20:36:19.23ID:nHLuJ5vk
業務のDBとかででっかいBeanやテーブルさわってるとImmutableこだわると死ぬ気がする
ライブラリレベルだとImmutableすごいよさそうなんだが
2017/11/28(火) 20:40:51.18ID:7DSslbhb
immutableがいいのはソースの可読性が高まるのと、マルチスレッド化したときにリソースアクセスに問題ないのが保証できることでしょう。バグらなない自信があるなら効率を求めてmutableにするがよろし。
2017/11/28(火) 21:07:28.65ID:LCKhcLzq
mut にするのもそこまで困難な言語設定ってわけでもないし、
デフォルトが immutable でもいいんじゃねとは思う。
まあ大規模に作ったことはないからその際の困難はわからんけど、そこまで問題にならんのでは?
322デフォルトの名無しさん
垢版 |
2017/11/28(火) 21:37:26.40ID:RsLfLMGU
let mutって書くのめんどくせーしvar
323デフォルトの名無しさん
垢版 |
2017/11/28(火) 21:37:34.07ID:RsLfLMGU
追加してほしい
2017/11/28(火) 22:58:48.40ID:91xy27Pm
mutにするのをめんどくさくするというのが
let mut構文を採用した理由なので
varはよっぽど何かない限り入らないと思う
325デフォルトの名無しさん
垢版 |
2017/11/29(水) 00:16:55.36ID:ZRmpNQ2i
Haskellのイミュータブルは永続データ構造?参照の使いまわし?
Rustのイミュータブルは?コピーしないと使いまわせない?
2017/11/29(水) 00:58:38.85ID:RLTBNHC0
wasmに出力するのって、依存ライブラリも全部pure Rustじゃないとダメなの?
2017/11/29(水) 03:28:58.51ID:wq9Dycsx
1.22でOptionにも?使えるようになって、haskellのMaybeモナドっぽく使えて捗るわ
ブロック内だけでも使えたら良いんだけど仕組み的に無理そうか
2017/11/29(水) 12:04:01.36ID:TbD0G3jq
try catchみたいな構文検討されていたような
2017/11/29(水) 19:35:23.16ID:PZaIONIl
Rustを叩いている奴ってミラーレスカメラを叩いている一眼レフカメラ信奉者と同類に見える
大抵の場合は合理的な方が最終的に選択されるけどな
2017/11/29(水) 20:42:06.07ID:FCGUeU3g
mutable変数扱うなバーカ、というメッセージだと思ってる
必要なら再宣言させるようにして人為バグを減らそうという魂胆は分かるぞ(Javaのfinal教徒感
2017/11/29(水) 20:50:40.91ID:wq9Dycsx
BufReaderとかReadするStringとかにもmut必要何だからmut禁止とか無理じゃね?

不要なmutだったらワーニング出るでし、必要だったらコンパイルエラーになるでしょ

必要な形で使えば良いだけなのに一体何を議論してるんだ?
ミュータブルが気に入らないならhaskellおすすめ
2017/11/29(水) 22:01:09.26ID:pXSSowmn
Readした結果はmutableでいいのにlet mutと書かなければならんの面倒
人によってはletで再宣言するのかな
2017/11/30(木) 01:36:34.69ID:zpCxrqzF
例えばさ
mutな変数1つ宣言してそこに足し上げていくのと、
非mutな計算結果同士を足して新しい非mutな計算結果を作るのと

素朴に考えれば前者の方が省リソースだよな

別にその程度コンパイラの最適化やレジスタ割り当てでどうとでもなるだろうとも思うが
2017/11/30(木) 02:16:29.28ID:ypA28Khv
https://qiita.com/koji_mats/items/62e85a87cc580e225796
これ見たんだけど、なんでwinがlet mut winじゃないんだろうって不思議に思った。

let win = gtk::ApplicationWindow::new(&app);
win.set_title("Vanilla Text");

で、コードを調べてみたら、こんな感じにFFIを呼んでるだけだから、
概念的にはオブジェクトを変更してるけどRust的にはmutが要らないという仕組みらしい。
ちょっと違和感無い?

fn set_title(&self, title: &str) {
unsafe {
ffi::gtk_window_set_title(self.to_glib_none().0, title.to_glib_none().0);
}
}
2017/11/30(木) 02:51:13.41ID:AHSKxIeg
ポインタの先がどう変更されようが、ポインタを持ってるだけの側は不変。
2017/11/30(木) 03:27:18.42ID:NyMSxVXi
gtkはgoのほうが簡単
2017/11/30(木) 07:37:17.88ID:YOUdxrbO
Cellもしらんのか
2017/11/30(木) 13:33:26.57ID:2d5TEUTF
Rust的な設計の指針というかコツみたいのって無いですかね…

勉強のつもりで外部のCのライブラリとの間に入るちっちゃなFFIのラッパーを書いてみたんですが、Cの感覚で書く->コンパイラに怒られてあーなるほど修正ってのを繰り返してとりあえずは動くようになったんだけど
何をするにも

let foo = xxx ;
{
let bar = foo.xxx() ;
bar.yyy() ;
}
{
let baz = foo.zzz() ;
baz.www() ;
}
{
let bar = foo.xxx() ;
bar.yyy() ;
}

みたいに書かないといけなくて書いた本人でも「何やねんこのウンコ!」ってなってる(´・ω・`)
(Rustがって意味じゃなくて自分の書いたものがって意味で)
2017/11/30(木) 15:21:22.37ID:AHSKxIeg
どんなエラー出してそんな醜いコード書いてるのかを説明してくれないと。
340デフォルトの名無しさん
垢版 |
2017/11/30(木) 19:20:57.05ID:dqSyxXgg
>>338
RustがRustで書かれてるのだからRustのリポジトリのコードを読んで参考にすれば勉強になるのでは?

https://github.com/rust-lang/rust/search?l=rust
2017/11/30(木) 19:27:22.21ID:uu2PxLG/
>>338
cと触れる部分はしょうがないんじゃないの?
その何回も触ってる部分をcで書いてインターフェイスを最小化した後で
rust から呼び出す方が正解なんじゃないかね。
2017/12/01(金) 00:02:21.38ID:9zBEgLMI
Rustに限らず他言語で書かれたライブラリを利用するときは呼び出し元言語の作法に適合するように改修しないと使いにくいことが多いような
2017/12/01(金) 00:53:10.98ID:+mBQRpP6
>>338
> Rust的な設計の指針というかコツみたいのって無いですかね…

私も知りたいです!
2017/12/01(金) 18:20:32.47ID:MEq6f57k
>>338 見た感じFoo::xxx : &mut Self -> BarとかFoo::zzz: &mut Self -> bazとなっているのでbarやbazが生きてるとfooにアクセスできないのが直近の原因だと思うけど、
xxxやzzzが本当にFooの変更を伴わないといけないのかを考えないといけない
CellやRefCellを使ってinterior mutabilityを導入したらFoo::xxx: &Self -> Barというメソッドにできる可能性がある
まあ実際のソースがどんなもんなのか知らないから適当だけど
2017/12/02(土) 18:50:17.68ID:LUcOy7p3
https://doc.rust-lang.org/book/first-edition/crates-and-modules.html

japaneseってrust作成者らって日本語好きなの?
2017/12/02(土) 19:17:25.64ID:XMmE+FVV
トーキョー、サムライ、ハラキリ、ゲイシャ!
2017/12/02(土) 21:21:37.22ID:nhUA9ni6
>>345
公式Twitterアカウントをフォローしてみれば、リツイートに含まれるアニメ画像の多さで分かるだろ
2017/12/02(土) 21:26:24.08
ジャパニメーション
2017/12/02(土) 23:06:36.11ID:LUcOy7p3
プログラマ=アニメオタクの構図は海外でもデフォか
2017/12/02(土) 23:25:28.54ID:IvGxcnlE
アニメに限らずエンジニアのオタク率は高い
2017/12/03(日) 02:23:51.05ID:o8sHMMD+
そもそもエンジニアの時点でPCオタみたいなもんだろ
2017/12/03(日) 15:14:02.84ID:nF9LHZwo
標準ライブラリAPIリファレンス見てるけど難しいなぁ。
2017/12/04(月) 20:49:12.68ID:Guj0xD4V
map: HashMap<String, usize>をメンバーに持つ構造体Fooを作りHashMap::getをラップするメソッドを定義したいんだけど、
型表記をどう書けばStringとstrの両方を受け取れるようになれるの?
2017/12/04(月) 20:51:25.15ID:Guj0xD4V
自己解決。AsRef<str>を使えば良かった
2017/12/05(火) 00:26:24.15ID:9T1+J47W
panic!で終わらすのでなくErr()を返してエラー時の挙動は呼び出し側に任せる・・・?
2017/12/05(火) 01:46:51.82ID:Z65eXqg0
get で使うなら AsRef じゃなくて Borrow
2017/12/05(火) 08:09:29.16ID:qtUVw02h
>>356 こういうことかhttps://play.rust-lang.org/?gist=2b7d7c7aa544cc2dde43c2aa06533c87&;version=stable
こんなの行けるんだな。doc見てもよう分からんかったありがとう
2017/12/05(火) 09:27:16.18ID:hHacdpPt
Mercurialも、Python/CからRust/Pythonに切り替えるのか

> Python is also hindering us because it is a dynamic programming language.
2017/12/05(火) 18:20:02.95ID:zRXsR4tV
>>358
ソースどこだよデマ乙
歴史あるVCSがRustみたいなゴミつかうわけねえだろ
2017/12/05(火) 18:38:54.65ID:lkNfeWcr
>>358
なんでそれでpython残すんだ?
2017/12/05(火) 19:47:27.34ID:qtUVw02h
https://www.reddit.com/r/programming/comments/7hesom/mercurial_oxidation_plan/
・hg本体がpythonなんで起動時のラグが気になる、特にスクリプトからhg呼び出す場合に重いからネイティブにしたい
・python2.7のGILのおかげで高速化のための並列化が面倒
・メモリ安全と並列化をCや古めのC++でやるのはキツい

何故まずpython3に移行しないのかは分からんかった。Rustで書き直すより先にやった方がいいんじゃないかと
2017/12/05(火) 20:16:52.30ID:Z65eXqg0
> For Mercurial, Rust is all around a better C.
> It is much safer, about the same speed, and has a usable standard library and modules system for easily pulling in 3rd party code.

>>359みたいな基地外君発狂しそう。
2017/12/05(火) 21:03:22.04ID:zRXsR4tV
ソースはRedditwwwwwwwww
ソースは2chよりひでえwwwwwwwwwwww
2017/12/05(火) 21:16:31.60ID:qtUVw02h
一次情報はmercurial oxideなんだけどこれが公式mercurialとどんな関係があるかがRedditのスレで言及されてるんだが
モジカス連呼基地外君は発狂中だとurlしか読めないのね
2017/12/05(火) 21:18:53.28ID:gT8tzSz1
>>360
mercurialにpythonで書かれた拡張機能がいっぱいあるからだろうかね
2017/12/05(火) 21:42:01.40ID:4Jhqan/B
HN見ないんだ?https://www.mercurial-scm.org/wiki/OxidationPlan#
ていうかモジカス君固定ハンドルつけてくれない?名声もつくよ
2017/12/05(火) 22:45:09.30ID:H7tXCLyD
言語が錆でプロダクト名が水銀だから、プロジェクト名が酸化ってのもうまいことつけたな
Python3化を優先しないのは、斜め読みした感じだと「hgコマンドをPythonスクリプトから(必要に応じてPythonインタプリタを埋め込んだ)バイナリにしたい」ってあったから、順番的には確かにそっちは後だな
2017/12/05(火) 22:52:10.21ID:H7tXCLyD
あとは、GILの性能自体はPython3で向上したとはいえ、GILそのものがなくなった訳ではないから、
それで得られる速度向上は並列化と比べてたいしたことないってのもあるんじゃね?

あとPython3はそもそも単純なベンチでは2より遅かった気がする
369デフォルトの名無しさん
垢版 |
2017/12/06(水) 00:11:41.11ID:aEHwTVhz
なるほどね。
個人的にはgitよりmercurialに頑張ってほしい
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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