0

伙计们。

我设计了一个货币兑换应用程序,我在应用程序启动时获得所有汇率并创建自己的 SQLite DB,然后轻松将它们拉入转换器界面。我已经设计了要在带有 textwatcher 的 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

3

从您的描述中我可以想象的是,您很可能有 2 个 EditText,其中用户只输入第一个,然后您将同步转换后的值,这是真的吗?如果是,我是否建议您不要在每次更改文本后立即执行该操作?

您可能只想Calculate()在用户完成输入后才做,也许一秒钟的计算延迟是可以接受的?

// Declare these as class variable
private Handler handler = new Handler();
private Runnable calculateRunnable = new Runnable() {
    public void run() {
        Calculate();
    }
}

至于你的 TextWatcher,改变这个

public void afterTextChanged(final Editable s) {
    handler.removeCallbacks(calculateRunnable);
    handler.postDelayed(calculateRunnable, 1000);
}
于 2013-08-04T02:57:42.777 回答