Kotlin 2

■ このスレッドは過去ログ倉庫に格納されています
2017/11/01(水) 00:07:43.82ID:jxmKQQAl
JetBrainsが開発した期待の新言語Kotlinについて語りましょう
https://kotlinlang.org

前スレ
Kotlin
http://mevius.5ch.net/test/read.cgi/tech/1456505161/
2017/11/04(土) 11:18:50.17ID:onhYINWl
Kotlinの仕事ができてないお前ら失業確定www無職ざまあwwwwww
2017/11/04(土) 11:58:10.64ID:hKqH3C3y
>>49
Java使ってれば違和感なく移行できますと言われつつ、実際はプチパラダイムシフトの受け入れが必要なのはちょっと不誠実かなとは思う
我々は「うっひょー○○言語や××言語のアレみたいだね!」とか喜ぶわけなんだが
Javaしかやらないような人から見たら「Javaとは全く違うだけの気持ち悪い何かがくっついてる」としか思えない可能性は高い
2017/11/04(土) 12:33:29.77ID:jcPkxcYi
>>51
アピールしてるのは「相互運用性が高いから移行できます」であって、「違和感なく移行できます」では無いよ
そういうのを書いてる第三者の記事はありそうだけど

公式的にはむしろ関数型に力入れてるのを売りにしてる
2017/11/04(土) 19:11:42.37ID:mE4V8fBV
>>51
> Javaしかやらないような人から見たら「Javaとは全く違うだけの気持ち悪い何かがくっついてる」としか思えない可能性は高い

そうやって全く関数型やらモダン言語らしいとこ使わない違和感あるKotlinコードが出来そう
2017/11/04(土) 19:14:15.39ID:YWCXhaIP
プロパティと型推論しか使わないのもあり?
それならできそう。
2017/11/04(土) 22:23:46.53ID:g0AJbdlv
>>38
Kotlin in action買おうか迷っているけど、公式サイトの解説と比べてもっと深いことが書いてあったりする?
ちなみにKotlinスタートブック は読了済み。
2017/11/04(土) 22:34:52.81ID:U6RGh2Ax
>>54
javaとの対比だとプロパティとnull安全だな。最も有用
それ以外はコーディング的な進化だから追々覚えればよい
2017/11/05(日) 00:26:43.77ID:x5/Ij6xv
俺のお気に入りのF#はなんだかんだでnull残ってるから、その点はkotlin羨ましい
58デフォルトの名無しさん
垢版 |
2017/11/05(日) 00:58:12.21ID:YBVMpJn0
残念ながらjava互換だからnullは無くならないのだよ
2017/11/05(日) 02:57:49.62ID:WRVCeBNz
ガードしない場合、ぬるぽが起こる割合はJavaとほぼ同じ
言語の仕組み上安楽にガードしやすいってだけの話だからね
しない・できない・忘れてたという場合はぬるぽぬるぽぬるぽだ
コードはまさに意図した通りではなく書いた通りに動く
そこでは思想など無意味だ
2017/11/05(日) 11:18:58.60ID:vfJyTH9D
Android Studioでのコード補完のパラメータ表示にInputStream!とか末尾に「!」が
ついてるんですが、これは何なんでしょうか?
61デフォルトの名無しさん
垢版 |
2017/11/05(日) 11:55:04.18ID:WRVCeBNz
IntelliJ の T! は「T か T? のどちらか」を示す
つまりNullableかどうかすらわかんねえという記号
2017/11/05(日) 12:09:14.89ID:vfJyTH9D
>>60
ありがとうございます。Java絡みのは当たり前ですが、ほぼそうなってますね。
理解しました。
2017/11/05(日) 12:47:54.37ID:pFqd1r18
忘れてたって言ったって全部に?付けないとJavaと同じにならないわけで
?付けなけりゃコンパイル通らないしNULL安全意識せざるを得ない
2017/11/05(日) 14:29:21.23ID:kyKiHR5g
!! は、Nullable を、NotNull に強制変換する、危険な演算子だから、
requireNotNull 関数を使え

例えば、Java から、null が代入される場合、
String → IllegalStateException。ヌルポよりまし
String? → Nullable なのでOK

Platform Type
型を省略(String!) → デリファレンス時に、ヌルポ

Java からの戻り値がすべて、Nullable になるのは困るので、
その折衷案がPlatform Type
6564
垢版 |
2017/11/05(日) 14:35:11.49ID:kyKiHR5g
Java からの戻り値をすべて、Nullable にするのは面倒なので、
そのまま使ったのが、Platform Type

デリファレンス時に、ヌルポとなるため危険!
66デフォルトの名無しさん
垢版 |
2017/11/05(日) 14:40:57.73ID:YBVMpJn0
めんどくせえな
2017/11/05(日) 15:03:32.80ID:cR0WBKoF
Javaのほうのコードに@NonNullアノテーションつけとけば、KotlinからT!じゃなくてTとして扱える
2017/11/05(日) 15:52:17.12ID:WRVCeBNz
現代的な気遣いのされてるJavaライブラリはKotlinからでも便利に扱える
シガラミがあって旧来のままのライブラリはそりゃ利用者側が手間かけるしかない
69デフォルトの名無しさん
垢版 |
2017/11/05(日) 16:52:07.10ID:J++DNvfV
ラッパークラス作るぐらいしか方法なさそうだな
2017/11/05(日) 18:48:00.64ID:WL5EiVt2
ラッパークラスもありだし、OSSなライブラリだったらアノテーション付与してPR送るのも有用だな
2017/11/05(日) 19:23:52.87ID:giKdejUB
Kotlinから使いやすくなりました! みたいに言えるのはひょっとしたら売りになるかもしれんね
2017/11/05(日) 19:25:37.10ID:zDQnBwdh
ことりちゃん、マジ使いやすいぜグフフ
73デフォルトの名無しさん
垢版 |
2017/11/05(日) 19:26:26.36ID:YBVMpJn0
ことりんの擬人化はよ
2017/11/05(日) 20:25:14.58ID:UMg3GOyt
>>33
2017/11/05(日) 22:47:01.75ID:z1YM2S+z
(・8・)
76デフォルトの名無しさん
垢版 |
2017/11/06(月) 10:56:08.46ID:OqkByGQj
やはり擬人化が必要だな
萌えキャラで
2017/11/06(月) 11:49:59.43ID:kblaZiQ3
何のために必要なの?
78デフォルトの名無しさん
垢版 |
2017/11/06(月) 13:01:01.21ID:V0vtn4gd
それは君には中々理解できない理由による。

例えば以前Appleが傾いた時にジョブズが復帰してiMacを作ってAppleは救われたが、iMacはハードウェアとしてそんなに素晴らしかっただろうか?
たいして素晴らしくはないのだ。ブラウン管ディスプレイに本体入れて一体化しただけだ。しかし売れた。なぜか?
デザインがよかったからだ。コンピュータとしてはどうでもいい見た目が売れ行きに多大に影響した。
技術者から見ればどうでもよさそうなものでも甘く見てはいけないということだ。
2017/11/06(月) 13:32:09.21ID:wZC/0idP
>>77
技術的な話をスレでされても理解できなくて不愉快だから「とにかくほかの話」をさせたがっている
知らない言語のスレなんて見なきゃいいのにね
2017/11/06(月) 15:15:58.89ID:DlVzck/L
goが人気になった要因もgopher君が半分くらいあるからな。ことりんはいいな
81デフォルトの名無しさん
垢版 |
2017/11/06(月) 15:18:23.96ID:8DS1P3Ga
ほんとおまえらはばかだなあ
日本の電子IT系なんてオタクの巣窟なんだから萌えキャラことりんで流行言語間違いなしやで
2017/11/06(月) 16:21:48.60ID:kblaZiQ3
うわぁ、、、
2017/11/06(月) 16:34:20.33ID:9YhppvEm
ことりんとペアプログラミングしたい
2017/11/06(月) 19:29:33.22ID:otMLf3Eu
「ことりん」のライバルが「ざまりん」で草
85デフォルトの名無しさん
垢版 |
2017/11/06(月) 20:50:33.70ID:iuxlkbQ9
インアクションとなんとか太郎本どっち買おう
後者は本屋で見たんだけど
2017/11/06(月) 21:11:27.46ID:RNAOm4Mq
目指すとこがちゃうからな
現在どのくらい習熟してるかにもよるかと
2017/11/07(火) 06:11:35.45ID:uepCx6fG
「たのしいRuby 第5版、2016」高橋 征義
「みんなのPython 第4版、2017」柴田 淳
「Kotlinスタートブック、2016」長澤 太郎

この辺は、日本では、避けては通れない人達
2017/11/07(火) 06:23:46.73ID:W6HmiFf1
逆に避けなくてはいけない人達はだれ?
2017/11/07(火) 07:22:52.64ID:atDIxfPJ
掌田津耶乃
2017/11/07(火) 08:53:40.81ID:kYRdbaxp
掌田津耶乃
91デフォルトの名無しさん
垢版 |
2017/11/07(火) 12:19:01.95ID:yzrwY/tJ
そうなの?どういう点がまずいの?
2017/11/07(火) 12:37:41.70ID:08KjVeec
内容が薄い
93デフォルトの名無しさん
垢版 |
2017/11/07(火) 12:40:11.22ID:yzrwY/tJ
なるほど。
濃いめなのは?
2017/11/07(火) 12:53:17.32ID:atDIxfPJ
>>91
公式のチュートリアルをパクって
チョコっと変えて解説してるだけ
2017/11/07(火) 14:06:00.83ID:uepCx6fG
掌田津耶乃は、ほとんどの言語・フレームワーク・開発環境の、本を書いてる

売れ筋では、必ず顔を出す。
売れる分野に、掌田あり!
2017/11/07(火) 17:10:16.14ID:qyKBmVxs
公式見て自習しろや、が通じるならセミナーとか講演会とか必要ないわけでな(いや、これに関しては別に必要ないとは思ってるが)
世の中の需要はあんまりロジカルではないのだ
2017/11/07(火) 21:38:52.62ID:tWasbjrL
>>85
太郎しか読んでないでActionは買ったばかりだけど、
Javaは一通りで来てKotlinをとりあえずやってみたいなら太郎、
Kotlinにどっぷり漬かることが確定しているならAction?かな
いずれにしてもJavaの理解はないとかなり不利。

>>95
器用貧乏というやつですね、わかります。
2017/11/07(火) 22:51:30.64ID:6NdbJPOz
昔の河西か
2017/11/07(火) 23:03:28.24ID:kYRdbaxp
入門書ばっかり書いて金儲けするのが目的なんだろう
2017/11/07(火) 23:20:19.14ID:hhPr1fc6
やってみるとわかるのだが(やらなくてもいいが)、中上級者向けの本というのは全然儲からないのだ
書くの時間かかるし分厚くなって値段高くなるし売れなくなるしチェック内容増えるし時代遅れが混じるし下手すると共書だし
出来によっては「あのすごい便利な本を書いた人」という称号はいくらかの称賛になり、ひょっとしたら生活豊かルートをも開拓するかもしれないが、分は悪い
初心者向けの本をひとりで年に2冊くらい書いてたほうが、志低いと揶揄されながらもきちんと生活できるのさ
2017/11/08(水) 01:07:22.53ID:3tNQk30d
粗製濫造して食う飯はうまいか
2017/11/08(水) 01:24:37.30ID:pvxNciwf
やってみるとわかるとな?
2017/11/08(水) 05:57:05.62ID:Z7LnM2jK
掌田津耶乃って何者? (Late 2012)
http://egg.2ch.net/test/read.cgi/mac/1349360916/

1 :Mac Fan Letterより転載 [sage] :2012/10/04(木) 23:28:36.22 ID:ZGQCgQTH0
● ネットサーフの溺死者たち
「友がみな我より偉く見ゆる日よ」

「2チャンネル」という最低最悪のサイトがある。
2017/11/08(水) 06:28:34.57ID:ShM00Q+N
>>94
器用貧乏とは言ったものの、翻訳書が原書+1000円くらいの値段になることがざらなことを考えると
英語の公式チュートリアルを訳しただけでも、値段相応なのかもしれん。

しかし、著者のことをよく知らずにタイトルだけでうっかり買ってしまったものの身にもなって欲しい(自己責任)
深く理解した上で書かれた本かどうかは、(本を必要とするレベルの人には)立ち読み程度ではわからない。
2017/11/08(水) 08:32:48.67ID:a/cZ4nXd
Kotlinに限らずあれもこれも全く初心者に寄り添っていないことを鑑みると、初心者向けの本を書くというだけで価値があるのやもしれぬ
あなたがライブラリマニュアル作るときに開発環境のダウンロードやプログラミング言語の文法から説明しないのと同じだ
2017/11/09(木) 10:27:49.04ID:IVrwQxMl
「単純に意味や役割が似通ってるメソッドを集めただけのメソッド集」を表すものってないですかね
Rubyでいうmoduleみたいなやつ
特にどのオブジェクトに属してるってわけでもない、誰も初期化しなくてよくてすぐメソッドが使えるやつ
いまobjectでシングルトンクラスにしてるけど、なんか漂う特別感に違和感が
2017/11/09(木) 12:13:06.41ID:77e4Bz/I
適当なネームスペースで、メソッドじゃなくて関数だけ複数定義したファイルを作ればいいんじゃないかな?
2017/11/09(木) 13:29:13.78ID:IVrwQxMl
ああなるほど、packageで分ければいいのか…
シングルトンクラスの中に書くよりはしっくりくる…ような…気が…す…うん、そういうものだと思うことにします
2017/11/09(木) 21:56:51.74ID:+8G/D3P4
Kotlinで以下の処理をスマートに書き直したらどうなりますか

int idx = -1;
for (int i=0; i<list.size(); i++) {
  if (list[i].data == data) {
    idx = i;
    break;
  }
}
(idxを使った処理)
2017/11/09(木) 22:05:39.85ID:UXPTP/DS
val idx = list.indexOfFirst{ it.data == data }
111デフォルトの名無しさん
垢版 |
2017/11/09(木) 22:25:18.35ID:UmUHoiDy
逆引き、ポケットリファレンスものを出して
2017/11/09(木) 22:52:38.14ID:+8G/D3P4
>>110
サンクス!まさか1行でできてしまうとは。。
Android Studioに貼り付けてもこうはならないよね
113デフォルトの名無しさん
垢版 |
2017/11/10(金) 09:13:11.87ID:oAWKYFWM
>>111
とりあえずここで質問すれば答えが書かれるので、後でまとめページを作れば良い。
2017/11/10(金) 09:42:49.25ID:ju9EA6eo
Kotlin、、怖ろしい子。。
2017/11/11(土) 02:40:35.26ID:BhMQDmGd
じゃばの妹ことりん
116デフォルトの名無しさん
垢版 |
2017/11/11(土) 03:22:51.50ID:xG+5Xfzv
>>115
なんだその国民の妹みたいな表現は
2017/11/11(土) 10:02:03.10ID:N7WPFjKT
ことりん星からやったきたことりん
2017/11/11(土) 10:10:11.58ID:ydtAG8Bz
>>117
それ最後に爆発するやつじゃんw
2017/11/11(土) 11:27:33.83ID:GExxj/Q0
お前ら「よーし新しく覚えたKotlinのあんな技こんな技使ってコーディングするぞー」
〜 数日後コードレビュー 〜
リーダー「あー、これ全部Javaと同じ感じで作り直しといてネ、ヨロシク」
2017/11/11(土) 13:22:59.28ID:2zKmkyWC
ゆうこりん
2017/11/11(土) 14:04:32.65ID:7fLEJN4j
>>119
コーディングルールでピュアJava使えってなってるならただのアホだろw
2017/11/11(土) 21:12:50.74ID:F2DPX6tK
>>121
トップがKotlinへの移行を目指して次はKotlinとJavaの混在プロジェクトにするとか言って、
でも所属するチームのトップがJavaしか使わないとかいうシナリオなら、
>>119のような事が起きたとしても>>121の言うような矛盾はない...と思う。
123122
垢版 |
2017/11/11(土) 21:14:35.14ID:F2DPX6tK
そして逆コンパイルしたJavaを提出して盛大に怒られる...みたいな。

こんなことで連投してスマン
2017/11/12(日) 01:41:23.15ID:x+b1eGgz
そんな会社辞めちまえ
2017/11/12(日) 02:34:42.29ID:0YSprajH
君、セミコロンを忘れているよ。
126デフォルトの名無しさん
垢版 |
2017/11/13(月) 09:38:49.46ID:Ffr39/Md
2017/11/15(水) 06:46:05.48ID:cIMRwHcF
>>126
君、中身を忘れているよ^^;
128デフォルトの名無しさん
垢版 |
2017/11/15(水) 12:16:34.07ID:XQCt13cq
println(";")
2017/11/15(水) 12:45:09.17ID:P+eW6LIt
ぷりんとりん
130デフォルトの名無しさん
垢版 |
2017/11/15(水) 17:33:26.94ID:NOd3J7Vc
そういや print って印刷って意味だよな。もはや時代も変わり誰も印刷してないのにプログラミング言語では print で出力が定番になっちゃったな。
2017/11/15(水) 18:04:14.40ID:svkVDlGw
厳密には印字なのでギリギリ合ってる
原初のBASICのPRINT対象はテレタイプだったから印刷するという意図とはそもそもちょっとだけ違う
2017/11/15(水) 18:13:51.46ID:B4seksg+
ポワトリン
133デフォルトの名無しさん
垢版 |
2017/11/15(水) 20:09:08.28ID:hiEIJUlA
ブラウン管に文字を焼き付けるから print

無理があるな。
134デフォルトの名無しさん
垢版 |
2017/11/16(木) 10:46:41.50ID:Wcsn/bEa
printの古い意味は押すだからな
2017/11/16(木) 11:23:36.83ID:pe2ew9X7
そういえば昔、プリントごっこで押しまくってたな
136デフォルトの名無しさん
垢版 |
2017/11/16(木) 11:54:15.38ID:czRbGJih
putもあるやん
137デフォルトの名無しさん
垢版 |
2017/11/16(木) 12:14:02.89ID:Wcsn/bEa
>>136
putは置く
138デフォルトの名無しさん
垢版 |
2017/11/16(木) 16:02:46.86ID:bDWmFK6d
押して痕跡残すようなのが print だな。
2017/11/16(木) 20:15:28.89ID:Sk98YgzR
kotlinの文法ってちょっと省略しすぎだし、やりすぎじゃねぇの・・・
C#の方がバランス取れてるわ。
2017/11/16(木) 21:14:22.81ID:3Aqd/ZMZ
>>139
具体的にはどういう文法のこと言ってるの?
141デフォルトの名無しさん
垢版 |
2017/11/17(金) 08:55:38.80ID:YqqDZ5Dd
慣れの問題だと思うけどなあ
2017/11/17(金) 09:43:27.88ID:Ddb5xKAY
抽象化と少ないコードが正義な昨今の風潮ではこういう文法が受ける
本当にこれで良かったのかは後10年ぐらいしたらわかるだろう
2017/11/17(金) 09:59:51.99ID:QGpoznNs
>>140
どれがとは言いにくいけど>>139の言いたいこともわかる気がする。
個人的にはコンストラクタをクラス宣言に書けば、フィールドやコンストラクタの宣言を省略できる仕様とか。
2つ以上のコンストラクタを定義したり複雑なコンストラクタを定義しようとするときの表現に一貫性がなくなったと思う。
フィールド(Kotlinではプロパティだっけ)の記述場所もクラス宣言と本体にバラバラの配置になるし。

Javaにしとけばいいのかもしれないけど、null安全に書いてみたいと思って使っている。
あとwhenがお気に入り。
2017/11/17(金) 10:24:11.98ID:welKudTx
CP/M80上で動くKotlin処理系が無い…
2017/11/17(金) 10:46:54.88ID:8xh7qM4F
これはこれで同じこと書いてる感がん〜って感じではある
class MyData(name: String, age: Int){
val name = name
val age = age
}
引数にval書けちゃうことでの「見かけ一貫性の破れ」と「引数もチェックしなければならなくなったという手間」は肯定する
2017/11/17(金) 10:51:53.19ID:ENBrszFD
というかあれはdataクラスを便利に書くためだけのギミックな気がするぞ
しかし言われてみれば視線的にめっちゃ遠いのはその通りだな、家のやつは今度使わずに書いてみるか
147デフォルトの名無しさん
垢版 |
2017/11/17(金) 11:08:33.26ID:YqqDZ5Dd
>>144
JavaVMが動かんわw
2017/11/17(金) 15:22:12.81ID:4edLbtL+
KotlinがNull安全といっても結局、Javaなどの使用するクラスライブラリがNull安全じゃないからな。
Kotlinだけで閉じてればいいけど、Kotlin最小限のライブラリしか用意してねぇし。どうすりゃいいんでしょうか??
「!!」演算子積極的に使えばいいの?
2017/11/17(金) 15:36:01.97ID:ocCweAVX
自分のメソッドは全部ヌルポ無しにすればいい。
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。

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