91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android IPC機制Messenger實例詳解

發布時間:2020-08-26 13:01:05 來源:腳本之家 閱讀:121 作者:左手木亽 欄目:移動開發

Android IPC機制Messenger實例詳解

前言:

Messenger可以翻譯成信使,通過它可以在不同進程間傳遞Message對象有了它就可以輕松實現進程間的數據傳遞了。

Messenger使用的方法相對AIDL比較簡單,它對AIDL做了一層封裝是的我們不需要像采用AIDL那樣去實現進程通信那么麻煩,可以看看他的源碼有AIDL的跡象。

public final class Messenger implements Parcelable {
  private final IMessenger mTarget;

  public Messenger(Handler target) {
    mTarget = target.getIMessenger();
  }

  public void send(Message message) throws RemoteException {
    mTarget.send(message);
  }

  public IBinder getBinder() {
    return mTarget.asBinder();
  }

  public boolean equals(Object otherObj) {
    if (otherObj == null) {
      return false;
    }
    try {
      return mTarget.asBinder().equals(((Messenger)otherObj)
          .mTarget.asBinder());
    } catch (ClassCastException e) {
    }
    return false;
  }

  public int hashCode() {
    return mTarget.asBinder().hashCode();
  }

  public int describeContents() {
    return 0;
  }

  public void writeToParcel(Parcel out, int flags) {
    out.writeStrongBinder(mTarget.asBinder());
  }

  public static final Parcelable.Creator<Messenger> CREATOR
      = new Parcelable.Creator<Messenger>() {
    public Messenger createFromParcel(Parcel in) {
      IBinder target = in.readStrongBinder();
      return target != null ? new Messenger(target) : null;
    }

    public Messenger[] newArray(int size) {
      return new Messenger[size];
    }
  };

  public static void writeMessengerOrNullToParcel(Messenger messenger,
      Parcel out) {
    out.writeStrongBinder(messenger != null ? messenger.mTarget.asBinder()
        : null);
  }

  public static Messenger readMessengerOrNullFromParcel(Parcel in) {
    IBinder b = in.readStrongBinder();
    return b != null ? new Messenger(b) : null;
  }

  public Messenger(IBinder target) {
    mTarget = IMessenger.Stub.asInterface(target);
  }
}

首先我們需要新建一個Service來處理客戶端的請求,同時聲明一個Handler作為參數來創建一個Messenger,然后通過getBinder()方法返回Binder。

public class MessageService extends Service {

  private Messenger mMessenger = new Messenger(new Handler() {
    @Override
    public void handleMessage(Message msgFromClient) {
      super.handleMessage(msgFromClient);
      Message msgToTarget = Message.obtain(msgFromClient);
      msgToTarget.what = 0;
      try {
        Thread.sleep(2000);
        msgToTarget.arg1 = msgFromClient.arg1 + msgFromClient.arg2;
        msgFromClient.replyTo.send(msgToTarget);
      } catch (InterruptedException e) {
        e.printStackTrace();
      } catch (RemoteException e) {
        e.printStackTrace();
      }
    }
  });

  @Nullable
  @Override
  public IBinder onBind(Intent intent) {
    return mMessenger.getBinder();
  }
}

里面的邏輯是簡單的將客戶端傳來的Message中的arg1和arg2的值相加并將結果返回給Message對應的replyTo這個Messenger,并通過send將服務端的Message返回給客戶端。

然后在客戶端處理:首先需要bindService來綁定這個Service,然后通過IBinder生成一個Messenger對象,這個Messenger對象就可以將需要處理的數據封裝到Message然后send到Service去。

 Messenger mMessenger = new Messenger(new Handler() {
    @Override
    public void handleMessage(Message msg) {
      super.handleMessage(msg);
      Log.w("Jayuchou", "--- 從異步線程中讀取到數據 --- " + msg.arg1);
    }
  });

  Messenger mService;

  ServiceConnection connection = new ServiceConnection() {
    @Override
    public void onServiceConnected(ComponentName name, IBinder service) {
      mService = new Messenger(service);
      Log.w("Jayuchou", "-- Connected success --");
    }

    @Override
    public void onServiceDisconnected(ComponentName name) {
      Log.w("Jayuchou", "-- Connected dismiss --");
      mService = null;
    }
  };

然后調用的地方方式為:

     Message msgFromClient = Message.obtain(null, 0, 1, 2);
        msgFromClient.replyTo = mMessenger;
        try {
          mService.send(msgFromClient);
        } catch (RemoteException e) {
          e.printStackTrace();
        }

將數據封裝Message中,并且Message中的replyTo指定服務端中要將結果回調的Messenger對象。

msgFromClient.replyTo.send(msgToTarget);

我們可以看到Service中有這么一句代碼,其中的replyTo就是我們在客戶端傳進去的Messenger,這時候調用send方法就可以將服務端的也就是另一個進程的數據傳到想要用的進程然后采用Messenger進行接收,我們可以跟Handler用法類似的使用即可。Messenger是一個輕量級的AIDL,一次一個處理請求。

以上就是Android messenger 的消息處理的詳解,關于Android 開發的文章,本站還很多,請大家搜索參閱,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

苍南县| 靖江市| 凤城市| 孟村| 绥棱县| 荣成市| 华容县| 密山市| 土默特右旗| 招远市| 靖宇县| 彩票| 浦城县| 曲周县| 九江县| 灵台县| 诏安县| 麻江县| 太仆寺旗| 日喀则市| 博野县| 奉化市| 开化县| 济南市| 内江市| 射洪县| 乐都县| 西和县| 甘德县| 和林格尔县| 安徽省| 依安县| 南京市| 固阳县| 葵青区| 三穗县| 新沂市| 汪清县| 师宗县| 伊金霍洛旗| 会宁县|