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/
2018/02/21(水) 19:30:46.29ID:CION/kfn
>>661
意図はないけど、null安全とかいっておきながらkotlin側だけでnull入るコード書けるのまずいような気がする。
いや、プロパティの初期化方法がうざくて色々調べてたら気づいただけ。
2018/02/21(水) 19:35:19.91ID:CION/kfn
プロパティ宣言すると初期値与えろってうるさいんだけど、うるさいのはいいんだけど初期値の与え方が
val str: String = プロパティイニシャライザ
プロパティイニシャライザ以外、bakcingFieldに直接与える方法ないの??
>>659だって、初期値与えろってコンパイルエラーでるから、セカンダリコンストラクタに
str = "あいう" // これはsetter経由のプロパティアクセス
書いたんだけど、setter経由のプロパティアクセスだとsetterが>>658のようになってるって初期値実際与えられてないし・・
2018/02/21(水) 19:38:04.92ID:CION/kfn
>書いたんだけど、setter経由のプロパティアクセスだとsetterが>>658のようになってるって初期値実際与えられてないし・・

>書いたんだけど、setter経由のプロパティアクセスだとsetterが>>658のようになってるいじわるコードだと初期値実際与えられてないし・・
に修正
2018/02/21(水) 19:44:04.71ID:ftdNQJg9
そういうことね
確かにこれならsetterの部分でコンパイルエラー出て欲しい気がするな
帰ったらドキュメント舐め回してみるか
2018/02/21(水) 22:17:43.95ID:mU+xwBkv
>>658
lateinintつけないでコンパイル通ってしまうなら、Kotlinコンパイラのバグの可能性も...
2018/02/21(水) 22:24:25.01ID:mU+xwBkv
>>666は勘違いでした。申し訳ない。
>>658
多分あまりにも悪意に満ちた常人なら間違え内容のない契約プログラミング違反だから、
そこまでは面倒を見られないということかも。
2018/02/21(水) 22:33:20.79ID:A2iqRMA5
悪意の無い初心者がめちゃくちゃ書いてもちゃんと面倒見てくれるべきだと思う
2018/02/21(水) 23:05:16.86ID:CION/kfn
null安全の導入とともに変数は宣言時に初期値を与えなきゃいけなくなって、
ローカル変数は宣言時に与えなきゃいけないけど、インスタンス変数は宣言時または
コンストラクタ内で与えればOKなんだけど、
backingFieldを持つプロパティと相性悪かった?ってことかな。

backingFieldを持つプロパティはプロパティイニシャライザを与えるか、
コンストラクタ内でbackingFieldに直接初期化するという条件を付けくわえないとだめ?

field:str = "あいう" // コンストラクタ内でのみ使えるbakckingFieldにアクセスする専用構文の導入が必要 か
str = "あいう” // コンストラクタ内でのプロパティへの代入はsetterは経由しないとかの条件が必要
2018/02/22(木) 00:40:47.03ID:P3OwyHQx
バグ相当だと思う

初期化(setter呼び出し)の有無は判定出来ているのだから
コンパイルエラーにするのが難しいなら
その直後にそのプロパティのBacking Fieldがnullだったら
KotlinNullPointerExceptionを投げる処理を暗黙的に追加すべき
2018/02/22(木) 00:42:25.58ID:P3OwyHQx
コンパイラor言語仕様のバグって意味ね
2018/02/22(木) 01:34:10.26ID:2g+h2XZc
null安全の導入->非nullableのクラス型のデフォルト値なんてないから、変数は必ず初期化する
必要がある->(この再、nullable、非nullable関係なく全変数初期化するように)

未初期化の変数がコンパイラエラーにならないんて、これが言語仕様なら
仕様がクソだったってことだな(さすが、適当に作った言語ってことに)。
コンパイラのバグであることを祈ろう。
673666
垢版 |
2018/02/22(木) 06:49:37.65ID:W5l1Fr+S
>>658は、Test()でconstructor()が呼ばれないことについて
エラーも警告も出ないことも問題かもしれない。
>>672
Javaで1回しか代入できないフィールドを作るのにsetterに渡された値を捨ててしまうことは
手法としては考えれられなくはないから、バグではなく仕様かも。
逆にチェックを厳しくし過ぎると出来そうなことができなくなる罠も出てくるから
完璧は無理かと。
Kotlin自体「実用的な」範囲でバランスをとったというコンセプトだし。
674666
垢版 |
2018/02/22(木) 06:57:22.88ID:W5l1Fr+S
>>673
の一つ目は勘違いでした。
Kotlinは便利だけど、いくつかの規則は言語仕様でなく契約に基づいていて
契約違反のコードは勘違いを起こさざるを得ないと言い訳する...orz
2018/02/22(木) 07:31:42.26ID:tIZ7FSiP
C#でいいじゃん
2018/02/22(木) 07:39:36.87ID:HpXxCMc4
>>674
いや、この件は普通にコンパイラの仕様バグだと思うからissue上げて来なよ
2018/02/22(木) 07:44:53.50ID:HpXxCMc4
一回しか代入したくないならセッターの中にそういう処理を書けばいいだけだし、
非NullableなのにNullが入る状態でコンパイルできるのはどう考えてもバグでしょ
2018/02/22(木) 07:45:17.47ID:P3OwyHQx
>>673
そういう手法のときは内部フィールド側はNullableになっているべきじゃないかな
通常ケースの一つとしてnullがあるパターンなわけだから

private var strF: String? = null
var str: String get(){return strF ?: ""} set(value) { }
2018/02/22(木) 09:29:54.25ID:tZO46ghF
setterを空にしたらバッキングフィールドへの代入は永遠にされないのでは?
外部からバッキングフィールドへの代入ってできないよね?
(getterで値を変更するカウンターみたいなやつは別として)。
2018/02/22(木) 21:30:53.59ID:MQzOZIuj
Nullableでないプロパティのsetterがnullの状態で呼ばれることがあるって考えるとなんか気持ち悪いな
俺の感覚だとsetterが呼ばれた時点でフィールドは初期化されていて欲しいしフィールドの初期化にsetterは使って欲しくない
2018/02/22(木) 22:55:00.07ID:4ek3nBtk
JRubyよりはええんか?
2018/02/23(金) 00:50:16.39ID:U4AoY/IO
>>658の var str : String の部分を var str = "aaa" みたいに書くと var なのに str に何を代入しても
中身が"abc"のまま変化しないプロパティが完成w
2018/02/23(金) 00:50:44.77ID:U4AoY/IO
間違えた。"abc"じゃない"aaa"な。
2018/02/23(金) 07:49:04.02ID:bsuGQjVb
>>682
ワロタ
嫌な会社を辞めるときにテロとしてそういうコード残しておくイタズラとかできそう
それはそうとnullableじゃないのにnullになりうるセッターがコンパイル通るのはやっぱおかしいよな
そんなんする奴がいるのかって話ではあるが
2018/02/23(金) 08:31:33.24ID:nqFe2RWJ
githubにあるkotlinのプロジェクトはissuesのリンクがないや
どこに報告すればいいんだ
2018/02/23(金) 08:54:38.23ID:MOvRrowf
>>685
なぜREADMEを読まない…
687デフォルトの名無しさん
垢版 |
2018/02/23(金) 14:54:59.97ID:0k9d4/AB
まとめ
https://paiza.io/projects/E8Wb5DZH7qOC-b5hcPSk3Q
2018/02/23(金) 18:54:32.34ID:fUBBLv0N
こりゃダメだ
C#使おっと
2018/02/23(金) 19:22:20.80ID:tkkK8G2q
>>687
えぇ…これ仕様通りなん?だとしたら糞じゃね?
690デフォルトの名無しさん
垢版 |
2018/02/23(金) 20:44:31.66ID:Py5a3myD
>>688
C#はこういうこと起きないの?
てか、そもそも同じような形式のプログラム作れるの?
2018/02/23(金) 21:13:42.52ID:8lqriKW0
C#はそもそもnull安全じゃないから出てくること自体おかしい
2018/02/23(金) 21:26:34.63ID:i7MOfoRF
8.0ではoptinでnull安全にできるようになるんじゃなかったけ。まあ、でもmicrosoftはこんなポカしないと思うけど。
2018/02/23(金) 22:05:57.26ID:R3lraTlN
オプティン…
2018/02/23(金) 22:13:05.72ID:YiHajEe6
・セカンダリコンストラクタが存在する
・代入して初期化してる(ように見える)プライマリコンストラクタかセカンダリコンストラクタがある
この2つを満たすとコンパイル通っちゃうのかな
https://paiza.io/projects/78ZAW5fM_jNEyfhRPD5VbA
2018/02/23(金) 22:28:48.21ID:8lqriKW0
>>694
こりゃコンパイラのバグ説が濃厚だな
2018/02/23(金) 22:46:50.15ID:ZKkKvK7/
完全に趣味でSwift触り始めたんだけど、ことりんと似すぎてて脳の切り替えが大変
2018/02/23(金) 23:32:19.57ID:gu5jD4u6
setterがNOPだからでしょ
何もおかしくないと思うんだが
2018/02/23(金) 23:51:24.69ID:pZoCSvCU
>>697
Javaなら何もおかしくないけど、これはkotlinなんですよ
2018/02/24(土) 00:23:17.37ID:KMKYwria
あー、ごめんごめん、nullableじゃないのにってことね
2018/02/24(土) 06:43:01.61ID:geSYf0sR
SwiftではOptionalよん
2018/02/24(土) 06:47:11.68ID:H2lSL8Bq
そこら辺の名称も統一してくれたらよかったのに
2018/02/24(土) 08:17:33.01ID:vmshfWHt
引数や戻り値の属性(アノテーション)としての出自でNullable (@Nullable)
型引数を持つデータ構造として出自でOptional (Optional<T>)
2018/02/24(土) 08:21:38.91ID:gsJVlH30
だから何?
2018/02/24(土) 08:32:56.79ID:vmshfWHt
単なる経緯にだからも何も無いんだけど
2018/02/24(土) 09:18:53.65ID:b9ViFkCo
Optionalではアンラップが必要で、Nullableでは不要
2018/02/24(土) 15:32:03.48ID:QRpOEI48
つまりOptionalは神Nullableは糞
2018/02/24(土) 15:33:06.32ID:QRpOEI48
間違えた逆だNullableは神Optionalは糞
2018/02/24(土) 16:29:10.25ID:XDApard5
神と糞は種類が違うだろ
2018/02/24(土) 16:55:50.73ID:La3HIAz8
Xamarin程の糞はない
2018/02/24(土) 20:13:00.64ID:geSYf0sR
Kotlinではnullにならない型など存在しないのだ、がっはっは
711デフォルトの名無しさん
垢版 |
2018/02/24(土) 23:25:19.26ID:QE7g/pJn
神は糞である。
2018/02/25(日) 06:02:39.69ID:z/Jlakx1
糞は紙で拭け
2018/02/25(日) 10:33:42.84ID:4s22ePtw
Kotlinインアクションの尼評価低いなと思ったら理由が「難しい」ってw
2018/02/25(日) 10:54:15.05ID:skC5U3zO
やっぱGroovy in Actionだろ、GradleはGrooovyなんだぜぇ
715デフォルトの名無しさん
垢版 |
2018/02/25(日) 11:44:58.69ID:XjF3qDop
こんな本が出てたんだな。

Androidアプリ開発の教科書
http://amzn.asia/59lxVwl
2018/02/25(日) 11:46:33.02ID:XjF3qDop
あ、Kotlin で検索したら出てきた本だけど Kotlin とは限らないみたいだな。すまん。
2018/02/25(日) 11:50:17.94ID:XjF3qDop
すまん。Kotlin の K の字も出てこないな。忘れてくれ。
2018/02/25(日) 12:40:42.33ID:pcyqC+jB
Kotlinイン・アクション、2017

Kotlinスタートブック -新しいAndroidプログラミング、長澤 太郎、2016

せっかく太郎が、イン・アクションを参考にして、わかりやすく書いたのだから、
日本人は、太郎本を読んだ方がよい
2018/02/25(日) 13:02:41.55ID:OHKw3fir
情報量はインアクションの方が多いから、わざわざ薄めた本を買う必要なんてないよ
2018/02/25(日) 13:29:07.46ID:V/Ygd9gi
>>718
お前はスッキリをすすめてろよ
2018/02/25(日) 14:16:36.00ID:4s22ePtw
Kotlin本といえば今のところインアクションとスタートブックの2択だと思うけど、
「難しい」って理由でレビュー評価下げるのはどうよ?と思ったんで、難しい以外に
インアクションで問題点ある?
バージョンが古いとか?
2018/02/25(日) 14:31:03.18ID:VQCl2C19
※716
Androidの入門本なんてAndroid搭載機種の種類と同じくらい大量に出てるのになぜわざわざそれを貼ろうと思ったのか
2018/02/25(日) 14:41:45.45ID:XjF3qDop
>>722
先に書いた通り、AmazonでKotlinで検索して出てきたため。
2018/02/25(日) 15:09:27.72ID:Ydc/tL+D
電子書籍でレイアウト固定だと買う気しない
2018/02/26(月) 08:03:23.98ID:RZjRtr5i
知らんけどkotlinのandroid入門書なんてもう山ほど出てるんちゃうの?まだjavaばっかなの?
726デフォルトの名無しさん
垢版 |
2018/02/26(月) 08:23:30.09ID:t40oU2wX
まだ一冊しかないのでは?
2018/02/26(月) 08:27:44.65ID:RZjRtr5i
そうなのか、意外と動き遅いんだな
2018/02/26(月) 08:56:28.62ID:qQ1Da7Hp
本で勉強する時代じゃないからね
2018/02/26(月) 09:20:17.57ID:G+urRbGd
細切れ情報を探すのはやだな。レベルも方針もバラバラだし。
良書があるなら本がいい。
2018/02/26(月) 09:34:26.29ID:/jWICelY
まあ、AndroidでKotlin使うのは増え続けるだろうから何れ本も増えるだろう。
2018/02/26(月) 09:43:22.22ID:CZmy/XEe
本は中古やで何冊かあったよ、まだ高かったけど
正直Pythonは失敗だったと思う
2018/02/26(月) 10:09:15.19ID:G+urRbGd
pythonは糞本で良書が埋もれちゃってる
2018/02/26(月) 10:47:30.45ID:/j3wCSg3
Null Objectパターン流行るといいなあ。
734デフォルトの名無しさん
垢版 |
2018/02/26(月) 13:51:07.53ID:Mu1MCm3E
>>732
流行った言語は自動的にそうなる。
2018/02/26(月) 17:53:54.70ID:i6+hAPO4
>>733
流行るも何もgof23パターンのうちの一つだぞ
2018/02/26(月) 18:03:06.16ID:3e/qclCH
Null Objectはgof外でしょ
2018/02/26(月) 18:15:26.27ID:i6+hAPO4
>>735
すまぬ。
どうやらボケが始まったようだ…
2018/02/26(月) 18:44:34.21ID:3e/qclCH
気にするな、禊としてXamarinのライセンス買ってこい
739デフォルトの名無しさん
垢版 |
2018/02/26(月) 18:51:59.91ID:3Mt4XsWV
買わない買わない
2018/02/26(月) 19:46:08.16ID:FSYyOpBd
>>721
本を読んだけどどっちもよかったよ。
ただ読み手のスキルで理解力に差があるからそこで評価が分かれてるのかも。
2018/02/27(火) 10:02:27.46ID:GEmGj4yT
IntelliJの変換機能使ってシコシコKotlinに変換してるけどstatic無いのがウザくなって来た
Swiftにはあるのにー
2018/02/27(火) 12:16:20.20ID:pU97M93t
>>741
コンパニオンは?
2018/02/27(火) 18:56:17.20ID:9XUAnYvD
自動変換使ったら普通にcompanion objectにならなかったっけ
2018/02/27(火) 20:07:07.98ID:VEiALCIH
スーパーコンパニオンがいいです
2018/02/27(火) 23:14:15.97ID:m5Iw3K9X
自動変換してもコンパニオンにならなかったから、シコシコ変えてる
2018/02/27(火) 23:34:21.25ID:l+pACPTY
Android stuiosって糞重いのな
Xcodeの比じゃなかったわ
2018/02/27(火) 23:39:03.53ID:oVWfwCMw
Core i7、メモリ32GBだけど、コーディングに支障があるほど重いとは感じないかな
2018/02/28(水) 00:05:50.05ID:KPu2dHe+
ノート用のi5、8Gでもサクサク動くぞ
2018/02/28(水) 01:54:55.83ID:SwOhtkGH
基本xcodeの方が重くない?
750デフォルトの名無しさん
垢版 |
2018/02/28(水) 04:32:16.89ID:ifAjmiIg
Android stuios...
2018/02/28(水) 06:49:11.80ID:qqsPLA0F
明らかにxcodeの方が重い
2018/02/28(水) 06:51:00.64ID:qqsPLA0F
あ、Android StudioじゃなくてAndroid stuiosの話なのか
それなら知らんわ
2018/02/28(水) 07:13:17.29ID:hln4Ed73
VisualStudioはサクサク動くね
2018/02/28(水) 08:34:11.55ID:pTBSmEfK
Android Studioはエミュレータの起動が激重
2018/02/28(水) 08:51:39.92ID:CR0DdEON
お前のPCが糞なんだろ
756デフォルトの名無しさん
垢版 |
2018/02/28(水) 09:34:38.82ID:3IEGD0z0
そういやエミュレータは遅いな。あれ速くならんもんかね?実機に繋いじゃうしかないか?
2018/02/28(水) 11:19:49.30ID:fhD/c/L7
そんなにおもいか?
2018/02/28(水) 12:23:44.87ID:pWBZNbli
その部分はXcodeも糞重いからまあしゃあない
2018/02/28(水) 13:05:00.32ID:/o1cB3Jz
お前の収入がまともなPCも買えないほど低いだけ
2018/02/28(水) 15:32:06.67ID:nKEiX8dA
Flutterが話題になってるけど、Dartなんだよなあ、、
2018/02/28(水) 15:32:21.47ID:nKEiX8dA
Kotlinならよかったのに
■ このスレッドは過去ログ倉庫に格納されています
5ちゃんねるの広告が気に入らない場合は、こちらをクリックしてください。