次世代言語議論スレ[Go Rust Scala Haskell]第5世代 [無断転載禁止]©2ch.net

■ このスレッドは過去ログ倉庫に格納されています
2017/06/13(火) 08:54:07.99ID:O1HnBMDk
いざ、語ろうぞ。

スレタイ超過のため、一部省略。
その他もウェルカム。

前スレ
次世代言語議論スレ[Go Rust Kotlin Scala]第4世代
http://mevius.2ch.net/test/read.cgi/tech/1492631007/
520
垢版 |
2017/07/25(火) 08:31:31.28ID:Yx6+jkpX
>>519
あー、その地雷は理解できるわ。
型がないからうんぬんペチプァーと言ってるようなやつは前者の2つどっちかって印象。

あの道具に徹する姿勢好きなんだけどね。
気をつけて使うとそこそこまともだし。
敢えてfalsyなものを扱う勇気も要るけど。
気をつけたくないやつには向いてない言語。

言語仕様が破綻してるってのもまぁ、php3の時点であれだったのに、その後また使える文字減ったし、諦めるしかない。
2017/07/25(火) 08:57:41.36ID:SyNDf/s0
falsy って何やねん?
522
垢版 |
2017/07/25(火) 10:08:41.40ID:Yx6+jkpX
>>521
評価した結果falseとみなされる値。
2017/07/27(木) 00:19:42.46ID:2FlrvgGr
使い捨てのモックとしてならまだしも
そこそこの規模の開発で使って苦しんでる連中は
ただのバカとしか思えんわ
524
垢版 |
2017/07/27(木) 11:12:41.51ID:A4iX0nN0
>>523
既存コード捨てられない病の人居るからねぇ。
あとはフレームワークしか使えない病の人とか。
2017/07/27(木) 11:56:41.88ID:T03zDTBA
Lispは神の言語
526デフォルトの名無しさん
垢版 |
2017/07/27(木) 15:33:01.66ID:dBtvUIpG
forthは?
2017/07/27(木) 16:20:31.74ID:gEdE1/qh
May the Forth be with you!
2017/07/27(木) 18:56:32.71ID:L9OidomQ
5月専用言語ってことか。
2017/07/27(木) 19:42:40.59ID:rQ7K04i3
mlが黄泉から還って左目を洗ったときにsmlが産まれ、右目を洗ったときにOCamlが産まれ、
鼻を洗ったときに産まれたのがF#であるらしい
2017/07/30(日) 23:52:50.44ID:W7NHR4pI
elmの話題が無いみたいだけど触ってる人いないの?
elmの影響を受けたというreduxをtyprscriptから使ってるけど、
reducerを書くのにimmutable.jsを導入してみたらtypescriptと相性があまり良くなくて悲しい。

どうせならelm触ったほうが幸せになれんのかしら。
2017/07/31(月) 02:15:29.10ID:iyeoTq8u
低レベル記述は出来なくてもいいから、短く書けて速いバイナリを吐く言語ってなんだろ?
2017/07/31(月) 02:49:09.85ID:RkZnFpRc
nimとcrystalは?
2017/07/31(月) 09:34:17.04ID:rPsLgQ6H
あまりにもマイナーな言語だと誰も行列計算を実装してくれてなくて面倒臭い
2017/07/31(月) 11:09:33.58ID:TrWT5gkf
Nim結構良さげな感じするなあ
2017/07/31(月) 14:47:02.65ID:8d7NzLwa
>>531
goってそれが売りじゃないの?
2017/07/31(月) 14:53:08.10ID:TrWT5gkf
>>535
俺にはちょっと冗長かなあ……
内包表記もmapもないのは俺には辛い
2017/07/31(月) 15:05:58.03ID:luO5NyKL
>>536
関数型がいいならrustじゃないの
538デフォルトの名無しさん
垢版 |
2017/07/31(月) 15:12:57.67ID:wxFD97LM
本当内包表記もmapもないのは謎だわ
おまけに三項演算子もif式もmatch文もないし
うんこ
539デフォルトの名無しさん
垢版 |
2017/07/31(月) 15:13:14.76ID:wxFD97LM
match文じゃないmatch式
2017/07/31(月) 15:28:16.20ID:G/Fk6WhF
>>532
nim はバイナリ吐かないけどな。
2017/07/31(月) 15:45:00.94ID:u2+qVqAB
オブジェクト指向言語で作るときよくOMT(オブジェクトモデリングテクニックとかなんとか)をよく使って設計してたんだけど、
関数型言語で作るときは何使えばいいの?
2017/07/31(月) 16:27:21.72ID:uq0CdBZz
今思いついたんだが
数学は公理を使えばいいというより、公理以外の何も使わない方がいいな
特に言語に依存するテクニックを使ってはいけない
言語を変えた途端に使えなくなるので
2017/07/31(月) 16:28:38.94ID:A1TauzTI
三項演算子は構文がまるで違うからね
式中にもif書けるようにするからそれ使えの方向
(逆にif廃止全部三項演算子使えな言語があったらおもしろいけどw)
2017/07/31(月) 19:35:10.71ID:xqAPypbO
>>541
関数型の重要な設計指針として、トップダウンで考えるというのがある
1. 問題全体の結果を求める関数のスタブを作る
2. スタブを一つ選ぶ
3. 2で選んだ関数を実装するために必要なものを考え、それぞれを求める関数のスタブを作る
4. 2へ戻る
これを、すべての関数が十分(容易に実装できるレベル)に細分化されるまで繰り返す
こうやっていくと非常に明快で平易なコードになる
逆に入力から出力を導くという考え方で作ろうとすると、俺スゲェに陥って意味不明なコードになりやすい
2017/07/31(月) 19:54:36.50ID:u2+qVqAB
>>544
構造化手法ですか
業務系はオブジェクト指向のが良さそうだ
2017/07/31(月) 20:05:13.60ID:ZV6hqn66
「おまえはこういうコマンドを与えるとこれをやるクラス」って
トップダウンで構造決めてくオブジェクト指向の基本手法の
単語入れ替えたコピペかと思ったw
そしてそれならコマンドに対するふるまい変えられるオブジェクト指向の方がいいや
2017/07/31(月) 20:42:45.33ID:uq0CdBZz
トップダウンの細分化をどこで止めるかを考えないと意味がない
CPUの種類までトップが決めるのか?
CPUを変えたり仮想関数のふるまいを変えたいならトップダウンを止める必要がある
2017/07/31(月) 21:03:46.00ID:iyeoTq8u
>>537
この需要ならrustがベストかいなー
何をするにも面倒な言語というイメージがあって避けて来たけどやってみるか
ありがと
2017/07/31(月) 21:35:05.34ID:VY/jm5nF
もし関数型で大規模な業務アプリを作るなら、大まかなところは伝統的なIPOベースのDFDで描いて
各プロセスを>>544のようなスタイルで実装していくことになるんじゃないかな
データ指向の設計ってCOBOL時代に既に完成してて、あとは莫大なコピペコードの問題を関数型の高度な宣言的記述によって回避できるなら
設計手法としてはわざわざ意識高そうな複雑な手法を持ち出すまでもなく十分に完成と言えると思う
2017/07/31(月) 23:51:23.68ID:CknoIXsc
俺が若い頃(90年頃)はC言語の事を
関数型言語と呼んでたのに。
2017/08/01(火) 08:07:11.18ID:JcYmkGrg
今じゃlispも関数型に入れてもらえるかどうか
2017/08/01(火) 09:55:49.70ID:QEGWTgnM
そろそろ次次世代が気になる
2017/08/01(火) 12:52:24.85ID:PIQ133u2
関数型が注目されてるのってマルチコア時代の並列処理を効率良く動かすための
手法として注目されてるわけで
更に次の世代というと、量子コンピュータってことになるけど
今の実用化している量子コンピュータは機械学習に最適化されてるんで
つまり機械学習専用言語ってことになるのかな
2017/08/01(火) 13:12:51.64ID:3yEb4FWA
>>553
飽きてきたから次のおもちゃってことだろ
2017/08/01(火) 15:56:17.80ID:HS7kzK9m
機械学習のハードが実現してなくても、ソフトで実現すれば数世代先取りできるだろ
現にソフトで機械学習やってるし
ソフトでやるのに飽きた頃にハードが出てくる
2017/08/01(火) 16:42:50.10ID:BPE2Uku1
機械学習専用ハード(ASIC)もうあるよグーグルTPUとか
2017/08/01(火) 17:03:33.70ID:HS7kzK9m
ハードの実験っていうかオープンソースじゃない実験は再現性が怪しい
2017/08/02(水) 00:22:40.42ID:trs+oWK4
VHDLに代わる言語が出てもいいかな。
2017/08/03(木) 18:26:45.17ID:JgW7vvvx
OCamlが学問分野で今微妙にアツイらしい
2017/08/03(木) 19:50:47.86ID:NS2Ahv95
>>559
どういう理由でアツイの?
またその「学問分野」って具体的にはどの分野?
2017/08/03(木) 19:54:19.27ID:eWbe8h/f
>>559
Googleは君の興味関心を学習して君の見たい世界を見せているということを念頭に置いておいたほうがいいよ
2017/08/03(木) 20:14:27.98ID:JgW7vvvx
>>560
東大辺りの奴らで、機械学習をわざわざOCamlで書いてる輩が増えているらしい 。ライブラリも整備されてきたってよ
>>561
知ってる。ちなみにOCamlの情報はGoogleじゃなくてリアルの交友経由の情報
2017/08/03(木) 21:01:12.44ID:cUZMqwjs
OCamlに限った話ではない
2017/08/03(木) 21:24:53.35ID:JgW7vvvx
まああくまで微妙にアツイだからな
ScalaとかHaskellもあったかな?
他はもうC++FortranPythonMatlabMathematicaしか知らんなあ
ケムインフォマティックスなんかはHaskell Scalaはやってる人いるけど Ocamlは聞かないし、やっぱりHaskell Scalaのが上かな?
2017/08/03(木) 21:35:28.91ID:VGeKeN5L
haskell とか scala とかってもはや学習した時間を無駄だと思いたくない人たちが
無理やり盛り上げてるようにしか思えないんだが。
2017/08/03(木) 21:36:52.08ID:8l5FpDvx
OCamlはマルチコア対応になったらまた始めたい
Jocamlとか折角面白いのにシングルコアなんで魅力半減
2017/08/03(木) 21:37:14.15ID:e6YEFDfb
>>565
は?
2017/08/03(木) 22:18:12.98ID:nBK54dRQ
HaskellもScalaも関数型言語の考え方だけ学んだら用済みで、
取り入れるだけ取り入れたJava8や、Kotlinが正義
このスレでは叩かれたが、今となっては俺の言った通りになったじゃないか
2017/08/03(木) 22:21:48.14ID:WxFDmNeE
正直kotlinが優勢だよね。感覚的には
golangは早めに安定したから今はやってるけど、
また状況は変わりそう。
rustはメモリオーナーシップモデルをswiftにパクられたらいらない子になりそう。
2017/08/03(木) 22:25:27.52ID:N0DDjuI1
>>565
たし蟹
Scalaはそこそこ良い言語だったけど
尖りすぎてKotlinにあっさり置いて枯れてしまった
571デフォルトの名無しさん
垢版 |
2017/08/03(木) 22:39:07.10ID:563u4f2I
kotlinはscalaの知識使えるし別に
webならplayあるscalaの方が有利だし使い分けじゃね
2017/08/03(木) 23:08:37.77ID:nBK54dRQ
>>571
Playは絶賛失速中だろう
コミュニティは機能してないし勉強会もイベントもなく、QiitaやTwitterにももう何もない
Scalaで使ってた人はRailsやDjangoを使い始め、Javaやってる人はSpringに戻っていった
2017/08/03(木) 23:29:24.10ID:6A4YkL5b
やっぱりGroovyやってた人たちが一番先見性あったな
次はどの言語だろう…
2017/08/03(木) 23:39:13.81ID:F8ZQ8AqH
一時のscala ブームは何だったのか?
2017/08/04(金) 00:11:57.82ID:O3MamTZa
>>572
今さらRailsとかどんだけセンスないのおまえ(暗黒藁半紙)

型無し能無しセンスなしの糞ゴミ言語は全員死ね
マツボックリだかなんだか知らんヒゲ爺は
さっさとこのゴミ言語を潰せボケ
2017/08/04(金) 01:18:05.91ID:f63aP9iW
java8w
2017/08/04(金) 04:09:41.88ID:U01kvQtM
rubyってrailsで当てた一発屋なのにね。
2017/08/04(金) 10:42:41.04ID:zYGfuuva
型無し能無しセンス無し
2017/08/04(金) 12:14:49.37ID:rS2vQ23N
セイロンの事も忘れないでね
580560
垢版 |
2017/08/04(金) 14:49:35.41ID:eMF9uhYU
>>562
レスと御教示ありがとう
機械学習のコードをOCamlでですか
2017/08/04(金) 23:25:50.79ID:vuZIQLpQ
むやみやたらと大量のソースコードを量産して、ディスクの肥やしにする最近の風潮になじめない。

元凶はJavaあたりか。

価値のあるコードってのは、定義が難しそうだけど、

たとえば実行可能コードとそのソースコードのボリューム比較を考えてみると、
ソースが理不尽にふくらんでいる気がする。

hello,worldに数十行ってのは本末転倒。

なんでもかんでもオブジェクト指向しなくても、昔も別に困ったわけじゃないんだから、OOが必然ではないはず。

どんどん全体を見渡せる、いわゆる、神の目を持つものが少なくなっている。

まあ、仕事を増やすって意味で業界に貢献してるんだろうけど、ばかばかしいほどにまで非効率になっている
気がするね。
2017/08/04(金) 23:50:29.87ID:ZFg5jE9u
記憶力が落ちただけだと思うよ
自分で気付いてないだけ
2017/08/05(土) 00:35:23.13ID:yfDugfcM
どこの世界の話だ
ここ最近の風潮では、短いコードが正義だと関数型を採用しひたすら抽象化に邁進する流れじゃないのか
2017/08/05(土) 01:02:28.33ID:jB/epMOs
どこの世界の話だ
2017/08/05(土) 02:27:20.31ID:r+UIi6ic
少なくとも日本ではなさそうだな

ジャップランド土人は屁臭いペチプゥで
型無し能無しセンス無しの糞コードウンコモリモリ大将軍してる
基地害低脳ゴミカスしかおらんからな
2017/08/05(土) 09:39:30.67ID:LM2wNYVN
Petit peu な Codeaux un commois liais mois liais?
2017/08/05(土) 12:37:44.56ID:ioSmFHmD
Ceylon は消えるだろうな。キラーアプリが出てくれば別だけど。
(Ruby がRailsで一発当てたみたいに、すごいソフトが出てくればの話だけど)
2017/08/05(土) 12:38:46.91ID:ioSmFHmD
最近のKotolin 推しって何なの?
一時期Scala を押していた人たちがKotolin に移っているのかな?
2017/08/05(土) 12:56:21.44ID:r+UIi6ic
Androidもしらないサーバーサイドお爺ちゃん
組み込み曾お爺ちゃんの後を継ぐのは君だ
2017/08/05(土) 13:04:32.77ID:wQFjSmwa
きっかけはAndroidの件だけど、Kotlinを話題にしてるのはサーバーサイドの連中が中心だろう
Android開発なんて金にならない三流分野で、プログラミングのメインストリームを変えるような影響力なんて無いよ
2017/08/05(土) 13:16:01.72ID:POjfJmBG
今はなんとなくSwiftやTypeScriptのような言語が流行っている雰囲気があるから。
Java/Android界隈の人も var 変数 : 型 って書きたいんだろう。
2017/08/05(土) 15:02:06.08ID:j/cNGuAY
>>590
プログラミングのメインストリーム変えるような連中は、Android開発だろうとサーバサイドだろうとなんでもできるフルスタックが多いんじゃない?
2017/08/05(土) 15:05:18.69ID:RDrQu3eT
var 変数 で型推論してくれるのが前提の書き方のはずで
関数型言語だと「型注釈は(コンパイラが失敗するまで)書くな」だけど
: 型 つけないとコンパイラに怒られまくるなら最初から書いとくのも仕方ないね
2017/08/05(土) 15:37:15.82ID:wQFjSmwa
>>592
フルスタックな人ならクライアントに置くコードは最小限にするはずだから、
Androidアプリを何で書くかなんて深く議論するに値しない些細な問題だよ
2017/08/05(土) 15:51:07.66ID:5/nXCXeI
>>593
>関数型言語だと「型注釈は(コンパイラが失敗するまで)書くな」だけど
誰がそんなデマを言いふらしてるんだ?
2017/08/05(土) 16:12:29.25ID:uXlFBIBD
フルスタックって、FORTH かよっ!
2017/08/05(土) 17:12:21.73ID:n8pq6YqV
天才プログラマが一人で全部作りましたって時代ではないからな。。
2017/08/05(土) 18:16:19.01ID:RDrQu3eT
>>595
逆に積極的に書くのがベストプラクティスなんてのがどこにあるんだよ?
2017/08/05(土) 19:21:58.27ID:j/cNGuAY
まぁ書かないのが良いとはされてるが、プロダクションコードはコード規約とかで、全てに型注釈入れろとしてるとこが多いね
2017/08/05(土) 21:37:34.82ID:boLwVObe
>>598
>>599
意味不明すぎ
型注釈は入れるのが当たり前だろ
単なるジェネリックプログラミングと勘違いしてない?
2017/08/05(土) 22:33:18.79ID:r+UIi6ic
Javaかよ(笑)
2017/08/06(日) 01:46:33.87ID:X6yw5Nga
ScalaでもHaakellでも書くのが当たり前だぞ
2017/08/06(日) 02:30:30.64ID:0wpHTVIH
えっ それはどこの当たり前??
2017/08/06(日) 03:09:28.92ID:OwbCgw8i
OCamlでも普通は型を書くぞ。
2017/08/06(日) 03:13:20.32ID:JQasL6d0
2017/08/06(日) 03:34:23.31ID:0wpHTVIH
OCamlとか死んだ老害言語の話はしてないから
耄碌お爺ちゃんはあっち行ってて
2017/08/06(日) 04:44:58.60ID:X6yw5Nga
>>603
2017/08/06(日) 04:45:24.92ID:X6yw5Nga
なんだエアプが湧いてんのか
2017/08/06(日) 04:54:54.04ID:X6yw5Nga
もしかして式一つずつに型注釈入れるとでも思ってるのかね
そんなのJavaですらやらんよ?

HaskellやScalaは少なくとも各モジュールのトップレベルの関数には型注釈つけるし、つけないと効率悪くなる
コンパイル遅くなりやすいし、推論に頼りすぎるとエラー時に問題箇所が曖昧になるから
2017/08/06(日) 07:49:45.80ID:K4D4wFtM
書いても書かなくてもよいというのが客観的事実だから
理系なら話はそれで終わり
それ以上踏み込むのは文系の仕事
2017/08/06(日) 10:18:56.55ID:fAxfwMN0
OCamlアンチおるな
2017/08/06(日) 10:46:44.29ID:0wpHTVIH
>>609
なら最初からそう書けよ

> ScalaでもHaakellでも書くのが当たり前だぞ
エアプガイジ
2017/08/06(日) 11:37:53.63ID:exhLY8Mw
Ocaml自体は良い言語なの?
あんまり使ってるって人は聞かないけど
2017/08/06(日) 11:40:40.31ID:+mclrVGG
>>613
よく知らないけど金融で使ってる人がいるらしいのと、最近機械学習で使ってる輩がいるらしい
2017/08/06(日) 12:03:55.69ID:K4D4wFtM
>>613
型ありライブラリなし特技なし
2017/08/06(日) 12:23:21.27ID:+mclrVGG
あとHLVMはOCamlじゃなかったっけ?
2017/08/06(日) 14:51:30.93ID:X6yw5Nga
>>612
またお前か
ガイジガイジうるさいだけでなくただの知ったかぶりか
2017/08/06(日) 14:51:53.14ID:9I48IW8u
ocaml, haskell の比較

ttp://d.hatena.ne.jp/camlspotter/20101212/1292165692

まあ極論抜きにして普通に考えればこういうことだろうなという印象。
2017/08/06(日) 15:00:38.52ID:X6yw5Nga
>>618
この人は良く分かってるなあ
純粋言いながらunsafePerformIO使うって件はまさにその通り
結局このIO書くときの面倒さがあるから、ScalaやOCamlのが使いやすい印象になってしまう
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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