Androidでサーバーとお話したい。
外部サーバーとお話する機会があって色々調べたまとめ。
AsyncTask
お馴染みの奴。
遠い昔にメインスレッドでお話できなくなった事で長らく使われて来たイメージ。
AsyncTaskLoader
AsyncTaskよりもこっち使おうぜ!って流れっぽい。
UIスレッドと切り離せるので先にActivityとかが死んでも安心らしい。(画面の回転とかでも簡単に処理を引き継げたりする)
コールバック書いたり。複数処理をする場合とかLoaderの使い方がわかりにくかったりする。
なれるまでしんどい。
rxandroid + retrofit + okhttp
ナウなヤングにバカウケしてるっぽい組み合わせ。
RESTなAPIとやり取りするならこの組み合わせで良いんじゃないかなーって感じ。
AsyncTaskLoaderで書く前に知りたかった。お勉強不足ですね。
APIのinterface書いてEntityで受け取って感じがわかりやすいしjava感ある。
retrofitは1系の記事も多いけど2系と互換があんまり無いので注意が必要。
やる気が出たらコードを含めつつまとめておきたいね。
Androidのレイアウトをフォルダ分けしたかった
アプリ作ってて画面が増えてくるとレイアウトファイルも増えてくるのでどれがどれなのかわからなくなってくる。 単純にフォルダを切ってみたらエラーが出たのでどうするか考えてみた。
一番しっくり来たのは適当にフォルダ切ってgradleにパスを書いてあげる方法。 イケてるんだけどAndroidStudio使ってると良きに計らわれてLayout配下に各xmlがあるように見えて分けてる意味が無くなってしまう。。。
https://github.com/eskimoapps/ResourceNestingExample
sourceSets { main { res.srcDirs = [ 'src/main/res/layouts/layouts_category2', 'src/main/res/layouts', 'src/main/res' ] } }
妥協で考えたのは普通にファイル名のprefixに分類書いていく案。 階層は変わらんけどまぁ妥当な対応なのかなー。
layout/ main_activity.xml main_hogehoge.xml sub_activity.xml sub_hogehoge.xml
追記
最初の奴と似てるけど一番しっくり来たのでこれでしばらくやってみる予定。 AndroidStudioが予期に計らってしまうのは変わらないけどツリー表示をAndroidからProjectに変えておけばちゃんとわかるしまぁ良いでしょ。
laravelの環境用意しようとしたらエラー吐いた
pullしてcomposer updateしとけばええんやろ?って感じでやってたら
Fatal error: Class 'Illuminate\Foundation\Application' not found in /path/to/project/bootstrap/app.php on line 14
って怒られた…。 あれパスが通ってない?とか数瞬考えたけどそもそもcomposer installじゃんって事に気付いた。 他にも同じボケかました人いそうだなーって検索したらlaracastsとかstackoverflowにもスレッドあって安心したよね。
laravelで空白の代わりにnullを登録したい
追記: laravel5.4でConvertEmptyStringsToNullとか言う素敵ミドルウェアが出たので今後はそっちで。
larabelのEloquent使って以下のようにデータを登録しようとするとフォームにデータが入っていないカラムは空白で登録されてしまう。
<?php Hoge::create($request->all());
Hogeモデルの中で以下のようにミューテータを定義しておけばnullに変換して登録してくれる。
<?php public function setHogaAttribute($field) { $this->attributes['hoga'] = trim($field) !== '' ? $field : null; }
追記
Hogeモデル内の全カラムに対して適用する場合は以下のようにするとよさ気。
<?php public static function boot() { parent::boot(); static::saving(function ($model) { foreach ($model->attributes as $key => $value) { if ($value !== 0) { $model->{$key} = empty($value) ? null : $value; } } }); }
laravelでcsv出力とか大量データを取得する場合にどうすれば良いのか試行錯誤した。
たまにはブログでも始めてみよう。
結果を先に言うとpdoで実行してしまうのがよさそう。
以下自分の辿った流れ。
get()で取得する
- 簡単だけどgetした場合すべてメモリ上に展開されるので大量データの処理には向いていない。
<?php $results = List::get(); foreach($results as $row) { // 処理 }
chunk()で指定件数ずつ処理する
- 指定件数分取得してクロージャ内の処理を行ってくれて素敵。
- SQLで指定件数分取得 > 処理を繰り返すので大量のクエリを発行する可能性がある。
- SQLを複数回発行するのでソートしておかないと意図しない動作をする可能性がある。
<?php List::orderBy('id')->chunk(1000, function ($results) { foreach ($results as $row) { // 処理 } });
pdoのコネクション取ってフェッチしていく
- SQLが一回で済む。
- fetchしてる分しかメモリ上に展開しないはず。
<?php $query = List::query(); $statement = DB::Connection()->getPdo()->prepare($query->toSql()); $statement->execute($query->getBindings()); while ($row = $statement->fetch(PDO::FETCH_ASSOC)) { // 処理 }