Android IPC機制:Messenger

Messenger可以被翻譯為信使氧腰,通過它可以在不同進程中傳遞Message對象诅福。在message中放入需要傳遞的數(shù)據(jù)泛范,就可以實現(xiàn)數(shù)據(jù)在進程中傳遞。Messenger是一種輕量級的IPC方案谍夭,底層實現(xiàn)還是AILD,具體見構(gòu)造方法黑滴。

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

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

一、對于Messenger的使用先從原理圖開始

圖.png

二慧库、實現(xiàn)Messenger的具體步驟

  1. 服務端進程
    服務端需要創(chuàng)新一個Server來處理客戶端的連接請求跷跪,同事創(chuàng)建一個Handler并通過它創(chuàng)建一個Messenger對象,然后在Server的onBind中返回Messenger底層的Binder即可齐板。

  2. 客戶端進程
    首先需要綁定服務吵瞻,連接成功之后使用服務端返回的IBinder對象創(chuàng)建一個Messenger對象,通過這個Messenger對象可以傳遞Message對象甘磨。
    如果需要服務端回應客戶端橡羞,則需要向服務端一樣,創(chuàng)建一個Handler和一個由它構(gòu)造出來的Messenger济舆,并將這個Messenger對象通過Message.replyTo=Messenger傳遞給服務端卿泽。之后服務端就可以獲取Message利用同樣的方法實例化一個Messenger,之后就可以給服務端傳遞信息滋觉,并由Handler處理签夭。

  3. 代碼
    服務端

public class MessengerService extends Service {
    public static final String TAG = MessengerService.class.getSimpleName();

    private final Messenger mMessenger = new Messenger(new MessengerHandler());

    public MessengerService() {
    }

    @Override
    public IBinder onBind(Intent intent) {
        //獲取messenger的binder對象返回給客戶端使用
        return mMessenger.getBinder();
    }

    public static class MessengerHandler extends Handler {
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what) {
                case MyConstants.MSG_FROM_CLIENT:
                    Log.e(TAG, "來自客戶端的消息" + msg.getData().getString("msg"));
                    //給客戶端做出回應
                    Message message = Message.obtain(null, MyConstants.MSG_FROM_SERVER);
                    Bundle data = new Bundle();
                    data.putString("msg", "親!你已經(jīng)成功連上服務器了椎侠!");
                    message.setData(data);
                    try {
                        msg.replyTo.send(message);
                    } catch (RemoteException e) {
                        e.printStackTrace();
                    }
                    break;
                default:
                    super.handleMessage(msg);
            }
        }
    }

}

客戶端

public class MainActivity extends AppCompatActivity {
    public static final String TAG = MainActivity.class.getSimpleName();
    private Messenger mServer, mClient;
    private Intent mIntent;
    private ServiceConnection mServiceConnection = new ServiceConnection() {
        @Override
        public void onServiceConnected(ComponentName name, IBinder service) {
            //連接成功第租,使用服務端傳遞過來的Ibinder對象實例化messenger
            mServer = new Messenger(service);
            Message message = Message.obtain(null, MyConstants.MSG_FROM_CLIENT);
            Bundle data = new Bundle();
            data.putString("msg", "來自客戶端的消息");
            message.setData(data);
            //將客戶端的messenger傳遞給服務端,以便服務端響應客戶端
            message.replyTo = mClient;
            try {
                mServer.send(message);
            } catch (RemoteException e) {
                e.printStackTrace();
            }
        }

        @Override
        public void onServiceDisconnected(ComponentName name) {

        }
    };


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        mIntent = new Intent(this, MessengerService.class);
        mClient = new Messenger(new MyHandler());

    }

    public void bindServer(View view) {
        //綁定服務
        bindService(mIntent, mServiceConnection, BIND_AUTO_CREATE);

    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        unbindService(mServiceConnection);
    }

    private class MyHandler extends Handler {
        @Override
        public void handleMessage(Message msg) {
            switch (msg.what) {
                //來自服務器的回應
                case MyConstants.MSG_FROM_SERVER:
                    Log.e(TAG, "來自服務器的消息" + msg.getData().get("msg"));
                    break;
                default:
                    super.handleMessage(msg);

            }
        }
    }
}
最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末我纪,一起剝皮案震驚了整個濱河市慎宾,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌浅悉,老刑警劉巖趟据,帶你破解...
    沈念sama閱讀 211,265評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異术健,居然都是意外死亡汹碱,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,078評論 2 385
  • 文/潘曉璐 我一進店門荞估,熙熙樓的掌柜王于貴愁眉苦臉地迎上來咳促,“玉大人色难,你說我怎么就攤上這事〉茸海” “怎么了?”我有些...
    開封第一講書人閱讀 156,852評論 0 347
  • 文/不壞的土叔 我叫張陵娇昙,是天一觀的道長尺迂。 經(jīng)常有香客問我,道長冒掌,這世上最難降的妖魔是什么噪裕? 我笑而不...
    開封第一講書人閱讀 56,408評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮股毫,結(jié)果婚禮上膳音,老公的妹妹穿的比我還像新娘。我一直安慰自己铃诬,他們只是感情好祭陷,可當我...
    茶點故事閱讀 65,445評論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著趣席,像睡著了一般兵志。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上宣肚,一...
    開封第一講書人閱讀 49,772評論 1 290
  • 那天想罕,我揣著相機與錄音,去河邊找鬼霉涨。 笑死按价,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的笙瑟。 我是一名探鬼主播楼镐,決...
    沈念sama閱讀 38,921評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼逮走!你這毒婦竟也來了鸠蚪?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,688評論 0 266
  • 序言:老撾萬榮一對情侶失蹤师溅,失蹤者是張志新(化名)和其女友劉穎茅信,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體墓臭,經(jīng)...
    沈念sama閱讀 44,130評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡蘸鲸,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,467評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了窿锉。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酌摇。...
    茶點故事閱讀 38,617評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡膝舅,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出窑多,到底是詐尸還是另有隱情仍稀,我是刑警寧澤,帶...
    沈念sama閱讀 34,276評論 4 329
  • 正文 年R本政府宣布埂息,位于F島的核電站技潘,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏千康。R本人自食惡果不足惜享幽,卻給世界環(huán)境...
    茶點故事閱讀 39,882評論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望拾弃。 院中可真熱鬧值桩,春花似錦、人聲如沸豪椿。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,740評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽砂碉。三九已至蛀蜜,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間增蹭,已是汗流浹背滴某。 一陣腳步聲響...
    開封第一講書人閱讀 31,967評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留滋迈,地道東北人霎奢。 一個月前我還...
    沈念sama閱讀 46,315評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像饼灿,于是被迫代替她去往敵國和親幕侠。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,486評論 2 348

推薦閱讀更多精彩內(nèi)容

  • 一碍彭、IPC簡介 (1)IPC是Inter-Process Communication的縮寫晤硕,含義為進程間通信或者跨...
    遙遙的遠方閱讀 7,200評論 0 3
  • 在上一篇Window里提及過IPC,本篇將詳細總結(jié)IPC庇忌,知識點如下: IPC基礎及概念多進程模式序列化Seria...
    厘米姑娘閱讀 8,074評論 17 29
  • Android跨進程通信IPC整體內(nèi)容如下 1舞箍、Android跨進程通信IPC之1——Linux基礎2、Andro...
    隔壁老李頭閱讀 3,553評論 3 12
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理皆疹,服務發(fā)現(xiàn)疏橄,斷路器,智...
    卡卡羅2017閱讀 134,629評論 18 139
  • 那是遠方的醇香 那是五谷的芬芳 那是勤勞的歡笑 釀造 釀造 釀出了瓊漿玉液 造出了歲月傳奇 流傳至今 華夏品贊 不...
    語文行者閱讀 356評論 0 9