今天测试人员给我提了一个程序崩溃的问题,我看了一下代码,执行了一遍,确定了崩溃的原因是有一个TextView变成了null。如代码所示
/**
* 从服务器中请求数据
*/
public void reqData() {
GetUserTopReq getUserTopReq = new GetUserTopReq(userId, userId);
new AsyncGsonRequest<GetUserTopRes>(Constants.GETUSERDETAIL,
getUserTopReq, context) {
@Override
protected void onPostExecute(GetUserTopRes res) {
if (res != null && res.recode == 0) {
reqUnreadMsg();
initDatas(res.iwUserInfo);
String json = new Gson().toJson(res);
SharedPreferencesManager.saveWoFragmentData(json);
}
}
@Override
protected void onPostError(VolleyError e) {
LogUtil.e(TAG, "获得用户信息失败", e);
// 如果访问服务器失败,使用SharedPreferences里的数据
User user = SharedPreferencesManager.getLoginInfo();
if (!TextUtils.isEmpty(user.getUsername())) {
nickName_tv.setText(user.getUsername());
}
}
}
}.execute();
确定了原因,那改起来就很容易了,我的方法是一进入这个fragment,就让view取得保存在SharedPreferences里的数据,而不是像上面的代码那样当请求出错时才给view设置值。
虽然解决了bug但是让我纳闷的是好好的nickName_tv(它是一个TextView)怎么会变成NULL了呢,我明明是先
nickName_tv = (TextView) view.findViewById(R.id.nickName_tv);
再请求的网络啊。
当然AsyncGsonRequest是项目里的其他人写的一个请求网络的类,很有可能是在这个类里,当网络请求不成功时,将所有的View都变成null了,需要重新再find一遍。然而这只会在这个fragment里,而在其它的里并不会有这个错误。
让我想不明白的是nickName_tv 为什么会变成null呢?希望有大神可以解答我的疑惑。