質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

Q&A

解決済

1回答

10585閲覧

定期実行処理をKotlinで行いたい

hodoru3sei

総合スコア284

Android

Androidは、Google社が開発したスマートフォンやタブレットなど携帯端末向けのプラットフォームです。 カーネル・ミドルウェア・ユーザーインターフェイス・ウェブブラウザ・電話帳などのアプリケーションやソフトウェアをひとつにまとめて構成。 カーネル・ライブラリ・ランタイムはほとんどがC言語/C++、アプリケーションなどはJavaSEのサブセットとAndroid環境で書かれています。

Android Studio

Android Studioは、 Google社によって開発された、 Androidのネイティブアプリケーション開発に特化した統合開発ツールです。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

0グッド

0クリップ

投稿2019/05/27 05:57

最終目標としてはボタンが押されている時に定期実行処理を繰り返してUIの描画を変更することです。
Andriodで定期実行処理を行う方法を調べてこちらの記事にたどり着きました。

Kotlinで書いてみたもの

記事はJavaで書かれていたので、こちらの記事とAndroid Studioの補完機能を使いながらKotlinに直してみました。
以下のコードで1秒ごとにcountがLogcatに出力されると思ったのですが、なぜか出力されませんでした。

Kotlin

1import android.support.v7.app.AppCompatActivity 2import android.os.Bundle 3import android.os.Handler 4import android.util.Log 5 6class MainActivity : AppCompatActivity(), Runnable { 7 8 override fun onCreate(savedInstanceState: Bundle?) { 9 super.onCreate(savedInstanceState) 10 setContentView(R.layout.activity_main) 11 12 var handler: Handler = Handler() 13 var r: Runnable = Runnable { 14 var count = 0 15 @Override fun run(){ 16 count++ 17 Log.d("count", count.toString()) 18 handler.postDelayed( this, 1000); 19 } 20 } 21 handler.post(r) 22 } 23 override fun run() { 24 TODO("not implemented") //To change body of created functions use File | Settings | File Templates. 25 } 26} 27

Andriod自体まだまだ分からないことだらけなので見当違いな質問をしていたらすみません。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

文法的にも問題があるのですが、思ったように動かない最大要因はpostDelayed()の第1引数が何を指しているのかという点です。

それを解決する記述としては、次のような2つのパターンがあると思います。(import文は省きます)

1 MainActivityにRunnableインターフェースを実装するパターン

kotlin

1class MainActivity : AppCompatActivity(), Runnable { 2 3 private val handler = Handler() 4 private var count = 0 5 6 override fun onCreate(savedInstanceState: Bundle?) { 7 super.onCreate(savedInstanceState) 8 setContentView(R.layout.activity_main) 9 handler.post(this) 10 } 11 12 override fun run() { 13 count++ 14 Log.d("count", count.toString()) 15 handler.postDelayed(this, 1000) 16 } 17}

2 匿名クラスを作成するパターン

kotlin

1class MainActivity : AppCompatActivity() { // , Runnableは記述しない 2 3 private val handler = Handler() 4 private var r: Runnable? = null 5 6 override fun onCreate(savedInstanceState: Bundle?) { 7 super.onCreate(savedInstanceState) 8 setContentView(R.layout.activity_main) 9 10 var count = 0 11 r = Runnable { 12 count++ 13 Log.d("count", count.toString()) 14 handler.postDelayed(r, 1000) 15 } 16 handler.post(r) 17 } 18}

Runnableを匿名クラスとして実装する場合、下記のようなラムダ式で記述すると文法エラーになります。このthisが指すのは匿名クラスではなく、その外側のオブジェクト(この場合はMainActivity)になります。postDelayed()の第1引数が求めるのはMainActivityではありませんから、エラーになってしまいます。

kotlin

1 val r = Runnable { 2 count++ 3 Log.d("count", count.toString()) 4 handler.postDelayed(this, 1000) 5 }

投稿2019/05/27 08:39

編集2019/05/27 09:14
keicha_hrs

総合スコア6766

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hodoru3sei

2019/05/27 08:56

ありがとうございます。匿名クラスというものを知らず勉強不足でした。 Runnableを実装するコードを試してみたところ問題なく動作しましたありがとうございます! 匿名クラスについても勉強してみようと思います
keicha_hrs

2019/05/27 09:01

いっぺんにいろいろ覚えようとすると混乱するので上記では避けていますが、私の回答で示したコードだと「カウントアップを止める処理」が存在しないため、実はプログラムとしては欠陥があります。postDelayed()でペンディングした処理を取り消すには、removeCallbacks()という処理を呼び出すことになります。それをどこで行うべきかということもどこかの段階で検討してみてください。
keicha_hrs

2019/05/27 09:16

2番目の例にちょっとまずい点(動かないわけではないが)があったので、ベストアンサー後で申し訳ありませんがコードを修正させていただきました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問