Android AyncTaskメモリの安全性について簡単に話します。
問題
内部クラスや内部匿名クラスはメモリが漏れてしまうため、非同期コードが多く書かれています。この後ずっと考えています。非同期コードはどう書くべきですか?どうやって正しい書き方ですか?どうやって簡潔な書き方ですか?
考え方
弱い引用のインターフェースをメインスレッドとして子スレッドと交流するブリッジです。
コード
WeakTask.java
この数日間ずっとrxJavaを見ています。どうしてrxJavaを勉強するのかをずっと考えています。もちろん、その名前は観測者モードである以上、解決すべき問題は主にスレッドに表示されているデータをサブスレッドのデータに従って更新します。これまでAndroid公式を見たmvmはrxJavaを使ったようです。試しにrxJavaを使ってみましたが、何のメリットも感じられません。もし後に時間があれば、観察者モードを深く研究して、その後rxJavaとrxAndroidを見てみます。最近また秋招の時になりました。
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。
内部クラスや内部匿名クラスはメモリが漏れてしまうため、非同期コードが多く書かれています。この後ずっと考えています。非同期コードはどう書くべきですか?どうやって正しい書き方ですか?どうやって簡潔な書き方ですか?
考え方
弱い引用のインターフェースをメインスレッドとして子スレッドと交流するブリッジです。
コード
WeakTask.java
public class WeakTask<T> extends AsyncTask<Void, Void, T> {
private WeakReference<OnWeakTaskListener<T>> listenerReference;
public WeakTask(OnWeakTaskListener<T> listener){
this.listenerReference = new WeakReference<>(listener);
}
@Override
protected T doInBackground(Void... voids) {
if (listenerReference.get() != null) {
return listenerReference.get().middle();
}else{
return null;
}
}
@Override
protected void onPreExecute() {
super.onPreExecute();
if (listenerReference.get() != null) {
listenerReference.get().before();
}
}
@Override
protected void onPostExecute(T t) {
super.onPostExecute(t);
if (listenerReference.get() != null && t != null){
listenerReference.get().after(t);
}
}
}
OnWeak Task Listener
public interface OnWeakTaskListener<T> {
void before();
T middle();
void after(T t);
}
使用-->LoginaActivity.java
public class LoginActivity extends AppCompatActivity implements View.OnClickListener {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
initLayout();
}
private void initLayout(){
findViewById(R.id.btn_login).setOnClickListener(this);
}
@Override
public void onClick(View view) {
if (view.getId() == R.id.btn_login){
new WeakTask<Integer>(new LoginWeakTaskListener()).execute();
}
}
private class LoginWeakTaskListener implements OnWeakTaskListener<Integer>{
@Override
public void before() {
...
}
@Override
public Integer middle() {
...
}
@Override
public void after(Integer integer) {
...
}
}
}
結論この数日間ずっとrxJavaを見ています。どうしてrxJavaを勉強するのかをずっと考えています。もちろん、その名前は観測者モードである以上、解決すべき問題は主にスレッドに表示されているデータをサブスレッドのデータに従って更新します。これまでAndroid公式を見たmvmはrxJavaを使ったようです。試しにrxJavaを使ってみましたが、何のメリットも感じられません。もし後に時間があれば、観察者モードを深く研究して、その後rxJavaとrxAndroidを見てみます。最近また秋招の時になりました。
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。