2013-04-17 13 views
9

私はこの質問に対する回答としてStackOverflowとWebを検索しましたが、回答が見つかりませんでした。私がGingerbreadでアプリケーションを実行すると、正常に動作します。しかし、私が4.2.2でそれを実行すると、私はこのエラーを受け取ります:java.lang.IllegalStateException Cannot perform this operation because the connection pool has been closed 私は2つの断片を含むSherlockFragmentActivityを持っています。Androidのエラー:接続プールが閉じられているため、この操作を実行できません

断片1:

public final class TodoFragment extends SherlockListFragment { 
NotesDbAdapter db; 

private static final int DELETE_ID = Menu.FIRST + 1; 

public static TodoFragment newInstance(String s) { 
    TodoFragment fragment = new TodoFragment(); 

    return fragment; 
} 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    db = new NotesDbAdapter(getActivity()); 

} 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
     Bundle savedInstanceState) { 
    if (container == null) { 
     return null; 
    } 

    return ll; 

} 

フラグメント2:

public final class NotesFragment extends SherlockListFragment { 
NotesDbAdapter db; 
private static final int ACTIVITY_EDIT = 1; 

private static final int DELETE_ID = Menu.FIRST + 1; 

public static NotesFragment newInstance(String content) { 
    NotesFragment fragment = new NotesFragment(); 

    return fragment; 
} 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    db = new NotesDbAdapter(getActivity()); 

    db.open(); 
    if (db.fetchAllNotes().getCount() == 0) { 
     doWelcomeMessage(); 
    } 
    db.close(); 

} 

private void doWelcomeMessage() { 
    // Show welcome dialog 
    startActivity(new Intent(getActivity(), NotesWelcome.class)); 

} 

@Override 
public View onCreateView(LayoutInflater inflater, ViewGroup container, 
     Bundle savedInstanceState) { 
    if (container == null) { 
     return null; 
    } 

    db = new NotesDbAdapter(getActivity()); 

    db.open(); 
    if (db.fetchAllNotes().getCount() == 0) { 
     doWelcomeMessage(); 
    } 
    db.close(); 


    return ll; 

} 

SherlockFragmentActivity:

public class NotesFragmentActivity extends SherlockFragmentActivity { 

ViewPager mViewPager; 
TabsAdapter mTabsAdapter; 
TextView tabCenter; 
TextView tabText; 

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 

    mViewPager = new ViewPager(this); 
    mViewPager.setId(R.id.pager); 

    setContentView(mViewPager); 
    ActionBar bar = getSupportActionBar(); 
    bar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS); 

    mTabsAdapter = new TabsAdapter(this, mViewPager); 

    mTabsAdapter.addTab(bar.newTab().setText("Notes"), NotesFragment.class, 
      null); 
    mTabsAdapter.addTab(bar.newTab().setText("Todo List"), 
      TodoFragment.class, null); 

} 

public static class TabsAdapter extends FragmentPagerAdapter implements 
     ActionBar.TabListener, ViewPager.OnPageChangeListener { 
    private final Context mContext; 
    private final ActionBar mActionBar; 
    private final ViewPager mViewPager; 
    private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>(); 

    static final class TabInfo { 
     private final Class<?> clss; 
     private final Bundle args; 

     TabInfo(Class<?> _class, Bundle _args) { 
      clss = _class; 
      args = _args; 
     } 
    } 

    public TabsAdapter(SherlockFragmentActivity activity, ViewPager pager) { 
     super(activity.getSupportFragmentManager()); 
     mContext = activity; 
     mActionBar = activity.getSupportActionBar(); 
     mViewPager = pager; 
     mViewPager.setAdapter(this); 
     mViewPager.setOnPageChangeListener(this); 
    } 

    public void addTab(ActionBar.Tab tab, Class<?> clss, Bundle args) { 
     TabInfo info = new TabInfo(clss, args); 
     tab.setTag(info); 
     tab.setTabListener(this); 
     mTabs.add(info); 
     mActionBar.addTab(tab); 
     notifyDataSetChanged(); 
    } 

    @Override 
    public int getCount() { 
     return mTabs.size(); 
    } 

    @Override 
    public Fragment getItem(int position) { 
     TabInfo info = mTabs.get(position); 
     return Fragment.instantiate(mContext, info.clss.getName(), 
       info.args); 
    } 

    public void onPageScrolled(int position, float positionOffset, 
      int positionOffsetPixels) { 
    } 

    public void onPageSelected(int position) { 
     mActionBar.setSelectedNavigationItem(position); 
    } 

    public void onPageScrollStateChanged(int state) { 
    } 

    public void onTabSelected(Tab tab, FragmentTransaction ft) { 
     Object tag = tab.getTag(); 
     for (int i = 0; i < mTabs.size(); i++) { 
      if (mTabs.get(i) == tag) { 
       mViewPager.setCurrentItem(i); 
      } 
     } 
    } 

    public void onTabUnselected(Tab tab, FragmentTransaction ft) { 
    } 

    public void onTabReselected(Tab tab, FragmentTransaction ft) { 
    } 
} 
} 

私は、HOURS(なしジョーク)のために、この上で立ち往生してきました本当に助けに感謝します。 ありがとうございました

+0

全体のスタックトレースをポストします。このエラーは、アプリケーションがどこか別の場所でdbを閉じ、db接続が終了した後に別のdb接続が発生したことを意味します。 – kinghomer

+0

閉じる操作を削除する必要があります。 close()を削除してみます。このエラーはdbを閉じることによるものです。 – Nepster

答えて

8

Android 4.1の後にSQLiteConnectionPoolingが追加されました。以前のバージョンでは、接続プールで閉じられた接続でクエリやその他の操作が行われた場合、カーソルオブジェクトはデータベースを再オープンしようとしますが、例外がスローされます。 NotesDBAdapterは恐らく4.2.2との互換性を失っている可能性があります。

+1

それでは、どうやって解決するのですか?私はこのエラーを私のアプリで時々得ています。コードの一部でcursor.moveToFirst()を呼び出すと、エラーが発生します。接続プールが閉じられているため、この操作を実行できません。 –

+0

どのように解決しましたか?@FerranNegre –

+0

私はこのトピックを書いています。http://stackoverflow.com/questions/23293572/android-cannot-perform-this-operation-because-the-connection-pool-has-been-clos/23293930 ?noredirect = 1#23293930その答えと私のコメントを読んでください:) –

2

複数のスレッドが同じSQLiteOpenHelperにアクセスし、同時に接続を開いたり閉じたりしたため、同じ問題が発生しました。

userCount属性をヘルパーに追加して解決しました。現在、ヘルパーは、userCountがゼロである場合、すなわちデータベースを現在使用している他のスレッドがない場合にのみ、接続を閉じる。

+0

投稿コードをください!!!! –

関連する問題