X



Kotlin 5

■ このスレッドは過去ログ倉庫に格納されています
0292デフォルトの名無しさん
垢版 |
2019/02/15(金) 16:15:05.26ID:PR4djPv7
>>291
Javaの制限を理解すること
JVMは.NETのCLRに比べて機能的にはずっとショボくて、その制限に由来する奇妙な仕様がKotlinには数多く存在する
Javaに慣れてないとそのあたりは直感的に理解しづらい
0294デフォルトの名無しさん
垢版 |
2019/02/15(金) 17:29:59.00ID:tar5L0r6
>>291
プログラム言語全般に言えることだけど
各構文を概要程度でも良いので、まずは一通り知ること

C#知ってて引っ掛かりそうな箇所として思いついたのは
・最後のパラメータがラムダの場合は丸括弧の後に書ける
 他に引数が無い場合は丸括弧も省略出来る
 (GroovyやSwiftのTrailing Closureと同じ)
・レシーバ付きラムダ
・inlineラムダ
・returnはfunから抜けるもので、ラムダから抜けるものではない
・IterableとSequenceは遅延評価
・コンパイルでジェネリクス情報は消える
・suspendは同期(await)が基本動作
0296デフォルトの名無しさん
垢版 |
2019/02/15(金) 22:07:22.01ID:KHCIiBIM
kotlin勉強中なんだけど、結局のところjetbrainsがscala推さずにkotlin出したのは何でなの?
商業的に旨みがあるから?それともbetter javaとしてのscalaに見切りをつけたから?それとも?
0298デフォルトの名無しさん
垢版 |
2019/02/15(金) 23:10:54.49ID:9S5XTVoX
>>296
自分でScalaやってみればすぐにわかるよ
まともな感性があれば、あんなものが普及するわけがないことは明らかだった
JetBrainsもIDEを作る会社として自由にできる言語が一つは欲しかったというのはもちろんあっただろうけどね
0299デフォルトの名無しさん
垢版 |
2019/02/15(金) 23:25:58.35ID:KHCIiBIM
>>296
なるほど。Scalaのこれ以上の普及は難しいという判断があった(だろう)ってことなら納得。
0302デフォルトの名無しさん
垢版 |
2019/02/16(土) 17:00:29.98ID:odkD9xpX
なんだかんだでscalaは採用企業多いけどね
kotlinもtwitterとかpaypalみたいな大手で使ってくれると宣伝になるんだけど
0304デフォルトの名無しさん
垢版 |
2019/02/17(日) 08:06:13.22ID:8BWCGdz7
Scalaの方が出たのが早かったし意識高い系(笑)が挙って使ったから
でもそれを維持出来る新人たちが居ないのが現状
Scalaは端的に複雑で難解な部分が多い
2018年後半以降Scalaの記事殆ど見かけないやろ?
コップ本(笑)
0305デフォルトの名無しさん
垢版 |
2019/02/17(日) 11:12:07.88ID:IdBTBZJc
Androidの公式言語がScalaになる世界線もあり得たと思うけど、そうならなかったってことはつまりそういうこと
0306デフォルトの名無しさん
垢版 |
2019/02/17(日) 11:17:52.27ID:IdBTBZJc
一年くらいScalaで仕事してたしまあ慣れればどうってことはないと思うけど、ScalaとKotlinで選べるとしたらよほどの変人以外はKotlin選ぶと思うわw
0308デフォルトの名無しさん
垢版 |
2019/02/17(日) 11:57:32.09ID:nzXhLQND
Scalaのコンセプトは、スケーラビリティの理論実証
 オブジェクト指向と関数型の統合によりスケーラビリティが実現すると考え
 小規模から大規模まで同じ書き方/考え方で記述出来るように設計されている
 出自はコンピュータサイエンスの学者

Kotlinのコンセプトは、より良い産業向け言語
 Javaからの移行や相互運用、コンパイル速度、使い勝手について
 「仕事の道具」であることを意識して設計されている
 出自はIDE製品を提供する企業
0309デフォルトの名無しさん
垢版 |
2019/02/17(日) 12:47:22.79ID:7MWZQWrl
どっちも我田引水なだけやん
0310デフォルトの名無しさん
垢版 |
2019/02/17(日) 13:01:53.97ID:nzXhLQND
設計思想と既存資産があるから多様に派生し人が集まる
C, C++, Objective-Cが合流しないのも同様
それを我田引水と評することに何の意味もない
0312デフォルトの名無しさん
垢版 |
2019/02/17(日) 15:53:56.04ID:tF7RiGiR
scalaでAndroidのプラグインとかあった気がする
我田引水ってなんか意味わからんな
0314デフォルトの名無しさん
垢版 |
2019/02/18(月) 02:04:27.28ID:XPBhJDxI
我田引水ってのは共用物について不正に占有したり自らの便宜を図ったりするような場合を言う
自己アピールや競争を含めた利己的な行動すべてを我田引水と揶揄するのは農耕民族的な発想が過ぎる
そういうのは道徳というより村八分や出る杭が打たれるのを恐れる面が強くイノベーションの足枷
0316デフォルトの名無しさん
垢版 |
2019/02/18(月) 13:20:37.82ID:cZFby2gr
道徳説教スレ
0317デフォルトの名無しさん
垢版 |
2019/02/18(月) 13:34:09.52ID:trvxFZJG
我田引水スレ
0318デフォルトの名無しさん
垢版 |
2019/02/18(月) 19:19:37.69ID:I6FKQlBO
後ろ盾がjetbrainsっていうのはどうなんやろ。
大手と比べてどんなメリットデメリットあると思う?
0322デフォルトの名無しさん
垢版 |
2019/02/18(月) 21:57:58.91ID:EXht3ErA
>>318
大手と比べるとメリットはない。後ろ盾のない言語よりはいい。
IDEの開発会社という意味では、言語の普及がIDEの売上に直結する可能性があるので
Oracleみたいに独立不採算だからマネタイズに走るという思考にはなりにくいが、
絶対的なものではない。
0323デフォルトの名無しさん
垢版 |
2019/02/18(月) 22:33:30.93ID:nEhvYQ88
IDEの開発会社であるが故のリスクもあるけどね
VSCodeのような強力な他の開発ツールがKotlinサポートにおいてIntelliJを超えてしまってユーザーが流れた場合、
JetBrainsにとってKotlinの開発を続けることにもはや意味がなくなってしまう
0326デフォルトの名無しさん
垢版 |
2019/02/19(火) 08:14:46.86ID:cAOiK8uf
後ろ盾の強さでいったらGoだべ
あれだけの巨大企業がついてる上に、開発も独裁せずに異常なまでにオープンであることを重視してるし
0327デフォルトの名無しさん
垢版 |
2019/02/19(火) 09:12:17.39ID:D8b3v+Fo
>>326
最強のSEO力でそう見せてるだけだぞ
それでもDartに対するヘイトは抑えきれなかったようだが
0328デフォルトの名無しさん
垢版 |
2019/02/19(火) 09:33:24.18ID:cAOiK8uf
>>327
直接Go開発周りのディスカッションを見てきての感想だから、SEOも何も関係ねーよ
英語が読めるなら自分の目で確かめることをお勧めする
あれはある意味理想的なOSS開発の形かもしれない
0333デフォルトの名無しさん
垢版 |
2019/02/20(水) 15:54:05.41ID:agArr1lp
ダー子
0336デフォルトの名無しさん
垢版 |
2019/02/20(水) 19:05:59.81ID:v7iPz90J
夢は見るもの
目標は叶えるもの
0340デフォルトの名無しさん
垢版 |
2019/02/23(土) 12:08:36.03ID:9pS68leH
Котлин
0341デフォルトの名無しさん
垢版 |
2019/02/24(日) 12:59:23.23ID:pmK9w2Lp
ランキング画面を作っていてRecyclerViewの項目のソートをしたいんですが、
Cellectionをお気に入り数の降順でソートした上で、
タイトルとサブタイトルの昇順にソートするにはどうしたらいいですか
以下でお気に入り数の降順でソートするところまではできたんですが。
RankingDatas.sortedByDescending { it.bookMarkCount }
0343デフォルトの名無しさん
垢版 |
2019/02/24(日) 17:28:12.24ID:pmK9w2Lp
APIレスポンスはそうして返してるんですが、
ローカルでお気に入りオンオフしてランキング順位が変わった場合に
再度APIを叩いてデータを取り直すのも微妙なので
その場合はローカルでソートして
順番を入れ替えたいという感じです
0344デフォルトの名無しさん
垢版 |
2019/02/24(日) 18:25:01.14ID:nlMNXQkf
ドキュメントにこう書いてあるからascendingとdescendingを順次呼び出せばいいんじゃない?
The sort is stable. It means that equal elements preserve their order relative to each other after sorting.
呼び出す順序はソート優先順位の逆順で
0345デフォルトの名無しさん
垢版 |
2019/02/24(日) 20:05:27.33ID:pmK9w2Lp
rankingDatas.sortedByDescending { it.bookMarkCount }.sortedBy { it.title }.sortedBy { it.subTitle }

やってみましたが、途中の結果は捨てられて単に subTitle の降順になるようです
0352デフォルトの名無しさん
垢版 |
2019/02/26(火) 06:27:00.41ID:oQJIDyJZ
久しぶりに触ったらcoroutineがだいぶ変わってるらしくて以前からとりあえず動くけどよく分かってない状態だったのにもう全然分からないよ……(´・ω・`)
0355デフォルトの名無しさん
垢版 |
2019/02/26(火) 09:55:03.32ID:E0EMtjG2
え?子ルーチンそんなに変わったの?
0357デフォルトの名無しさん
垢版 |
2019/02/26(火) 12:06:54.02ID:5MxkS3P7
>>351
のリンク先で、数値なら、- で降順にできるのか?

list.sortedWith(compareBy({ -it.age }, { it.name }, { it.address }))

Ruby なら、
arr2 = arr.sort_by { |a| [ -a[:score], a[:room] ] }
0358デフォルトの名無しさん
垢版 |
2019/02/26(火) 18:17:15.84ID:k06atLuF
>>357
できる。
0359デフォルトの名無しさん
垢版 |
2019/02/28(木) 03:26:51.88ID:oRFlldUh
ま、しかし、複数項目で昇順降順が混在する場合は自分で Comparator 作っちゃった方が楽かもね。
0360デフォルトの名無しさん
垢版 |
2019/02/28(木) 07:06:25.14ID:Lh1ejLNL
いやいや rankingDatas.sortedBy { it.subTitle }.sortedBy { it.title }.sortedByDescending { it.bookMarkCount } でいいじゃん
0363デフォルトの名無しさん
垢版 |
2019/02/28(木) 10:37:24.91ID:o8LdAn98
>>362
10万件ソートするなら使えないし、1000件しかソートしないなら問題ない
ランキングならたいした件数ないんじゃない
0364デフォルトの名無しさん
垢版 |
2019/02/28(木) 13:05:23.62ID:oAFMMcaR
>>360
それって2番目の並べ替えで1番目の並べ替えの順序が変わらないことは保証されてるの?
0366デフォルトの名無しさん
垢版 |
2019/02/28(木) 15:53:56.89ID:sPMvbV7g
mutableLivedataを外部に公開したら良くないってことで
別途livedataを作ってそいつに参照を持たせて
外部にはlivedataだけ公開するっていうのを
全部のmutableLivedataに対して行うの面倒臭いんですが
なにかいい方法ないですか
0367デフォルトの名無しさん
垢版 |
2019/02/28(木) 19:05:52.26ID:TwQuwGRl
よく知らないけどmutableLivedataをコンストラクタで貰って
それを元にlivedataを作って両方保持するクラスでも作って包めばいいんじゃないの
0368デフォルトの名無しさん
垢版 |
2019/03/01(金) 01:02:08.44ID:8x0yRf06
それで何か解決するんですかね
結局view側からmutableLivedataに
アクセスできるんじゃないですかね
0369デフォルトの名無しさん
垢版 |
2019/03/01(金) 06:35:34.41ID:eJTnddJA
本当にやり方が思いつかないならもうちょっと経験値の高い先輩なりに相談してみよう
0371デフォルトの名無しさん
垢版 |
2019/03/01(金) 09:24:26.88ID:ajbNVKsu
動かしてないけどこんな感じ

import android.arch.lifecycle.*
import kotlin.reflect.KProperty

//保持用
fun <T> unmodifiableLiveData(d:LiveData<T>): LiveData<T> = Transformations.map(d){it}
class MutLiveWrap<T>(val lv:MutableLiveData<T>) {
val readonlyLv = unmodifiableLiveData(lv)
operator fun getValue(thisRef: Any?, property: KProperty<*>) = readonlyLv
}
val <T> MutableLiveData<T>.wrap get() = MutLiveWrap<T>(this)


//使用
class Test {
private val aWr = MutableLiveData<Int>().wrap
val a by aWr

fun f(){
val mutLv: MutableLiveData<Int> = this.aWr.lv
val roLv : LiveData<Int> = this.a
}
}
0372デフォルトの名無しさん
垢版 |
2019/03/01(金) 11:13:31.72ID:PhmT31GH
>>370
分かりません。
0374デフォルトの名無しさん
垢版 |
2019/03/01(金) 12:41:01.41ID:yZJ4Zkhu
荒らしに返事するな!

そいつは前からいる、荒らしだろ。
相手をすると、この板に居つくだけ!
0375デフォルトの名無しさん
垢版 |
2019/03/01(金) 12:57:49.73ID:PhmT31GH
ま、しかし、このスレの場合は日頃は過疎ってるのでたまに荒しが来てくれた方がスレが活性化して落ちる心配がなくなるなw
0376デフォルトの名無しさん
垢版 |
2019/03/01(金) 16:06:36.33ID:XD1TRf4c
developer.android.comの最近のページはコードサンプルがKotlinとJava両方載ってるんだね
タブで切り替えるんだけど最初に表示されてるのはKotlin
0377デフォルトの名無しさん
垢版 |
2019/03/01(金) 16:54:26.44ID:ae30enpy
俺も動かしてないけどつくってみた

import androidx.annotation.MainThread
import androidx.lifecycle.LifecycleOwner
import androidx.lifecycle.LiveData
import androidx.lifecycle.MutableLiveData
import androidx.lifecycle.Observer

private class ReadOnlyLiveData<T>(private val liveData: LiveData<T>) : LiveData<T>() {
override fun setValue(value: T) { TODO("この関数を呼び出したとき、リードオンリーだから使えないよって教える。") }
override fun postValue(value: T) { TODO("この関数を呼び出したとき、リードオンリーだから使えないよって教える。") }
@MainThread override fun observe(owner: LifecycleOwner, observer: Observer<in T>) { liveData.observe(owner, observer) }

@MainThread override fun observeForever(observer: Observer<in T>) { liveData.observeForever(observer) }

@MainThread override fun removeObserver(observer: Observer<in T>) { liveData.removeObserver(observer) }

@MainThread override fun removeObservers(owner: LifecycleOwner) { liveData.removeObservers(owner) }

override fun getValue(): T? = liveData.value

@SuppressWarnings("WeakerAccess") override fun hasObservers(): Boolean = liveData.hasObservers()

@SuppressWarnings("WeakerAccess") override fun hasActiveObservers(): Boolean = liveData.hasActiveObservers()
}

fun <T> LiveData<T>.readOnly(): LiveData<T> {
if (this is ReadOnlyLiveData<T>) return this // もうすでにリードオンリー
return ReadOnlyLiveData(this)
}
0378デフォルトの名無しさん
垢版 |
2019/03/02(土) 06:14:14.54ID:qFBH5IQH
>>357
降順と昇順が混在する場合は compareBy または compareByDescending で Comparator 作って
それに対して thenBy または thenByDescending で追加させて行く方が楽だし速いと思う。
0379デフォルトの名無しさん
垢版 |
2019/03/04(月) 16:04:14.52ID:/4qbaGVQ
AnkoでBottom Sheetって使えますか?
0381デフォルトの名無しさん
垢版 |
2019/03/08(金) 10:46:41.80ID:pv8HlopZ
君が面白くなりなさい。
0385デフォルトの名無しさん
垢版 |
2019/03/10(日) 13:42:04.30ID:56gRJqyl
>>384
SequenceはIterableとほぼ同じ
違いは
 Sequence: 遅延評価する (なのでジェネレーターも含む)
 Iterable:  基本的には遅延評価でない (通常、実体はコレクション)

拡張関数も別れていて、例えば
 Sequenceのmap は遅延評価するSequenceを返す
 Iterableのmap はその場で全要素を処理してListを返す
0388デフォルトの名無しさん
垢版 |
2019/03/11(月) 17:24:32.47ID:2ppgAkG/
げ、知らなかった。
ずっとIterableがStreamの代わりだとばかり。
PythonのSequenceと混同してた。
ならば、Iterableをあそこまでゴージャスにする必要があったのか?
0390デフォルトの名無しさん
垢版 |
2019/03/11(月) 18:35:48.60ID:oxE6wZ/Z
>>388
典型的なコレクション操作では遅延評価せずその場で全処理する方が早いため

意味付けが違うだけで、SequenceとIterableは同じ拡張関数を持ってるくらいの認識でOK

分かりやすさのため、あえて使い分けを用意しなかった
Javaの割り切り方もありだとは思うけどね
0391デフォルトの名無しさん
垢版 |
2019/03/11(月) 21:05:48.78ID:MDT71nit
SequenceはJava8のStreamと類似で、KotlinであえてStreamを使うべき機会はほとんどないからSequenceを使っておけば良いってことかな
■ このスレッドは過去ログ倉庫に格納されています

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