2011-07-04 5 views
3

いつAssetManagerのインスタンスを作成して閉じますか。将来の機能によってAssetManagerはまだ必要ですか?

私のプログラムにはバグがありました。 DDMSは、私が気づい

public class myAppActivity extends Activity { 

    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.main); 

     usesAnInstanceOfAssetManager(); 
     addsTextToASpinner(); 
    } 


    private void usesAnInstanceOfAssetManager() { 
     AssetManager assetManager = getAssets(); 
     ///blah blah blah..... 
     assetManager.close(); 
     return; 
    } 

    public void addsTextToASpinner(){ 
     // code to add text fields to a spinner 
     // executing this function caused the error shown above 
     return; 
    } 
} 

....それは本当に長いですが、私のプログラムはこれと同様に構成されているので、私はすべての私のコードを掲載しません

07-04 18:44:59.241: DEBUG/KeyguardViewMediator(65): pokeWakelock(5000) 
07-04 18:44:59.541: DEBUG/KeyguardViewMediator(65): pokeWakelock(5000) 
07-04 18:45:00.101: INFO/ARMAssembler(65): generated scanline__00000077:03545404_00000004_00000000 [ 47 ipp] (67 ins) at [0x33b540:0x33b64c] in 9815520 ns 
07-04 18:45:00.281: INFO/ARMAssembler(65): generated scanline__00000177:03515104_00001001_00000000 [ 91 ipp] (114 ins) at [0x33c088:0x33c250] in 2206721 ns 
07-04 18:45:00.561: WARN/ActivityManager(65): finishReceiver called but no pending broadcasts 
07-04 18:45:10.843: DEBUG/AndroidRuntime(277): Shutting down VM 
07-04 18:45:10.843: WARN/dalvikvm(277): threadid=1: thread exiting with uncaught exception (group=0x4001d800) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277): FATAL EXCEPTION: main 
07-04 18:45:11.191: ERROR/AndroidRuntime(277): android.content.res.Resources$NotFoundException: File res/layout/simple_spinner_item.xml from xml type layout resource ID #0x1090008 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.content.res.Resources.loadXmlResourceParser(Resources.java:1916) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.content.res.Resources.loadXmlResourceParser(Resources.java:1871) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.content.res.Resources.getLayout(Resources.java:731) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.LayoutInflater.inflate(LayoutInflater.java:318) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.ArrayAdapter.createViewFromResource(ArrayAdapter.java:332) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.ArrayAdapter.getView(ArrayAdapter.java:323) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.AbsSpinner.onMeasure(AbsSpinner.java:192) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.View.measure(View.java:8171) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.TableRow.getColumnsWidths(TableRow.java:308) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.TableLayout.findLargestCells(TableLayout.java:497) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.TableLayout.measureVertical(TableLayout.java:462) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.TableLayout.onMeasure(TableLayout.java:428) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.View.measure(View.java:8171) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1012) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.LinearLayout.measureVertical(LinearLayout.java:381) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.LinearLayout.onMeasure(LinearLayout.java:304) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.View.measure(View.java:8171) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:245) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.View.measure(View.java:8171) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.LinearLayout.measureVertical(LinearLayout.java:526) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.LinearLayout.onMeasure(LinearLayout.java:304) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.View.measure(View.java:8171) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:3132) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.widget.FrameLayout.onMeasure(FrameLayout.java:245) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.View.measure(View.java:8171) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.ViewRoot.performTraversals(ViewRoot.java:801) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.view.ViewRoot.handleMessage(ViewRoot.java:1727) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.os.Handler.dispatchMessage(Handler.java:99) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.os.Looper.loop(Looper.java:123) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.app.ActivityThread.main(ActivityThread.java:4627) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at java.lang.reflect.Method.invoke(Method.java:521) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at dalvik.system.NativeStart.main(Native Method) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277): Caused by: java.lang.RuntimeException: Assetmanager has been closed 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.content.res.AssetManager.openXmlBlockAsset(AssetManager.java:483) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  at android.content.res.Resources.loadXmlResourceParser(Resources.java:1898) 
07-04 18:45:11.191: ERROR/AndroidRuntime(277):  ... 36 more 

....言っていましたライン:

7月4日18:45:11.191:ERROR/AndroidRuntime(277):java.lang.RuntimeException:によって引き起こさAssetmanagerは

を閉じているので、問題は "という最初の関数であるように見えましたusesAnInstanceOfAs setManager "がアセットマネージャを閉じており、2番目の関数がassetManagerを必要としていました。私は関数 "usesAnInstanceOfAssetManager"のassetManager.close()行をコメントアウトし、私のアプリケーションはクラッシュしませんでした。ですから、私の質問は....

AssetManagerを使用するベストプラクティスは何ですか?プログラムごとに1回しか使用できませんか?私はそれのインスタンスを宣言し、私が完了したときにそれを閉じることは適切な行動コースでしたが、それはそのようには見えません。 AssetManagerは静的ですか?私はいつもそれが必要ですか?

答えて

0

AddTextToSpinner()というアクティビティの後にAssetManagerを閉じることができます。 他に必要な場合は、もう一度開いてください。

あなたがAssetManagerについての詳細情報が必要な場合は、このリンクを訪問する必要があります。 http://developer.android.com/reference/android/content/res/AssetManager.html

私は、次のように私AssetManagerがある使用方法:

私は私のparseXMLFile(コール)、私は開いてそこに 私のAssetManager、 XMLファイルを開き、オブジェクト内のデータを読み込んで保存します。 AssetManagerを閉じます。

このように私はAssetManagerを一度使用し、後で私のアプリケーションでは、オブジェクトを使って作業することができます。

これがあなたが探していた答えだと思います!

+0

「AssetManagerを開く」とはどういう意味ですか?それ自体はオープンな機能を持っていません – BeniBela

2

これまでのところ、AssetManagerはシステムによって作成されているので、AssertManagerを開いたり閉じたりする必要はありません。

アプリケーションで実行する必要があるのは、使用するinputStreamを開いたり閉じたりすることです。 私が間違っている場合は私を修正してください。

関連する問題