作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对此很陌生,但我正在编写一个应用程序,但我不断收到此错误,导致应用程序在启动时崩溃。
java.lang.NullPointerException: Attempt to invoke virtual method 'void java.io.BufferedWriter.close()' on a null object reference
导致该问题的代码位于下面的类中,出现问题的行旁边会有一个 HERE 注释。
public class FileOptions extends Activity{
public void createFile(String title, String storeValue){
BufferedWriter bufferWriter = null;
try {
FileOutputStream fileOutputStream = openFileOutput(title, Context.MODE_PRIVATE);
bufferWriter = new BufferedWriter(new OutputStreamWriter(fileOutputStream));
String content = storeValue;
bufferWriter.write(content);
} catch (FileNotFoundException e) {
e.printStackTrace();
}
catch (IOException e) { //Cannot be removed
e.printStackTrace();
}
finally {
try {
/**HERE*/ bufferWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
//More unimportant stuff
}
这是我调用该方法的代码。
public class MainActivity extends ActionBarActivity {
Context context = this;
boolean debug = true;
FileOptions file = new FileOptions();
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Boolean isFirstRun = getSharedPreferences("PREFERENCE", MODE_PRIVATE)
.getBoolean("isfirstrun", true);
if(isFirstRun) {
file.createFile("userInfo", "");
getSharedPreferences("PREFERENCE", MODE_PRIVATE).edit()
.putBoolean("isfirstrun", false).commit();
}
if(file.readFile("userInfo") != "")
{
if(debug){alerter(file.readFile("userInfo"));alerter("true");}
switchToHome();
}else{
if(debug){alerter("false");}
}
}
}
这是堆栈跟踪。
08-27 22:44:35.830 13089-13089/? I/libpersona﹕ KNOX_SDCARD checking this for 10247
08-27 22:44:35.830 13089-13089/? I/libpersona﹕ KNOX_SDCARD not a persona
08-27 22:44:35.830 13089-13089/? E/Zygote﹕ MountEmulatedStorage()
08-27 22:44:35.830 13089-13089/? E/Zygote﹕ v2
08-27 22:44:35.830 13089-13089/? I/SELinux﹕ Function: selinux_compare_spd_ram, SPD-policy is existed. and_ver=SEPF_SM-N910V_5.0.1 ver=27
08-27 22:44:35.830 13089-13089/? I/SELinux﹕ Function: selinux_compare_spd_ram , priority [1] , priority version is VE=SEPF_SM-N910V_5.0.1_0027
08-27 22:44:35.830 13089-13089/? E/SELinux﹕ [DEBUG] get_category: variable seinfo: default sensitivity: NULL, cateogry: NULL
08-27 22:44:35.830 13089-13089/? I/art﹕ Late-enabling -Xcheck:jni
08-27 22:44:35.870 13089-13089/? D/TimaKeyStoreProvider﹕ TimaSignature is unavailable
08-27 22:44:35.870 13089-13089/? D/ActivityThread﹕ Added TimaKeyStore provider
08-27 22:44:35.920 13089-13089/? D/ResourcesManager﹕ creating new AssetManager
and set to /data/app/preventioninnovations.preventapp-2/base.apk
08-27 22:44:36.050 13089-13089/? D/AndroidRuntime﹕ Shutting down VM
08-27 22:44:36.050 13089-13089/? E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: preventioninnovations.preventapp, PID: 13089
java.lang.RuntimeException: Unable to start activity ComponentInfo{preventioninnovations.preventapp/preventioninnovations.preventapp.MainActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'void java.io.BufferedWriter.close()' on a null object reference
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2712)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2777)
at android.app.ActivityThread.access$900(ActivityThread.java:179)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1462)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5972)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'void java.io.BufferedWriter.close()' on a null object reference
at preventioninnovations.preventapp.FileOptions.createFile(FileOptions.java:37)
at preventioninnovations.preventapp.MainActivity.onCreate(MainActivity.java:38)
at android.app.Activity.performCreate(Activity.java:6289)
at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2665)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2777)
at android.app.ActivityThread.access$900(ActivityThread.java:179)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1462)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5972)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
感谢您的帮助。
最佳答案
当您的 openFileOutput()
方法抛出异常时,就会发生这种情况。
由于抛出异常,bufferWriter
未初始化为有效对象。
并且该异常导致执行跳过 try block 的其余部分,转到 catch block ,然后最终 block 。
因此,当到达finally block 时,bufferWriter
为null
。
finally {
try {
if (bufferWriter != null)
bufferWriter.close();
} catch (IOException e) {
e.printStackTrace();
}
}
要修复此问题,请在 bufferWriter
中调用 close 之前检查 null
。
或者更好地使用尝试资源。
try(BufferedWriter = new BufferedWriter(
new OutputStreamWriter(
openFileOutput(title, Context.MODE_PRIVATE)))) {}
关于java - 为什么我会收到 NullPointerException? bufferWriter.close(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32262639/
我是一名优秀的程序员,十分优秀!