次世代言語23 Go Nim Rust Swift Kotlin TypeScript

■ このスレッドは過去ログ倉庫に格納されています
2021/11/28(日) 16:59:19.16ID:gZqbEyz/
スレタイ以外の言語もok

前スレ
次世代言語22 Go Nim Rust Swift Kotlin TypeScript
https://mevius.5ch.net/test/read.cgi/tech/1629590343/
482デフォルトの名無しさん
垢版 |
2022/03/02(水) 15:59:49.43ID:AHCbeeLg
>>481
あー。まあそれはそうね外側でもunsafeなのは頂けないたしかに
2022/03/02(水) 16:02:47.42ID:re9dUtRi
あれぇ・・・コンパイル通ってないと実行できないんだけどなぁwwww
エラーも何も出てこないんだけどなぁwwww
安全とは???
Rustが安全!?
何をご冗談をw
2022/03/02(水) 17:00:29.10ID:YHOWtvAG
教官「GC無しで手動メモリ管理してきた言語だ、面構えが違う」


C/C++/Rust「( ゚ω゚ )」
2022/03/02(水) 17:26:12.32ID:2MKUvw25
おじさん来た?
スレの質が一気に下がるな
2022/03/02(水) 17:53:39.61ID:jfLsV1Py
>>482
そう
外側ではunsafeを使わない
その上で今回のケースはその独自仕様の双方向グラフの「安全な」型を作れば、Rustではプログラム全体の安全性が保証されます
そして「安全な」型を作るには
・型が外へ提供する「安全な」インターフェイス群を用いる限り、それらをどのように用いても、型の内部に矛盾や危険な状態を生じさせないこと
・たとえ型の内部でunsafeな操作が存在していても、型の外へは影響せずに内部に封じ込められていること
このような形で新たな型を実装することで全体を安全に解決できるところが他の言語にはないRustの特徴でしょう
487デフォルトの名無しさん
垢版 |
2022/03/02(水) 18:05:00.35ID:/7glPJ4X
まあGCライブラリさえあれば双方向グラフも簡単に作れるんですけどね
Javaくらいの出来のGCライブラリがついたら最強
2022/03/02(水) 18:30:26.52ID:nWwg4aea
Rustには静的型付けがあるすげー ← スクリプトから来た人
Rustは強力な型推論がある ← スクリプトかC++から来た人

こういう主張をする人は世間知らず
つまり雑魚
2022/03/02(水) 18:40:10.58ID:uPKvDIET
関数型言語以外の型推論は大体が変数の型や戻り値型の推論で、HM型推論採用してる言語ってあまりない気がする
もしそうならば非関数型言語にしてはRustは型推論が強力と言っても良いのでは
2022/03/02(水) 18:42:57.57ID:re9dUtRi
お猿さんは『「安全な」型を作れば、Rustではプログラム全体の安全性が保証されます』などと宣っているが、それは言語で保証しているのではなく、プログラマが手で保証しているに過ぎないw
つまりunsafeなブロックを少しでも含むものはC/C++と変わらないわけで、それを使っている部分も、どこでどう使うものなのか分からない限りC/C++と変わらないということw
さらに悪質なのは、Rustの外のライブラリなどunsafeな何かを呼び出しているわけでもないのに、自前で破壊的なコードを内包できる仕組みw
こうなると、もう外面だけでは分からないわけで、Rustの安全神話は完全に崩壊するw

またこのような状況に拍車をかけているのが自前で破壊的なコードを内包する動機になりやすい所有権の概念w
安全性の根幹をなす部分であるにも関わらず、双方向参照への例外なく簡単に適用可能な安全かつ高速な対応方法が存在していないw
これはプログラマに対してunsafeへの誘惑を助長する形で、逆に安全神話の崩壊を招いているw

まあRustは数ある実装言語の1つとして今後も使っていくとは思うけど、何でもRustに肩入れするお猿さんとはちゃんと線を引いていきたいw
2022/03/02(水) 18:47:26.04ID:uPKvDIET
https://www.thecodedmessage.com/posts/unsafe/
> “If you have to use unsafe to write good Rust, then Rust isn’t a safe language after all! It’s a cute effort, but it’s failing at its purpose! Might as well use C++ like a Real Programmer!”
このブログでstrawmanとして挙げられてる主張そのまんまじゃん
まずは議論のベースラインとしてこの記事読もうぜ
2022/03/02(水) 18:57:48.03ID:jfLsV1Py
>>490
全然違いますよ
CやC++ではunsafeなコードがプログラム全体に散らばってしまうため複雑になればなるほど人間にはどうしようもなくなります
一方でRustではunsafeなコードを各ライブラリや各型の中に封じ込めて外へはその影響を及ぼさないことを保証するだけでいいのです
あとはプログラム全体がどんなに大きく複雑になろうともコンパイラが安全性を保証してくれます
2022/03/02(水) 19:01:56.37ID:nWwg4aea
Rustの推論はプログラム追記で破綻する
後方で馬鹿が型を間違えて追記した場合予想した結果と異なる結果になる
しかもエラーが出ない

仕様が悪い
2022/03/02(水) 19:05:48.62ID:S8+3WyDZ
>>493
Rustは孤児ルールがあるからそんなことは無理だぜ
2022/03/02(水) 19:16:11.77ID:re9dUtRi
>>492
それが実際に違ってなくて同じという主張だろw 日本語読めないのかよw
2022/03/02(水) 19:31:49.02ID:2WElNNHW
会社でいたら距離置きたいな…
2022/03/02(水) 19:39:09.37ID:re9dUtRi
>>491
クソ長い英文読まされた上に被ってる部分が全くなかった悲しみ
2022/03/02(水) 20:09:18.80ID:0VCZHlOm
>>487
javaの出来は良くないぞ
ヒープのサイズかなり引き上げないとすぐメモリ不足になります
2022/03/02(水) 20:11:07.76ID:6P1w2PJ+
底辺プログラマにunsafeを使わせないってことで安心安全になる仕組みなんだね
2022/03/02(水) 20:20:58.51ID:re9dUtRi
より正確には底辺プログラマや広範囲な用件にRustを勧めないことで、双方向参照要件などの対応に破壊的なコードを混入させない/混入しても経験豊富なC/C++プログラマが書くコードに匹敵する品質にさせることで、安心安全になる仕組みw
2022/03/02(水) 20:25:05.11ID:re9dUtRi
>>498
その程度で出来ってなんだよwwww
2022/03/02(水) 21:26:39.54ID:uPKvDIET
>>497
読んでくれてありがとうございます。
2022/03/02(水) 22:40:07.92ID:nWwg4aea
Rustはお馬鹿さんには使えない
それが一番の参入障壁
2022/03/02(水) 22:42:38.46ID:8rl40gQE
>>458
確かにimmutableな配列とインデックスは整合性を保って更新される保証が無いから別の仕組みでラップする必要がある
それってunsafeをラップするのと変わらないかもな
2022/03/02(水) 23:57:29.40ID:re9dUtRi
out-of-boundsとsegmentation faultは違うw
前者はsafeかつ検出可能な実装ミスで、後者は検出可能か不明な未定義動作w
2022/03/03(木) 00:22:39.48ID:CxPtyFsv
rustがむずかしいお陰で仕事あるからその点はありがたいね
2022/03/03(木) 00:47:10.38ID:XF08VSWD
え、そう?
まだRustの案件少なすぎひん?
2022/03/03(木) 02:41:24.89ID:sMoqT2I4
ないこともないが限りなく地雷くさい
2022/03/03(木) 08:01:02.29ID:PSnBqABg
>>503
プログラミングできます→馬鹿の可能性あり
Rustできます→馬鹿でない
ステータスになるな
2022/03/03(木) 09:55:48.59ID:hTxF5AaQ
プログラミングできます→馬鹿の可能性あり
Rustできます→ステータスになると勘違いした馬鹿確定
2022/03/03(木) 10:16:01.15ID:sMoqT2I4
実際問題、言語知識の有無なんかよりもそういう無駄なプライドのがよっぽど開発の邪魔をするからな。
2022/03/03(木) 11:35:08.39ID:hTTcwRYV
アマチュアがステータス目的で手を出す言語:C++, Haskell, Scheme
ドカタが生きるために手に取る言語:Java, JS, php
情報系出身が身につけていがちな言語:C, C++, Pascal, Prolog, Emacs Lisp
電気屋さんが必要にかられて手を出す言語:C
測定機器に囲まれてる人が手を出しがちな言語:matlab, LabVIEW
2022/03/03(木) 13:08:11.35ID:mfROfu1m
ゲーム開発で使う言語 C++ C#
その他の人向けの言語 Python
2022/03/03(木) 18:29:13.09ID:qZcuxxc0
PrologとLispくらいは簡素なわりに他言語と差があり
学習しておくと各言語を客観視しやすくなって役立つね
2022/03/03(木) 18:57:00.77ID:mfROfu1m
Prologは果たしてプログラミング言語なのかと言う疑問は置いといて
2022/03/03(木) 19:06:06.37ID:hTxF5AaQ
いろいろ違ってるw
2022/03/03(木) 19:43:03.78ID:CxPtyFsv
>>512
電気屋ってクソワロタ
2022/03/03(木) 19:48:09.63ID:mfROfu1m
業界用語だろ

電気屋さん
電子屋さん
はかり屋さん

現場に色々いる
2022/03/03(木) 19:54:47.77ID:7NN6zDR3
電気屋さんも馬鹿にできないんだぞ
日頃ハンダゴテ握ってるような人も
PICやFPGA触ってたりするんだもん
2022/03/04(金) 11:39:05.33ID:euBBHe5j
馬鹿にしてるのは馬鹿だけだから気にすることはない。
2022/03/04(金) 12:49:38.60ID:/ow399Ux
>>515
さすがにチューリング完全をプログラミング言語じゃないと疑うのは不勉強。
brain f*ckですらプログラミング言語言われているのに。
2022/03/04(金) 13:23:54.20ID:4zB49VIz
よくチューリング完全を引き合いに出す人いるけど、その定義だと感覚的に合わないものまでプログラミング言語の枠に収まるし、prologはそんなこと考えるまでもなくプログラミング言語だろ
しかも(俺は>>515ではないが)515が言いたいのは自然言語に近いと言いたいだけだと思う
実際中身は手続き型の言語と大差ないんだけどw
2022/03/04(金) 14:11:55.85ID:L8b5lnOt
>>522
自然言語は形式言語じゃないから、もしそうならもっと勉強不足だな。
2022/03/04(金) 14:21:38.82ID:4zB49VIz
お前の頭が固いだけ
2022/03/04(金) 14:49:04.72ID:e8gLPWot
自然言語は全く関係ないな
手続き型言語しかやったことのない似非プログラマーには宣言型言語がそう見えるのか
2022/03/04(金) 15:28:18.85ID:4zB49VIz
頭固いねw 例えば、

親(ひろし,ももこ).
親(友蔵,ひろし).
親(友蔵,すみれ).
親(すみれ,ももこ).
男(ひろし).
男(友蔵).
女(すみれ).
女(ももこ).
祖父(X,Y):-男(X),親(X,Z),親(Z,Y).
?-祖父(X,Y).
X = 友蔵, Y = ももこ

みたいなことができるってこと
二個出るけどw
2022/03/04(金) 16:28:33.22ID:ZrKtVmP5
プロログはパターンマッチ型データベースに見える
あと同じのが二つ出るのは近親相姦してるからだ
2022/03/04(金) 20:48:14.68ID:ZrKtVmP5
prologのノリがどの言語にも持ち込まれてないのも問題だ
2022/03/04(金) 21:08:30.47ID:QzxUwnVT
サーバのバックエンドでwebsocketやるのに一番いいのはGoだよね?
2022/03/04(金) 21:22:57.44ID:4zB49VIz
そんなのなんでもいいのでは?
2022/03/04(金) 21:24:03.32ID:yR2IphvK
>>528
あ、Prologが話題に出たのでFlixを勧めておきます。 https://flix.dev/
2022/03/04(金) 21:28:27.24ID:e8gLPWot
>>529
JavaScriptからRustまで何でもサポートしてるから好きな言語を使えばいい
速さや省メモリを求めるならRust
2022/03/04(金) 21:35:37.03ID:4zB49VIz
最速を求めるならアセンブラで書けw
2022/03/04(金) 21:37:10.95ID:4zB49VIz
"Flix is inspired by OCaml and Haskell with ideas from Rust and Scala."ってどこにもprologさんいないんだがw
2022/03/04(金) 21:40:05.97ID:2lVDRIvt
>>533
それはコンパイラを舐めすぎ
2022/03/04(金) 21:40:43.17ID:yR2IphvK
>>534
"First-class Datalog Constraints"!
2022/03/04(金) 21:45:34.71ID:4zB49VIz
>>535
お前本当にアセンブラで書いたことないだろw
手でプロセッサやキャッシュを最適にするように書くと、最速ロジックの-O3からさらに数倍速くなるよw

>>536
論理型なら今はPrologでいいと思う
2022/03/04(金) 21:53:49.99ID:RxmAHNVk
今時プロセッサ決め打ちとかあるもんなの?
2022/03/04(金) 21:57:30.37ID:4zB49VIz
アセンブラにするならその辺ある程度は諦めてたな
要件次第だけどw
2022/03/04(金) 22:31:46.55ID:CBAI4YxM
>>528
if文をどの節で処理するかで表現するとか
ループを再帰で書くとか癖が強いからなあ
再帰を理解してくれない人も多いし
2022/03/04(金) 22:53:14.64ID:4zB49VIz
日本はPrologまだ使われてる国とかwikipediaか何かに書いてあったよw
世界でどういう状況かは推して知るべしw
2022/03/04(金) 23:28:26.59ID:ByaH8Iv1
C11こそ真の次世代言語だ

トーバルズ氏、Linuxカーネルを「C89」から「C11」コードに移行する準備
https://japan.zdnet.com/article/35184296/
2022/03/04(金) 23:37:07.33ID:2tyOtSaX
>>542
理由が興味深いね
ブロック内スコープ変数宣言をの有用性に気付いたみたい

> Linus Torvalds氏はLinuxカーネルメーリングリスト(LKML)に
> 「この種の非投機的なバグが発生する理由は、C99スタイルの
> 『ループ内での変数宣言』という選択肢をわれわれが今まで持ち合わせてこなかったためにほかならない。
> つまり、list_for_each_entry()といったものすべては基本的に常に、最後のHEADエントリーをループ外にリークさせる。
> というのも、ループ本体内でイテレーター変数を宣言できないためだ」と記している。
2022/03/05(土) 00:50:53.23ID:TqcF1vbz
>>543
なにがそんなに有効なのかわからんわ
どこでも変数宣言できたら、どこで宣言されてるかわかりづらいだろ
変数宣言は一番最初って決まってたほうがよくね?
2022/03/05(土) 00:56:06.36ID:IxOGShAZ
>>544
イテレーター変数(ループ内だけで使う変数)をわざわざ関数の一番上で宣言するのは
すごく古臭いスタイルって気がする
2022/03/05(土) 01:08:06.36ID:lbLi/sOl
CPUの投機実行関係のバグに関するやつだから結構めんどい話だな
2022/03/05(土) 01:31:43.43ID:GsTUxSAJ
>>542
いつまでC使うの?
2022/03/05(土) 05:34:52.76ID:EWrQPP5R
Cに回帰しようよ
2022/03/05(土) 08:41:45.95ID:UxduI4YM
>>547
おすすめの言語は何?
2022/03/05(土) 09:49:50.73ID:O/czQsw9
大変興味深いよな
世の中の色々大事なソフトウェアってやっぱCで書かれてんのよね
Linuxの恩恵はC89の恩恵
他のどんな言語でこれがなし得るというのよ
そう考えると世の中ゴミ言語ばっかだな
2022/03/05(土) 10:54:16.91ID:u03lzKn4
その理論ならCOBOLもいい言語だな
552デフォルトの名無しさん
垢版 |
2022/03/05(土) 10:59:24.96ID:5tAMjVxe
>>550
まるで大事なソフトはLinuxカーネルしかないみたいな言いぶりだな。
こうやって捏造されてくのか。
2022/03/05(土) 12:48:23.26ID:b38ED9f7
C言語はベストパフォーマンスを出せるプログラミング言語
ただしLinuxコードでも何度も起きて来たように
C言語は慎重に厳格なコードチェックを常に継続する必要があり
ちょっとスキができると様々な穴が生じてしまう

そこで誕生したのがC言語と同じベストパフォーマンスを出せるRust
Rustは強力な言語機能によりプログラミング効率が上がるだけだなく
メモリ安全性やデータ競合などの問題をコンパイル時にあぶり出し実行時の安全を保証する
つまりC言語の利点を持ったままさらに便利に安全なプログラミングをすることができるのがRustである
2022/03/05(土) 12:58:16.16ID:EWrQPP5R
ほんとかよ
2022/03/05(土) 13:40:33.23ID:QgP52ag+
ベストパフォーマンスwww
さすがw
2022/03/05(土) 13:42:18.69ID:6VIYcmrk
rustはlibc使ってる
お釈迦様cの手のひらからは逃れられない
2022/03/05(土) 13:43:51.14ID:C4PmhV7a
C言語はGCがないし、整数をポインタに変換できるし
正しくない言語は大事ではないから一個でいい

正しい言語は大事だから色々な方言を作ったり定期的に捨てて作り直したりする
2022/03/05(土) 14:13:05.07ID:GsTUxSAJ
ループ本体に変数を宣言できないから
C11に移行するって動機があまりにも前時代的すぎんか?
2022/03/05(土) 14:30:57.69ID:hdaSjS7b
10年も吟味して気付いたありがたい御言葉だぞ
2022/03/05(土) 15:37:44.81ID:zsDIUHb7
記事だけだとよく理解できんな。ブロック内の変数宣言はC89でも可能じゃないか?
2022/03/05(土) 15:48:32.78ID:uqzOnvYQ
for (int n = 0; ...) みたいな for のスコープの変数宣言のことっぽい?
2022/03/05(土) 15:50:43.81ID:gGGEnXYc
rubyなんかK&Rだぞ?
int foo(bar)
char* bar;
{
return 0;
}
2022/03/05(土) 16:00:58.43ID:AqnMHu7I
その時代のCコンパイラは確かに後から宣言はできなかったよ
2022/03/05(土) 16:27:21.01ID:AqnMHu7I
こういうのだな
$ gcc -x c -std=c90 -Wpedantic - <<EOF
int main() {
int a = 0;
a += 1;
int c;
c = a;
return 0;
}
EOF
<stdin>: In function ‘main’:
<stdin>:4:9: warning: ISO C90 forbids mixed declarations and code [-Wdeclaration-after-statement]
$
565デフォルトの名無しさん
垢版 |
2022/03/05(土) 16:54:20.54ID:CRIoLrg1
>>561
それですな。
566デフォルトの名無しさん
垢版 |
2022/03/05(土) 16:55:50.22ID:CRIoLrg1
>>564
それはどうみてもイテレーター関係無いだろ。
2022/03/05(土) 16:58:47.76ID:AqnMHu7I
ちゃんと記事読んだら違ってたなC99ならこれだ
https://godbolt.org/z/T1Pdnj5Yb
$ gcc -x c -std=c90 -Wpedantic - <<EOF
int main() {
for (int i = 0; i < 10; ++i);
return 0;
}
EOF
<stdin>: In function ‘main’:
<stdin>:2:5: error: ‘for’ loop initial declarations are only allowed in C99 or C11 mode
<stdin>:2:5: note: use option ‘-std=c99’, ‘-std=gnu99’, ‘-std=c11’ or ‘-std=gnu11’ to compile your code
$
2022/03/05(土) 17:41:51.00ID:6VIYcmrk
池の水全部抜きますじゃなくて
linuxを全てrustで書きますが始まったら起こしてくれ
2022/03/05(土) 17:44:45.04ID:AqnMHu7I
それだと一生眠ったままだなw
2022/03/05(土) 17:49:05.42ID:6VIYcmrk
多分そうなるな
大量のmod地獄が待ってるからなあ
rustの仕組みを変えるか自動的に全部解決するツールを作るしかない
2022/03/05(土) 17:50:51.66ID:AqnMHu7I
なあに我々にはunsafeがある
2022/03/05(土) 20:31:07.36ID:VcENWEwx
>>568
Rustが次々と採用されていってる案件はいずれも新規と大改修
今動いていて問題もないものを書き直すことはない
新規か何らかの弱点が見えていてシステム改修すべき機会などでRust採用
2022/03/05(土) 20:38:19.88ID:AqnMHu7I
> Rustが次々と採用されていってる案件
存在しない案件が実績として次々と計上。。。詐欺かな?w
2022/03/05(土) 22:08:15.20ID:vk+PU+My
>>562
それだいぶ前だよ
2022/03/05(土) 22:11:42.53ID:vk+PU+My
linuxのlistってgenericsっぽい作りになってて
任意の構造体に埋め込めるのよね
そのためにマクロでforeachとかあってそのせいっぽいな
仕様のせいじゃなくてそのマクロのせいだろw
2022/03/05(土) 22:58:00.53ID:AqnMHu7I
Cでのリストの良くある作り方みたいなモノ+これを使えばより安全的なマクロが多数用意されてるだけだろ・・・
その辺の実装を書く前提としてC仕様にC89を仮定してたってこと
↓にlist_for_each_entry他、リストの使い方が日本語でいろいろ載ってる
https://debimate.jp/2019/04/07/linux-kernel-list%E6%A7%8B%E9%80%A0%E3%82%92%E6%93%8D%E4%BD%9C%E3%81%99%E3%82%8B%E3%81%9F%E3%82%81%E3%81%AEapilist%E3%81%AE%E4%BD%BF%E3%81%84%E6%96%B9/
実際のコードはC89〜C11までいろいろあるんじゃね
2022/03/05(土) 23:01:37.79ID:AqnMHu7I
メインラインの多くはC89でC99もある程度と予想(推測)
2022/03/05(土) 23:07:24.44ID:b38ED9f7
C/C++やJavaなどからRustへ移行するパターンも多いけど
こういう形でプログラムコードをJavaScriptからRustへ移行する例も増えてきた

https://publickey1.jp/blog/22/amazon_prime_videowebassemblywasm_vm.html
Amazonはプロトタイプとして低レイヤのJavaScriptのコンポーネントのいくつかをRustのコードで書いてコンパイルし、WebAssemblyのバイナリにしたところ、JavaScriptのコードと比較して10倍から25倍も高速になったことを発見します。

これによりAmazon Prime VideoのアプリケーションにWebAssemblyを取り入れることを決定。

JavaScript VMの部分にWebAssembly VM(Wasm VM)をランタイムとして追加し、ユーザーのデバイス上へデプロイした上で、これまでJavaScriptで実現していたレンダラ、アニメーション、シーンとリソース管理の部分をRustコードから生成したWebAssemblyで置き換えました。
2022/03/05(土) 23:20:19.93ID:AqnMHu7I
それはたまたま実験結果として速くて置き換えた事例がたまたまあっただけだろ
他のwasmを使える言語との比較でもなければ、コードもなくどこまで安全かも分からんだろう上に
実際の置き換えでの効果については記載が何もないw

Rustやばやば言語ですなw
2022/03/05(土) 23:26:50.19ID:b38ED9f7
効果も全て>>578の記事に載っている
そしてアマゾンの今回の対象は、テレビやFire TVにスマートフォンなどの再生デバイス上でWebAssemblyを動かしその生成コードはRustで記述しているという話
2022/03/05(土) 23:36:13.20ID:AqnMHu7I
どこに対する何なのか改善ポイントが何なのかもさっぱりで、効果が何に対応してるのか分からんものを勝手に効果と思い込んでるだけでは?w
2022/03/05(土) 23:39:28.82ID:Koe9vBH8
>>577
なんでコンパイラオプションで指定してないと
思ったの?
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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