/ / Додаток аварійно завершує роботу під час отримання editText у потоці Android Studio - android, crash, android-edittext

Додаток виходить з ладу під час отримання editText у потоці Android Studio - андроїд, збій та android-edittext

Це схоже на іншу проблему, яку я мав ранішез textView, який передбачав збій програми (що було вирішено), але зараз у мене проблема з editText, тому що всякий раз, коли я намагаюся отримати editText.getvalue (), навіть коли він знаходиться поза потоком, він збиває програму.

Ось код:

package awsomisoft.yemeb;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.EditText;
import android.widget.TextView;
import android.widget.Toast;

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;

import awsomisoft.yemeb.R;

public class List extends Activity {
private Handler handler;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_list);
final TextView urlTextOut = (TextView) findViewById(R.id.URLtextView);
final EditText sear = (EditText) findViewById(R.id.editText);
new Thread() {
StringBuilder text = new StringBuilder();
@Override
public void run() {
try

{
String str = "";
URL url = new URL("http://mydomainname.com/"+sear.getText().toString()+"/test.meb");
BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream()));

while ((str = in.readLine()) != null) {
text.append(str);
}
in.close();
} catch (MalformedURLException e1)

{
} catch (IOException e)

{
}
runOnUiThread(new Runnable() {
@Override
public void run() {
urlTextOut.setText(text);
}
});
}
}.start();

}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.list, menu);
return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId();
if (id == R.id.action_settings) {
return true;
}
return super.onOptionsItemSelected(item);
}
}

РЕДАГУВАТИ: Ось Activity_list.xml -

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context="awsomisoft.yemeb.List"
android:id="@+id/List">

<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/URLtextView"
android:textSize="18dp" />

</RelativeLayout>

Я намагався використовувати Handlers раніше, тому що буврішення, яке я знайшов тут, щоб використовувати editText у потоках, але воно не вирішило проблему. Я припускаю, що є рішення проблеми, але я, здається, не можу його знайти. Мені просто потрібен посібник, щоб зрозуміти, що мені потрібно робити з editText, щоб переконатися, що програма не збій. Дякую за будь-яку допомогу. Прошу вибачення, якщо є просте рішення.

Відповіді:

1 для відповіді № 1

Зазвичай ви дозволяєте анонімному класуотримати доступ до змінних зовнішнього класу, оголосивши змінні остаточними. Однак у вашому випадку, оскільки мова йде про текст редагування, ви хочете, щоб цю змінну можна було змінювати, тому final не є прийнятним.

Найкраще в цій ситуації зробитипотік нормального класу, а не анонімного класу, а потім передайте змінну в конструктор (це повинен бути звичайний клас, оскільки ви не можете мати явно оголошений конструктор в анонімному класі).

public class MyThread implements Runnable {

StringBuilder text = new StringBuilder();
String editTextContents;

// Constructor
public MyThread(String editTextContents) {      // <-- Pass in the string from EditText here
this.editTextContents = editTextContents;
}

@Override
public void run() {
try

{
String str = "";
URL url = new URL("http://mydomainname.com/"+ editTextContents +"/test.meb");
BufferedReader in = new BufferedReader(new InputStreamReader(url.openStream()));

while ((str = in.readLine()) != null) {
text.append(str);
}
in.close();
} catch (MalformedURLException e1)

{
} catch (IOException e)

{
}
runOnUiThread(new Runnable() {
@Override
public void run() {
urlTextOut.setText(text);
}
}
}
}

Ви можете викликати нитку у своїй діяльності за допомогою:

Runnable myRunnable = new MyThread(editTextContents);
new Thread(myRunnable).start;

0 для відповіді № 2

Якщо EditText, до якого ви намагаєтесь отримати доступ, відсутній у макеті, який ви встановлюєте за допомогою

setContentView(R.layout.activity_list);

тоді він збирається встановити пошук для подання, яке він не може знайти або (нуль):

final EditText sear = (EditText) findViewById(R.id.editText); // null
sear.getText().toString() // will now crash your app because
// you"re trying to access a null object

Іншими словами R.id.editText повинен знаходитись у макеті Activity_list.xml, або потрібно використовувати інший файл xml, який він уже знаходиться, коли ви встановлюєтеContentView (*.xml)