- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在此 AddRestaurantActivity 上遇到此错误
这是我的 AddRestaurantActivity.java
文件。这是更新数据库并创建一个带有 goggle geo place 纬度和经度的新餐厅的 Activity 代码。在模拟器中,当我按“创建”按钮创建餐厅时,应用程序死掉了(不幸的是,餐厅查找器已停止)。并且在下面发现了logcat中的错误
package admin;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.apache.http.NameValuePair;
import org.apache.http.message.BasicNameValuePair;
import org.json.JSONException;
import org.json.JSONObject;
import android.app.Activity;
import android.app.AlertDialog;
import android.app.ProgressDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.location.Address;
import android.location.Geocoder;
import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import com.mad.restaurantfinderrm.R;
import com.mad.restaurantfinderrm.library.DatabaseHandler;
import com.mad.restaurantfinderrm.library.JSONParser;
import com.mad.restaurantfinderrm.library.UserFunctions;
public class AddRestaurantActivity extends Activity {
UserFunctions userFunctions;
// Progress Dialog
private ProgressDialog pDialog;
JSONParser jsonParser = new JSONParser();
EditText inputName;
EditText inputType;
EditText inputBio;
EditText inputAddressLine1;
EditText inputAddressLine2;
EditText inputAddressLine3;
EditText inputContactNum;
EditText inputEmail;
EditText inputMenuUrl;
// url to create new Restaurant
// private static String url_create_restaurant =
// "http://192.168.0.10/~robertmcnamara/RestaurantFinderAPI/createRestaurant.php";
private static String url_create_restaurant = "http://askme- jobs.com/api/createRestaurant.php";
// JSON Node names
private static final String TAG_SUCCESS = "success";
static Double lat;
static Double lng;
// DB
private SQLiteDatabase mDb;
private Cursor mCursor;
String user_id;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_add_restaurant);
userFunctions = new UserFunctions();
// getting user_id
DatabaseHandler mh = new DatabaseHandler(getApplicationContext());
mDb = mh.getWritableDatabase();
mCursor = mDb.query("login", null, null, null, null, null, null);
if (mCursor != null && mCursor.getCount() > 0) {
mCursor.moveToFirst();
user_id = mCursor.getString(mCursor.getColumnIndex("uid"));
}
// Edit Text
inputName = (EditText) findViewById(R.id.inputName);
inputType = (EditText) findViewById(R.id.inputType);
inputBio = (EditText) findViewById(R.id.inputBio);
inputAddressLine1 = (EditText) findViewById(R.id.inputAddress1);
inputAddressLine2 = (EditText) findViewById(R.id.inputAddress2);
inputAddressLine3 = (EditText) findViewById(R.id.inputAddress3);
inputContactNum = (EditText) findViewById(R.id.inputContactNum);
inputEmail = (EditText) findViewById(R.id.inputEmail);
inputMenuUrl = (EditText) findViewById(R.id.inputMenuUrl);
// Create button
Button btnCreateRestaurant = (Button) findViewById(R.id.btnCreateRestaurant);
// button click event
btnCreateRestaurant.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (inputName.getText().toString().trim().contentEquals("")
|| inputType.getText().toString().trim()
.contentEquals("")
|| inputBio.getText().toString().trim()
.contentEquals("")
|| inputAddressLine1.getText().toString().trim()
.contentEquals("")
|| inputAddressLine2.getText().toString().trim()
.contentEquals("")
|| inputContactNum.getText().toString().trim()
.contentEquals("")
|| inputEmail.getText().toString().trim()
.contentEquals("")
|| inputMenuUrl.getText().toString().trim()
.contentEquals("")) {
AlertDialog.Builder alertDialog = new AlertDialog.Builder(
AddRestaurantActivity.this);
// Setting Dialog Title
alertDialog.setTitle("Input validation");
// Setting Dialog Message
alertDialog
.setMessage("Please enter all details again,\nmaking sure they are correct");
// Setting Icon to Dialog
// alertDialog.setIcon(android.R.drawable.delete);
// Setting Positive "Yes" Button
alertDialog.setPositiveButton("OK",
new DialogInterface.OnClickListener() {
public void onClick(DialogInterface dialog,
int which) {
dialog.cancel();
}
});
// Showing Alert Message
alertDialog.show();
} else {
// creating new product in background thread
new CreateNewRestaurant().execute();
}
}
});
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu, menu);
return true;
}
/*
* Event Handling for Individual menu item selected Identify single menu
* item by it's id
*/
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.menu_logout:
// logout user
// TODO check Internet here?
userFunctions.logoutUser(getApplicationContext());
Intent login = new Intent(getApplicationContext(),
LoginActivity.class);
login.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(login);
overridePendingTransition(R.anim.fade_in, R.anim.fade_out);
// Closing dashboard screen
finish();
return true;
default:
return super.onOptionsItemSelected(item);
}
}
/**
* Background Async Task to Create new Restaurant
* */
class CreateNewRestaurant extends AsyncTask<String, String, String> {
/**
* Before starting background thread Show Progress Dialog
* */
@Override
protected void onPreExecute() {
super.onPreExecute();
pDialog = new ProgressDialog(AddRestaurantActivity.this);
pDialog.setMessage("Creating Restaurant..");
pDialog.setIndeterminate(false);
pDialog.setCancelable(true);
pDialog.show();
}
/**
* Creating Restaurant
* */
protected String doInBackground(String... args) {
String name = inputName.getText().toString();
String type = inputType.getText().toString();
String bio = inputBio.getText().toString();
String addressLine1 = inputAddressLine1.getText().toString();
String addressLine2 = inputAddressLine2.getText().toString();
String addressLine3 = inputAddressLine3.getText().toString();
String phoneNum = inputContactNum.getText().toString();
String email = inputEmail.getText().toString();
String menuUrl = inputMenuUrl.getText().toString();
// img
// String img = "";
String fullAddress = name + ", " + addressLine1 + ", "
+ addressLine2 + ", " + addressLine3;
Geocoder geoCoder = new Geocoder(getApplicationContext());
List<Address> addressList;
try {
addressList = geoCoder.getFromLocationName(fullAddress, 1);
Address address = addressList.get(0);
if (address.hasLatitude() && address.hasLongitude()) {
lat = address.getLatitude();
lng = address.getLongitude();
}
} catch (IOException e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
Log.v("LAT", lat.toString());
Log.v("LNG", lng.toString());
// Building Parameters
List<NameValuePair> params = new ArrayList<NameValuePair>();
params.add(new BasicNameValuePair("name", name));
params.add(new BasicNameValuePair("type", type));
params.add(new BasicNameValuePair("bio", bio));
params.add(new BasicNameValuePair("addressLine1", addressLine1));
params.add(new BasicNameValuePair("addressLine2", addressLine2));
params.add(new BasicNameValuePair("addressLine3", addressLine3));
params.add(new BasicNameValuePair("contactNumber", phoneNum));
params.add(new BasicNameValuePair("email", email));
params.add(new BasicNameValuePair("lat", lat.toString()));
params.add(new BasicNameValuePair("lng", lng.toString()));
params.add(new BasicNameValuePair("url", menuUrl));
params.add(new BasicNameValuePair("user_id", user_id));
// getting JSON Object
// Note that create product url accepts POST method
JSONObject json = jsonParser.makeHttpRequest(url_create_restaurant,
"POST", params);
// check for success tag
try {
int success = json.getInt(TAG_SUCCESS);
if (success == 1) {
// successfully created product
Intent i = new Intent(getApplicationContext(),
ViewRestaurantActivity.class);
i.putExtra("MESSAGE", "add");
i.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
startActivity(i);
overridePendingTransition(R.anim.slide_in_top,
R.anim.slide_out_bottom);
finish();
} else {
// failed to create product
}
} catch (JSONException e) {
e.printStackTrace();
}
return null;
}
/**
* After completing background task Dismiss the progress dialog
* **/
protected void onPostExecute(String file_url) {
// dismiss the dialog once done
pDialog.dismiss();
}
}
}
logcat 错误:
01-22 07:50:28.381: E/WindowManager(924): Activity com.mad.restaurantfinderrm.TabsViewPagerFragmentActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{41891c88 V.E..... R.....I. 0,0-240,147} that was originally added here
01-22 07:50:28.381: E/WindowManager(924): android.view.WindowLeaked: Activity com.mad.restaurantfinderrm.TabsViewPagerFragmentActivity has leaked window com.android.internal.policy.impl.PhoneWindow$DecorView{41891c88 V.E..... R.....I. 0,0-240,147} that was originally added here
01-22 07:50:28.381: E/WindowManager(924): at android.view.ViewRootImpl.<init>(ViewRootImpl.java:345)
01-22 07:50:28.381: E/WindowManager(924): at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:239)
01-22 07:50:28.381: E/WindowManager(924): at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:69)
01-22 07:50:28.381: E/WindowManager(924): at android.app.Dialog.show(Dialog.java:281)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment.error(Tab2Fragment.java:248)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment.displayDeals(Tab2Fragment.java:324)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment$LoadDeals$1.run(Tab2Fragment.java:209)
01-22 07:50:28.381: E/WindowManager(924): at android.app.Activity.runOnUiThread(Activity.java:4673)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment$LoadDeals.onPostExecute(Tab2Fragment.java:183)
01-22 07:50:28.381: E/WindowManager(924): at com.mad.restaurantfinderrm.Tab2Fragment$LoadDeals.onPostExecute(Tab2Fragment.java:1)
01-22 07:50:28.381: E/WindowManager(924): at android.os.AsyncTask.finish(AsyncTask.java:631)
01-22 07:50:28.381: E/WindowManager(924): at android.os.AsyncTask.access$600(AsyncTask.java:177)
01-22 07:50:28.381: E/WindowManager(924): at android.os.AsyncTask$InternalHandler.handleMessage(AsyncTask.java:644)
01-22 07:50:28.381: E/WindowManager(924): at android.os.Handler.dispatchMessage(Handler.java:99)
01-22 07:50:28.381: E/WindowManager(924): at android.os.Looper.loop(Looper.java:137)
01-22 07:50:28.381: E/WindowManager(924): at android.app.ActivityThread.main(ActivityThread.java:5103)
01-22 07:50:28.381: E/WindowManager(924): at java.lang.reflect.Method.invokeNative(Native Method)
01-22 07:50:28.381: E/WindowManager(924): at java.lang.reflect.Method.invoke(Method.java:525)
01-22 07:50:28.381: E/WindowManager(924): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
01-22 07:50:28.381: E/WindowManager(924): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
01-22 07:50:28.381: E/WindowManager(924): at dalvik.system.NativeStart.main(Native Method)
最佳答案
您在调用 onPostExecute
之前调用 finish()
。我认为这会泄露你的pDialog
。尝试在关闭 pDialog
onPostExecute
中移动
finish()
关于java - Activity 泄漏了窗口 com.android.internal.policy.impl.PhoneWindow$DecorView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21284047/
IntentReceiver 正在泄漏 由于 onDetachedFromWindow 在某些情况下未被调用。 @Override protected void onDetachedFromWind
好吧,我很难追踪这个内存泄漏。运行此脚本时,我没有看到任何内存泄漏,但我的 objectalloc 正在攀升。 Instruments 指向 CGBitmapContextCreateImage >
我编写了一个测试代码来检查如何使用 Instrument(Leaks)。我创建了一个单一 View 应用程序,单击按钮后我加载了一个像这样的新 View ... - (IBAction)btn_clk
我正在使用这个简单的代码并观察单调增加的内存使用量。我正在使用这个小模块将内容转储到磁盘。我观察到它发生在 unicode 字符串上而不是整数上,我做错了什么吗? 当我这样做时: >>> from u
我有以下泄漏的代码。 Instruments 表示,泄漏的是 rssParser 对象。我“刷新”了 XML 提要,它运行了该 block 并且发生了泄漏...... 文件.h @interface
我在我编写的以下代码片段中发现了内存泄漏 NSFileManager *fileManager=[[NSFileManager alloc] init]; fileList=[[fileManager
因此,我正在开发HTML5 / javascript rts游戏。观察一直有几种声音在播放。因此,对我来说,是一段时间后声音听起来像是“崩溃”,并且此浏览器选项卡上的所有声音都停止了工作。我只能通过重
下面是我正在使用的一段代码及其输出。 my $handle; my $enterCount = Devel::Leak::NoteSV($handle); print "$date entry $en
在这篇关于 go-routines 泄漏的帖子之后,https://www.ardanlabs.com/blog/2018/11/goroutine-leaks-the-forgotten-sende
我想知道为什么在执行 ./a.out 后随机得到以下结果。有什么想法我做错了吗?谢谢 http://img710.imageshack.us/img710/8708/trasht.png 最佳答案 正
我正在 Swift 中开发一个应用程序,在呈现捕获我放在一起的二维码的自定义 ViewController 后,我注意到出现了巨大的内存跳跃。 该代码本质上基于以下示例:http://www.appc
下面是我的 javascript 代码片段。它没有按预期运行,请帮我解决这个问题。 function getCurrentLocation() { console.log("insi
我们在生产环境中部署了 3 个代理 Kafka 0.10.1.0。有些应用程序嵌入了 Kafka Producer,它们将应用程序日志发送到某个主题。该主题有 10 个分区,复制因子为 3。 我们观察
我正在使用仪器来检测一些泄漏,但有一些泄漏我无法解决; NSMutableString *textedetails = [[NSMutableString alloc] init];
如果我使用性能工具测试我的代码 - 泄漏,它没有检测到任何泄漏。这是否意味着代码没有泄漏任何内存? 我有一个越狱的 iPhone,我可以监控可用内存。如果有人知道,那就是 SBSettings。我测试
我在从 AddressBook 中获取图像时遇到了很大的问题,下面我粘贴了我的代码。此 imageData 从未被释放,在我的 Allocations Instruments 上它看起来总是在内存中它
- (NSMutableArray *)getArrayValue:(NSArray *)array{ NSMutableArray *valueArray = [NSMutableArra
Instruments 工具说这是一个泄漏,有什么想法吗? 我在 for 循环结束时释放变量对象 在上述方法的开头,这就是我设置变量对象的方式,即自动释放; NSMutableArray *varia
我正在跟踪我的 iOS 应用程序的内存泄漏,我有一个奇怪的泄漏导致我的应用程序崩溃......负责的框架是:CGImageMergeXMPPropsWhithLegacyProps。在某些时候,我的应
我正在尝试使用 NSOperationQueue 在后台线程中执行一个方法,如下所示: NSOperationQueue *queue = [NSOperationQueue new]; NS
我是一名优秀的程序员,十分优秀!