0

皆さん。

アプリケーションの開始時に一度すべての為替レートを取得し、独自の SQLite DB を作成して、それらをコンバータ インターフェイスに簡単に取り込む通貨交換アプリケーションを設計しました。テキストウォッチャーを使用して Edittext onTextChanged リスナーで変更を行うように設計しましたが、すべて完全に機能します。また、お気に入りの為替レートの同じアクティビティにリストビューがあり、編集テキストが変更されるたびに計算する必要があります。私の主な問題は、アプリケーションのパフォーマンスが低下し、フリーズの問題が発生することです。計算を処理するために Asynctask を実装しようとしましたが、役に立たず、まだパフォーマンスの問題が発生しています。参考までに私のコードを以下に示します。ご意見をお聞かせください !!

テキストウォッチャー :

valval.addTextChangedListener(new TextWatcher() {

        public void onTextChanged(CharSequence s, int start, int before,
                int count) {



        }

        public void beforeTextChanged(CharSequence s, int start, int count,
                int after) {

        }

        public void afterTextChanged(final Editable s)

        {

            Calculate();

        }
    });

計算:

private void Calculate()

{

    curs = mDb.query(MyDbHelper.TABLE_NAME, columns, MyDbHelper.COL_Common
            + "=" + "?", new String[] { From[xxxto] + From[xxxfrom] },
            null, null, null);
    cursD = mDb.query(MyDbHelper.TABLE_NAME, columns, MyDbHelper.COL_Common
            + "=" + "?", new String[] { From[xxxfrom] + From[xxxto] },
            null, null, null);

    curs.moveToFirst();

    cursD.moveToFirst();

    double selection = curs.getDouble(curs
            .getColumnIndex(MyDbHelper.COL_Currone));

    double selection2 = cursD.getDouble(cursD
            .getColumnIndex(MyDbHelper.COL_Currone));

    Long myNum = Long.parseLong(valval.getText().toString().trim());

    double myNum3 = Double.parseDouble(new DecimalFormat("#.######").format(myNum * selection2));


    valval2.setText(String.valueOf(myNum3));



    Cursor B = mDb.query(MyDbHelper.TABLE_NAME, columns,
            MyDbHelper.COL_CurrFavor + " LIKE ? And "
                    + MyDbHelper.COL_Currsecond + " LIKE ?", new String[] {
                    "YES", "EUR" }, null, null, null);


    for (int s = 0; s < B.getCount() - 1; s++)

    {
        B.moveToPosition(s);

        String ZVZV = B.getString(0);

        int BSBS = B.getInt(9);


        Cursor curcur = mDb.query(MyDbHelper.TABLE_NAME, columns, MyDbHelper.COL_Common
                + "=" + "?", new String[] { From[xxxfrom] + From[BSBS-1] },
                null, null, null);

        curcur.moveToFirst();

        double calcal = curcur.getDouble(6);



        ContentValues args = new ContentValues();

        double formattedNumber = Double.parseDouble(new DecimalFormat("#.######").format(myNum * calcal));

        args.put(MyDbHelper.COL_Currsum,formattedNumber );

        mDb.update(MyDbHelper.TABLE_NAME, args, "_id =" + ZVZV, null);



    }

    cursm.requery();

}
4

1 に答える 1