1

配列から配列インデックスを削除してから、新しい配列でlistViewをリロードしてから、Androidの既存のファイルに文字列を書き込みます。私は次のコードを使用しています:

 OnItemLongClickListener longClickListener = new OnItemLongClickListener(){

            @Override
            public boolean onItemLongClick(AdapterView<?> arg0, View arg1,
                    int position, long arg3) {
                itemPosition = position;

                AlertDialog.Builder alertDialogBuilder = new AlertDialog.Builder(context);
                alertDialogBuilder.setTitle("Warning");

                alertDialogBuilder
                .setMessage("Are you sure?")
                .setCancelable(false)
                .setPositiveButton("Yes",new DialogInterface.OnClickListener() {
                    public void onClick(DialogInterface dialog,int id) {
                        ArrayList<String> itemsList = new ArrayList<String>();
                        for(int i=0; i<items.length; i++){
                            itemsList.add(items[i]);
                        }

                        itemsList.remove(itemPosition);
                        items = new String[itemsList.size()];
                        for(int i=0; i<itemsList.size(); i++){
                            items[i] = itemsList.get(i);
                        }

                        adapter.notifyDataSetChanged();

                        String newData = "";

                        for(int i=0; i<items.length; i++){
                            newData = newData+items[i];
                            if(i < items.length-1){
                                newData = newData+"NEXTLINE";
                            }
                        }
                        // write string to existing file
                        try {
                            fos = openFileOutput(FILENAME, Context.MODE_PRIVATE);
                            fos.write(newData.getBytes());
                            fos.close();
                        } catch (FileNotFoundException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        } catch (IOException e) {
                            // TODO Auto-generated catch block
                            e.printStackTrace();
                        }


                    }
                  })
                .setNegativeButton("No",new DialogInterface.OnClickListener() {
                    public void onClick(DialogInterface dialog,int id) {
                        // if this button is clicked, just close
                        // the dialog box and do nothing
                        dialog.cancel();
                    }
                });

                AlertDialog alertDialog = alertDialogBuilder.create();
                alertDialog.show();

                return true;
            }

        };

アラートで[はい]をクリックすると、アプリが応答せず、しばらくすると電話がアプリを強制終了するように要求しますか?誰かがこのコードの何が問題なのか教えてもらえますか?前もって感謝します。

4

1 に答える 1

1

問題は、コードの抜粋をたどることにあります...リストのサイズが遅すぎて、3回ループしていて、その間にリストも更新されている可能性があります。

             ArrayList<String> itemsList = new ArrayList<String>();
                    for(int i=0; i<items.length; i++){
                        itemsList.add(items[i]);
                    }

                    itemsList.remove(itemPosition);
                    items = new String[itemsList.size()];
                    for(int i=0; i<itemsList.size(); i++){
                        items[i] = itemsList.get(i);
                    }

                    adapter.notifyDataSetChanged();

                    String newData = "";

                    for(int i=0; i<items.length; i++){
                        newData = newData+items[i];
                        if(i < items.length-1){
                            newData = newData+"NEXTLINE";
                        }

このクリックでコードとループをデバッグして削減してみてください...

于 2012-06-27T14:15:57.243 に答える