吴忠躺衫网络科技有限公司

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

鴻蒙開發通信與連接:ohos.rpc RPC通信

jf_46214456 ? 來源:jf_46214456 ? 作者:jf_46214456 ? 2024-06-21 09:40 ? 次閱讀

RPC通信

本模塊提供進程間通信能力,包括設備內的進程間通信(IPC)和設備間的進程間通信(RPC),前者基于Binder驅動,后者基于軟總線驅動。

icon-note.gif說明: 本模塊首批接口從API version 7開始支持。后續版本的新增接口,采用上角標單獨標記接口的起始版本。 開發前請熟悉鴻蒙開發指導文檔 :[gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

導入模塊

import rpc from '@ohos.rpc';

MessageParcel

該類提供讀寫基礎類型及數組、IPC對象、接口描述符和自定義序列化對象的方法。

create

create(): MessageParcel

靜態方法,創建MessageParcel對象。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
MessageParcel返回創建的MessageParcel對象。

示例:

let data = rpc.MessageParcel.create();
console.log("RpcClient: data is " + data);

reclaim

reclaim(): void

釋放不再使用的MessageParcel對象。

系統能力 :SystemCapability.Communication.IPC.Core

示例:

let reply = rpc.MessageParcel.create();
reply.reclaim();

writeRemoteObject

writeRemoteObject(object: [IRemoteObject]): boolean

序列化遠程對象并將其寫入MessageParcel對象。

系統能力 :SystemCapability.Communication.IPC.Core

參數

參數名類型必填說明
object[IRemoteObject]要序列化并寫入MessageParcel的遠程對象。

返回值:

類型說明
boolean如果操作成功,則返回true;否則返回false。

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}
class TestRemoteObject extends rpc.RemoteObject {
    constructor(descriptor) {
        super(descriptor);
    }
    addDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    removeDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    isObjectDead(): boolean {
        return false;
    }
}
let data = rpc.MessageParcel.create();
let testRemoteObject = new TestRemoteObject("testObject");
data.writeRemoteObject(testRemoteObject);

readRemoteObject

readRemoteObject(): IRemoteObject

從MessageParcel讀取遠程對象。此方法用于反序列化MessageParcel對象以生成IRemoteObject。遠程對象按寫入MessageParcel的順序讀取。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
[IRemoteObject]讀取到的遠程對象。

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}
class TestRemoteObject extends rpc.RemoteObject {
    constructor(descriptor) {
        super(descriptor);
    }
    addDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    removeDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    isObjectDead(): boolean {
        return false;
    }
}
let data = rpc.MessageParcel.create();
let testRemoteObject = new TestRemoteObject("testObject");
data.writeRemoteObject(testRemoteObject);
let proxy = data.readRemoteObject();

writeInterfaceToken

writeInterfaceToken(token: string): boolean

將接口描述符寫入MessageParcel對象。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
tokenstring字符串類型描述符。

返回值:

類型說明
boolean如果操作成功,則返回true;否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeInterfaceToken("aaa");
console.log("RpcServer: writeInterfaceToken is " + result);

readInterfaceToken

readInterfaceToken(): string

從MessageParcel中讀取接口描述符。接口描述符按寫入MessageParcel的順序讀取。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
string返回讀取到的接口描述符。

示例:

class Stub extends rpc.RemoteObject {
    onRemoteRequest(code, data, reply, option) {
        let interfaceToken = data.readInterfaceToken();
        console.log("RpcServer: interfaceToken is " + interfaceToken);
        return true;
    }
}

getSize

getSize(): number

獲取當前MessageParcel的數據大小。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number獲取的MessageParcel的數據大小。以字節為單位。

示例:

let data = rpc.MessageParcel.create();
let size = data.getSize();
console.log("RpcClient: size is " + size);

getCapacity

getCapacity(): number

獲取當前MessageParcel的容量。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number獲取的MessageParcel的容量大小。以字節為單位。

示例:

let data = rpc.MessageParcel.create();
let result = data.getCapacity();
console.log("RpcClient: capacity is " + result);

setSize

setSize(size: number): boolean

設置MessageParcel實例中包含的數據大小。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
sizenumberMessageParcel實例的數據大小。以字節為單位。

返回值:

類型說明
boolean設置成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let setSize = data.setSize(16);
console.log("RpcClient: setSize is " + setSize);

setCapacity

setCapacity(size: number): boolean

設置MessageParcel實例的存儲容量。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
sizenumberMessageParcel實例的存儲容量。以字節為單位。

返回值:

類型說明
boolean設置成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.setCapacity(100);
console.log("RpcClient: setCapacity is " + result);

getWritableBytes

getWritableBytes(): number

獲取MessageParcel的可寫字節空間。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number獲取到的MessageParcel的可寫字節空間。以字節為單位。

示例:

class Stub extends rpc.RemoteObject {
    onRemoteRequest(code, data, reply, option) {
        let getWritableBytes = data.getWritableBytes();
        console.log("RpcServer: getWritableBytes is " + getWritableBytes);
        return true;
    }
}

getReadableBytes

getReadableBytes(): number

獲取MessageParcel的可讀字節空間。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number獲取到的MessageParcel的可讀字節空間。以字節為單位。

示例:

class Stub extends rpc.RemoteObject {
    onRemoteRequest(code, data, reply, option) {
        let result = data.getReadableBytes();
        console.log("RpcServer: getReadableBytes is " + result);
        return true;
    }
}

getReadPosition

getReadPosition(): number

獲取MessageParcel的讀位置。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回MessageParcel實例中的當前讀取位置。

示例:

let data = rpc.MessageParcel.create();
let readPos = data.getReadPosition();
console.log("RpcClient: readPos is " + readPos);

getWritePosition

getWritePosition(): number

獲取MessageParcel的寫位置。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回MessageParcel實例中的當前寫入位置。

示例:

let data = rpc.MessageParcel.create();
data.writeInt(10);
let bwPos = data.getWritePosition();
console.log("RpcClient: bwPos is " + bwPos);

rewindRead

rewindRead(pos: number): boolean

重新偏移讀取位置到指定的位置。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
posnumber開始讀取數據的目標位置。

返回值:

類型說明
boolean如果讀取位置發生更改,則返回true;否則返回false。

示例:

let data = rpc.MessageParcel.create();
data.writeInt(12);
data.writeString("parcel");
let number = data.readInt();
console.log("RpcClient: number is " + number);
data.rewindRead(0);
let number2 = data.readInt();
console.log("RpcClient: rewindRead is " + number2);

rewindWrite

rewindWrite(pos: number): boolean

重新偏移寫位置到指定的位置。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
posnumber開始寫入數據的目標位置。

返回值:

類型說明
boolean如果寫入位置更改,則返回true;否則返回false。

示例:

let data = rpc.MessageParcel.create();
data.writeInt(4);
data.rewindWrite(0);
data.writeInt(5);
let number = data.readInt();
console.log("RpcClient: rewindWrite is: " + number);

writeByte

writeByte(val: number): boolean

將字節值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的字節值。

返回值:

類型說明
boolean寫入返回成功,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeByte(2);
console.log("RpcClient: writeByte is: " + result);

readByte

readByte(): number

從MessageParcel實例讀取字節值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回字節值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeByte(2);
console.log("RpcClient: writeByte is: " + result);
let ret = data.readByte();
console.log("RpcClient: readByte is: " + ret);

writeShort

writeShort(val: number): boolean

將短整數值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的短整數值。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeShort(8);
console.log("RpcClient: writeShort is: " + result);

readShort

readShort(): number

從MessageParcel實例讀取短整數值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回短整數值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeShort(8);
console.log("RpcClient: writeShort is: " + result);
let ret = data.readShort();
console.log("RpcClient: readShort is: " + ret);

writeInt

writeInt(val: number): boolean

將整數值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的整數值。

返回值:

類型說明
boolean寫入返回成功,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeInt(10);
console.log("RpcClient: writeInt is " + result);

readInt

readInt(): number

從MessageParcel實例讀取整數值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回整數值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeInt(10);
console.log("RpcClient: writeInt is " + result);
let ret = data.readInt();
console.log("RpcClient: readInt is " + ret);

writeLong

writeLong(val: number): boolean

將長整數值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的長整數值

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeLong(10000);
console.log("RpcClient: writeLong is " + result);

readLong

readLong(): number

從MessageParcel實例中讀取長整數值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回長整數值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeLong(10000);
console.log("RpcClient: writeLong is " + result);
let ret = data.readLong();
console.log("RpcClient: readLong is " + ret);

writeFloat

writeFloat(val: number): boolean

將浮點值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的浮點值。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeFloat(1.2);
console.log("RpcClient: writeFloat is " + result);

readFloat

readFloat(): number

從MessageParcel實例中讀取浮點值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回浮點值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeFloat(1.2);
console.log("RpcClient: writeFloat is " + result);
let ret = data.readFloat();
console.log("RpcClient: readFloat is " + ret);

writeDouble

writeDouble(val: number): boolean

將雙精度浮點值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的雙精度浮點值。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeDouble(10.2);
console.log("RpcClient: writeDouble is " + result);

readDouble

readDouble(): number

從MessageParcel實例讀取雙精度浮點值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回雙精度浮點值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeDouble(10.2);
console.log("RpcClient: writeDouble is " + result);
let ret = data.readDouble();
console.log("RpcClient: readDouble is " + ret);

writeBoolean

writeBoolean(val: boolean): boolean

將布爾值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valboolean要寫入的布爾值。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeBoolean(false);
console.log("RpcClient: writeBoolean is " + result);

readBoolean

readBoolean(): boolean

從MessageParcel實例讀取布爾值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
boolean返回讀取到的布爾值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeBoolean(false);
console.log("RpcClient: writeBoolean is " + result);
let ret = data.readBoolean();
console.log("RpcClient: readBoolean is " + ret);

writeChar

writeChar(val: number): boolean

將單個字符值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valnumber要寫入的單個字符值。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeChar(97);
console.log("RpcClient: writeChar is " + result);

readChar

readChar(): number

從MessageParcel實例中讀取單個字符值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回單個字符值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeChar(97);
console.log("RpcClient: writeChar is " + result);
let ret = data.readChar();
console.log("RpcClient: readChar is " + ret);

writeString

writeString(val: string): boolean

將字符串值寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
valstring要寫入的字符串值,其長度應小于40960字節。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeString('abc');
console.log("RpcClient: writeString  is " + result);

readString

readString(): string

從MessageParcel實例讀取字符串值。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
string返回字符串值。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeString('abc');
console.log("RpcClient: writeString  is " + result);
let ret = data.readString();
console.log("RpcClient: readString is " + ret);

writeSequenceable

writeSequenceable(val: Sequenceable): boolean

將自定義序列化對象寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
val[Sequenceable]要寫入的可序列對象。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

class MySequenceable {
    num: number;
    str: string;
    constructor(num, str) {
        this.num = num;
        this.str = str;
    }
    marshalling(messageParcel) {
        messageParcel.writeInt(this.num);
        messageParcel.writeString(this.str);
        return true;
    }
    unmarshalling(messageParcel) {
        this.num = messageParcel.readInt();
        this.str = messageParcel.readString();
        return true;
    }
}
let sequenceable = new MySequenceable(1, "aaa");
let data = rpc.MessageParcel.create();
let result = data.writeSequenceable(sequenceable);
console.log("RpcClient: writeSequenceable is " + result);

readSequenceable

readSequenceable(dataIn: Sequenceable) : boolean

從MessageParcel實例中讀取成員變量到指定的對象(dataIn)。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataIn[Sequenceable]需要從MessageParcel讀取成員變量的對象。

返回值:

類型說明
boolean如果反序列成功,則返回true;否則返回false。

示例:

class MySequenceable {
    num: number;
    str: string;
    constructor(num, str) {
        this.num = num;
        this.str = str;
    }
    marshalling(messageParcel) {
        messageParcel.writeInt(this.num);
        messageParcel.writeString(this.str);
        return true;
    }
    unmarshalling(messageParcel) {
        this.num = messageParcel.readInt();
        this.str = messageParcel.readString();
        return true;
    }
}
let sequenceable = new MySequenceable(1, "aaa");
let data = rpc.MessageParcel.create();
let result = data.writeSequenceable(sequenceable);
console.log("RpcClient: writeSequenceable is " + result);
let ret = new MySequenceable(0, "");
let result2 = data.readSequenceable(ret);
console.log("RpcClient: writeSequenceable is " + result2);

writeByteArray

writeByteArray(byteArray: number[]): boolean

將字節數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
byteArraynumber[]要寫入的字節數組。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let ByteArrayVar = [1, 2, 3, 4, 5];
let result = data.writeByteArray(ByteArrayVar);
console.log("RpcClient: writeByteArray is " + result);

readByteArray

readByteArray(dataIn: number[]) : void

從MessageParcel實例讀取字節數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的字節數組。

示例:

let data = rpc.MessageParcel.create();
let ByteArrayVar = [1, 2, 3, 4, 5];
let result = data.writeByteArray(ByteArrayVar);
console.log("RpcClient: writeByteArray is " + result);
let array = new Array(5);
data.readByteArray(array);

readByteArray

readByteArray(): number[]

從MessageParcel實例中讀取字節數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回字節數組。

示例:

let data = rpc.MessageParcel.create();
let ByteArrayVar = [1, 2, 3, 4, 5];
let result = data.writeByteArray(ByteArrayVar);
console.log("RpcClient: writeByteArray is " + result);
let array = data.readByteArray();
console.log("RpcClient: readByteArray is " + array);

writeShortArray

writeShortArray(shortArray: number[]): boolean

將短整數數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
shortArraynumber[]要寫入的短整數數組。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeShortArray([11, 12, 13]);
console.log("RpcClient: writeShortArray is " + result);

readShortArray

readShortArray(dataIn: number[]) : void

從MessageParcel實例中讀取短整數數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的短整數數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeShortArray([11, 12, 13]);
console.log("RpcClient: writeShortArray is " + result);
let array = new Array(3);
data.readShortArray(array);

readShortArray

readShortArray(): number[]

從MessageParcel實例中讀取短整數數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回短整數數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeShortArray([11, 12, 13]);
console.log("RpcClient: writeShortArray is " + result);
let array = data.readShortArray();
console.log("RpcClient: readShortArray is " + array);

writeIntArray

writeIntArray(intArray: number[]): boolean

將整數數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
intArraynumber[]要寫入的整數數組。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeIntArray([100, 111, 112]);
console.log("RpcClient: writeIntArray is " + result);

readIntArray

readIntArray(dataIn: number[]) : void

從MessageParcel實例中讀取整數數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的整數數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeIntArray([100, 111, 112]);
console.log("RpcClient: writeIntArray is " + result);
let array = new Array(3);
data.readIntArray(array);

readIntArray

readIntArray(): number[]

從MessageParcel實例中讀取整數數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回整數數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeIntArray([100, 111, 112]);
console.log("RpcClient: writeIntArray is " + result);
let array = data.readIntArray();
console.log("RpcClient: readIntArray is " + array);

writeLongArray

writeLongArray(longArray: number[]): boolean

將長整數數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
longArraynumber[]要寫入的長整數數組。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeLongArray([1111, 1112, 1113]);
console.log("RpcClient: writeLongArray is " + result);

readLongArray

readLongArray(dataIn: number[]) : void

從MessageParcel實例讀取長整數數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的長整數數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeLongArray([1111, 1112, 1113]);
console.log("RpcClient: writeLongArray is " + result);
let array = new Array(3);
data.readLongArray(array);

readLongArray

readLongArray(): number[]

從MessageParcel實例中讀取長整數數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回長整數數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeLongArray([1111, 1112, 1113]);
console.log("RpcClient: writeLongArray is " + result);
let array = data.readLongArray();
console.log("RpcClient: readLongArray is " + array);

writeFloatArray

writeFloatArray(floatArray: number[]): boolean

將浮點數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
floatArraynumber[]要寫入的浮點數組。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeFloatArray([1.2, 1.3, 1.4]);
console.log("RpcClient: writeFloatArray is " + result);

readFloatArray

readFloatArray(dataIn: number[]) : void

從MessageParcel實例中讀取浮點數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的浮點數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeFloatArray([1.2, 1.3, 1.4]);
console.log("RpcClient: writeFloatArray is " + result);
let array = new Array(3);
data.readFloatArray(array);

readFloatArray

readFloatArray(): number[]

從MessageParcel實例中讀取浮點數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回浮點數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeFloatArray([1.2, 1.3, 1.4]);
console.log("RpcClient: writeFloatArray is " + result);
let array = data.readFloatArray();
console.log("RpcClient: readFloatArray is " + array);

writeDoubleArray

writeDoubleArray(doubleArray: number[]): boolean

將雙精度浮點數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
doubleArraynumber[]要寫入的雙精度浮點數組。

返回值:

類型說明
boolean寫入返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeDoubleArray([11.1, 12.2, 13.3]);
console.log("RpcClient: writeDoubleArray is " + result);

readDoubleArray

readDoubleArray(dataIn: number[]) : void

從MessageParcel實例中讀取雙精度浮點數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的雙精度浮點數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeDoubleArray([11.1, 12.2, 13.3]);
console.log("RpcClient: writeDoubleArray is " + result);
let array = new Array(3);
data.readDoubleArray(array);

readDoubleArray

readDoubleArray(): number[]

從MessageParcel實例讀取雙精度浮點數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回雙精度浮點數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeDoubleArray([11.1, 12.2, 13.3]);
console.log("RpcClient: writeDoubleArray is " + result);
let array = data.readDoubleArray();
console.log("RpcClient: readDoubleArray is " + array);

writeBooleanArray

writeBooleanArray(booleanArray: boolean[]): boolean

將布爾數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
booleanArrayboolean[]要寫入的布爾數組。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeBooleanArray([false, true, false]);
console.log("RpcClient: writeBooleanArray is " + result);

readBooleanArray

readBooleanArray(dataIn: boolean[]) : void

從MessageParcel實例中讀取布爾數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInboolean[]要讀取的布爾數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeBooleanArray([false, true, false]);
console.log("RpcClient: writeBooleanArray is " + result);
let array = new Array(3);
data.readBooleanArray(array);

readBooleanArray

readBooleanArray(): boolean[]

從MessageParcel實例中讀取布爾數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
boolean[]返回布爾數組。
let data = rpc.MessageParcel.create();
let result = data.writeBooleanArray([false, true, false]);
console.log("RpcClient: writeBooleanArray is " + result);
let array = data.readBooleanArray();
console.log("RpcClient: readBooleanArray is " + array);

writeCharArray

writeCharArray(charArray: number[]): boolean

將單個字符數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
charArraynumber[]要寫入的單個字符數組。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeCharArray([97, 98, 88]);
console.log("RpcClient: writeCharArray is " + result);

readCharArray

readCharArray(dataIn: number[]) : void

從MessageParcel實例中讀取單個字符數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInnumber[]要讀取的單個字符數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeCharArray([97, 98, 99]);
console.log("RpcClient: writeCharArray is " + result);
let array = new Array(3);
data.readCharArray(array);

readCharArray

readCharArray(): number[]

從MessageParcel實例讀取單個字符數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number[]返回單個字符數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeCharArray([97, 98, 99]);
console.log("RpcClient: writeCharArray is " + result);
let array = data.readCharArray();
console.log("RpcClient: readCharArray is " + array);

writeStringArray

writeStringArray(stringArray: string[]): boolean

將字符串數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
stringArraystring[]要寫入的字符串數組,數組單個元素的長度應小于40960字節。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeStringArray(["abc", "def"]);
console.log("RpcClient: writeStringArray is " + result);

readStringArray

readStringArray(dataIn: string[]) : void

從MessageParcel實例讀取字符串數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataInstring[]要讀取的字符串數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeStringArray(["abc", "def"]);
console.log("RpcClient: writeStringArray is " + result);
let array = new Array(2);
data.readStringArray(array);

readStringArray

readStringArray(): string[]

從MessageParcel實例讀取字符串數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
string[]返回字符串數組。

示例:

let data = rpc.MessageParcel.create();
let result = data.writeStringArray(["abc", "def"]);
console.log("RpcClient: writeStringArray is " + result);
let array = data.readStringArray();
console.log("RpcClient: readStringArray is " + array);

writeNoException8+

writeNoException(): void

向MessageParcel寫入“指示未發生異常”的信息

系統能力 :SystemCapability.Communication.IPC.Core

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}
class TestRemoteObject extends rpc.RemoteObject {
    constructor(descriptor) {
        super(descriptor);
    }
    addDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    removeDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    isObjectDead(): boolean {
        return false;
    }
    onRemoteRequest(code, data, reply, option) {
        if (code === 1) {
            console.log("RpcServer: onRemoteRequest called");
            reply.writeNoException();
            return true;
        } else {
            console.log("RpcServer: unknown code: " + code);
            return false;
        }
    }
}

readException8+

readException(): void

從MessageParcel中讀取異常。

系統能力 :SystemCapability.Communication.IPC.Core

示例:

import FA from "@ohos.ability.featureAbility";
let proxy;
let connect = {
    onConnect: function(elementName, remoteProxy) {
        console.log("RpcClient: js onConnect called.");
        proxy = remoteProxy;
    },
    onDisconnect: function(elementName) {
        console.log("RpcClient: onDisconnect");
    },
    onFailed: function() {
        console.log("RpcClient: onFailed");
    }
};
let want = {
    "bundleName": "com.ohos.server",
    "abilityName": "com.ohos.server.MainAbility",
};
FA.connectAbility(want, connect);
let option = new rpc.MessageOption();
let data = rpc.MessageParcel.create();
let reply = rpc.MessageParcel.create();
data.writeInt(1);
data.writeString("hello");
proxy.sendRequest(1, data, reply, option)
    .then(function(errCode) {
        if (errCode === 0) {
            console.log("sendRequest got result");
            reply.readException();
            let msg = reply.readString();
            console.log("RPCTest: reply msg: " + msg);
        } else {
            console.log("RPCTest: sendRequest failed, errCode: " + errCode);
        }
    }).catch(function(e) {
        console.log("RPCTest: sendRequest got exception: " + e.message);
    }).finally (() = > {
        console.log("RPCTest: sendRequest ends, reclaim parcel");
        data.reclaim();
        reply.reclaim();
    });

writeSequenceableArray

writeSequenceableArray(sequenceableArray: Sequenceable[]): boolean

將可序列化對象數組寫入MessageParcel實例。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
sequenceableArraySequenceable[]要寫入的可序列化對象數組。

返回值:

類型說明
boolean寫入成功返回true,否則返回false。

示例:

class MySequenceable {
    num: number;
    str: string;
    constructor(num, str) {
        this.num = num;
        this.str = str;
    }
    marshalling(messageParcel) {
        messageParcel.writeInt(this.num);
        messageParcel.writeString(this.str);
        return true;
    }
    unmarshalling(messageParcel) {
        this.num = messageParcel.readInt();
        this.str = messageParcel.readString();
        return true;
    }
}
let sequenceable = new MySequenceable(1, "aaa");
let sequenceable2 = new MySequenceable(2, "bbb");
let sequenceable3 = new MySequenceable(3, "ccc");
let a = [sequenceable, sequenceable2, sequenceable3];
let data = rpc.MessageParcel.create();
let result = data.writeSequenceableArray(a);
console.log("RpcClient: writeSequenceableArray is " + result);

readSequenceableArray8+

readSequenceableArray(sequenceableArray: Sequenceable[]): void

從MessageParcel實例讀取可序列化對象數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
sequenceableArraySequenceable[]要讀取的可序列化對象數組。

示例:

class MySequenceable {
    num: number;
    str: string;
    constructor(num, str) {
        this.num = num;
        this.str = str;
    }
    marshalling(messageParcel) {
        messageParcel.writeInt(this.num);
        messageParcel.writeString(this.str);
        return true;
    }
    unmarshalling(messageParcel) {
        this.num = messageParcel.readInt();
        this.str = messageParcel.readString();
        return true;
    }
}
let sequenceable = new MySequenceable(1, "aaa");
let sequenceable2 = new MySequenceable(2, "bbb");
let sequenceable3 = new MySequenceable(3, "ccc");
let a = [sequenceable, sequenceable2, sequenceable3];
let data = rpc.MessageParcel.create();
let result = data.writeSequenceableArray(a);
console.log("RpcClient: writeSequenceableArray is " + result);
let b = [new MySequenceable(0, ""), new MySequenceable(0, ""), new MySequenceable(0, "")];
data.readSequenceableArray(b);

writeRemoteObjectArray8+

writeRemoteObjectArray(objectArray: IRemoteObject[]): boolean

將IRemoteObject對象數組寫入MessageParcel。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
objectArrayIRemoteObject[]要寫入MessageParcel的IRemoteObject對象數組。

返回值:

類型說明
boolean如果IRemoteObject對象數組成功寫入MessageParcel,則返回true;如果對象為null或數組寫入MessageParcel失敗,則返回false。

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}
class TestRemoteObject extends rpc.RemoteObject {
    constructor(descriptor) {
        super(descriptor);
        this.attachLocalInterface(this, descriptor);
    }
    addDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    removeDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    isObjectDead(): boolean {
        return false;
    }
    asObject(): rpc.IRemoteObject {
        return this;
    }
}
let a = [new TestRemoteObject("testObject1"), new TestRemoteObject("testObject2"), new TestRemoteObject("testObject3")];
let data = rpc.MessageParcel.create();
let result = data.writeRemoteObjectArray(a);
console.log("RpcClient: writeRemoteObjectArray is " + result);

[](https://gitee.com/openharmony/docs/blob/OpenHarmony-3.2-Beta1/zh-cn/application-dev/reference/apis/js-apis-rpc.md#readremoteobjectarray8)readRemoteObjectArray8+

readRemoteObjectArray(objects: IRemoteObject[]): void

從MessageParcel讀取IRemoteObject對象數組。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
objectsIRemoteObject[]從MessageParcel讀取的IRemoteObject對象數組。

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}
class TestRemoteObject extends rpc.RemoteObject {
    constructor(descriptor) {
        super(descriptor);
        this.attachLocalInterface(this, descriptor);
    }
    addDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    removeDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    isObjectDead(): boolean {
        return false;
    }
    asObject(): rpc.IRemoteObject {
        return this;
    }
}
let a = [new TestRemoteObject("testObject1"), new TestRemoteObject("testObject2"), new TestRemoteObject("testObject3")];
let data = rpc.MessageParcel.create();
let result = data.writeRemoteObjectArray(a);
let b = new Array(3);
data.readRemoteObjectArray(b);

readRemoteObjectArray8+

readRemoteObjectArray(): IRemoteObject[]

從MessageParcel讀取IRemoteObject對象數組。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
IRemoteObject[]返回IRemoteObject對象數組。

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}
class TestRemoteObject extends rpc.RemoteObject {
    constructor(descriptor) {
        super(descriptor);
        this.attachLocalInterface(this, descriptor);
    }
    addDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    removeDeathRecipient(recipient: MyDeathRecipient, flags: number): boolean {
        return true;
    }
    isObjectDead(): boolean {
        return false;
    }
    asObject(): rpc.IRemoteObject {
        return this;
    }
}
let a = [new TestRemoteObject("testObject1"), new TestRemoteObject("testObject2"), new TestRemoteObject("testObject3")];
let data = rpc.MessageParcel.create();
let result = data.writeRemoteObjectArray(a);
console.log("RpcClient: readRemoteObjectArray is " + result);
let b = data.readRemoteObjectArray();
console.log("RpcClient: readRemoteObjectArray is " + b);

closeFileDescriptor8+

static closeFileDescriptor(fd: number): void

關閉給定的文件描述符。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
fdnumber要關閉的文件描述符。

示例:

import fileio from '@ohos.fileio';
let filePath = "path/to/file";
let fd = fileio.openSync(filePath, 0o2| 0o100, 0o666);
rpc.MessageParcel.closeFileDescriptor(fd);

dupFileDescriptor8+

static dupFileDescriptor(fd: number) :number

復制給定的文件描述符。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
fdnumber表示已存在的文件描述符。

返回值:

類型說明
number返回新的文件描述符。

示例:

import fileio from '@ohos.fileio';
let filePath = "path/to/file";
let fd = fileio.openSync(filePath, 0o2| 0o100, 0o666);
let newFd = rpc.MessageParcel.dupFileDescriptor(fd);

containFileDescriptors8+

containFileDescriptors(): boolean

檢查此MessageParcel對象是否包含文件描述符。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
boolean如果此MessageParcel對象包含文件描述符,則返回true;否則返回false。

示例:

import fileio from '@ohos.fileio';
let parcel = new rpc.MessageParcel();
let filePath = "path/to/file";
let r1 = parcel.containFileDescriptors();
let fd = fileio.openSync(filePath, 0o2| 0o100, 0o666);
let writeResult = parcel.writeFileDescriptor(fd);
console.log("RpcTest: parcel writeFd result is : " + writeResult);
let containFD = parcel.containFileDescriptors();
console.log("RpcTest: parcel after write fd containFd result is : " + containFD);

writeFileDescriptor8+

writeFileDescriptor(fd: number): boolean

寫入文件描述符到MessageParcel。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
fdnumber文件描述符。

返回值:

類型說明
boolean如果操作成功,則返回true;否則返回false。

示例:

import fileio from '@ohos.fileio';
let parcel = new rpc.MessageParcel();
let filePath = "path/to/file";
let fd = fileio.openSync(filePath, 0o2| 0o100, 0o666);
let writeResult = parcel.writeFileDescriptor(fd);
console.log("RpcTest: parcel writeFd result is : " + writeResult);

readFileDescriptor8+

readFileDescriptor(): number

從MessageParcel中讀取文件描述符。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回文件描述符。

示例:

import fileio from '@ohos.fileio';
let parcel = new rpc.MessageParcel();
let filePath = "path/to/file";
let fd = fileio.openSync(filePath, 0o2| 0o100, 0o666);
let writeResult = parcel.writeFileDescriptor(fd);
let readFD = parcel.readFileDescriptor();
console.log("RpcTest: parcel read fd is : " + readFD);

writeAshmem8+

writeAshmem(ashmem: Ashmem): boolean

將指定的匿名共享對象寫入此MessageParcel。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
ashmemAshmem要寫入MessageParcel的匿名共享對象。

返回值:

類型說明
boolean如果匿名共享對象成功寫入此MessageParcel,則返回true;否則返回false。

示例:

let parcel = new rpc.MessageParcel();
let ashmem = rpc.Ashmem.createAshmem("ashmem", 1024);
let isWriteSuccess = parcel.writeAshmem(ashmem);
console.log("RpcTest: write ashmem to result is : " + isWriteSuccess);

readAshmem8+

readAshmem(): Ashmem

從MessageParcel讀取匿名共享對象。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
Ashmem返回匿名共享對象。

示例:

let parcel = new rpc.MessageParcel();
let ashmem = rpc.Ashmem.createAshmem("ashmem", 1024);
let isWriteSuccess = parcel.writeAshmem(ashmem);
console.log("RpcTest: write ashmem to result is : " + isWriteSuccess);
let readAshmem = parcel.readAshmem();
console.log("RpcTest: read ashmem to result is : " + readAshmem);

getRawDataCapacity8+

getRawDataCapacity(): number

獲取MessageParcel可以容納的最大原始數據量。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
number返回MessageParcel可以容納的最大原始數據量,即128 Mb。

示例:

let parcel = new rpc.MessageParcel();
let result = parcel.getRawDataCapacity();
console.log("RpcTest: parcel get RawDataCapacity result is : " + result);

writeRawData8+

writeRawData(rawData: number[], size: number): boolean

將原始數據寫入MessageParcel對象。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
rawDatanumber[]要寫入的原始數據。
sizenumber發送的原始數據大小,以字節為單位。

返回值:

類型說明
boolean如果操作成功,則返回true;否則返回false。

示例:

let parcel = new rpc.MessageParcel();
let arr = [1, 2, 3, 4, 5];
let isWriteSuccess = parcel.writeRawData(arr, arr.length);
console.log("RpcTest: parcel write raw data result is : " + isWriteSuccess);

readRawData8+

readRawData(size: number): number[]

從MessageParcel讀取原始數據。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
sizenumber要讀取的原始數據的大小。

返回值:

類型說明
number[]返回原始數據(以字節為單位)。

示例:

let parcel = new rpc.MessageParcel();
let arr = [1, 2, 3, 4, 5];
let isWriteSuccess = parcel.writeRawData(arr, arr.length);
console.log("RpcTest: parcel write raw data result is : " + isWriteSuccess);
let result = parcel.readRawData(5);
console.log("RpcTest: parcel read raw data result is : " + result);

Sequenceable

在進程間通信(IPC)期間,將類的對象寫入MessageParcel并從MessageParcel中恢復它們。

marshalling

marshalling(dataOut: MessageParcel): boolean

將此可序列對象封送到MessageParcel中。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataOut[MessageParcel]可序列對象將被封送到的MessageParcel對象。

返回值:

類型說明
boolean如果封送成功,則返回true;否則返回false。

示例:

class MySequenceable {
    num: number;
    str: string;
    constructor(num, str) {
        this.num = num;
        this.str = str;
    }
    marshalling(messageParcel) {
        messageParcel.writeInt(this.num);
        messageParcel.writeString(this.str);
        return true;
    }
    unmarshalling(messageParcel) {
        this.num = messageParcel.readInt();
        this.str = messageParcel.readString();
        return true;
    }
}
let sequenceable = new MySequenceable(1, "aaa");
let data = rpc.MessageParcel.create();
let result = data.writeSequenceable(sequenceable);
console.log("RpcClient: writeSequenceable is " + result);
let ret = new MySequenceable(0, "");
let result2 = data.readSequenceable(ret);
console.log("RpcClient: readSequenceable is " + result2);

unmarshalling

unmarshalling(dataIn: MessageParcel) : boolean

從MessageParcel中解封此可序列對象。

系統能力 :SystemCapability.Communication.IPC.Core

參數:

參數名類型必填說明
dataIn[MessageParcel]已將可序列對象封送到其中的MessageParcel對象。

返回值:

類型說明
boolean如果可序列化成功,則返回true;否則返回false。

示例:

class MySequenceable {
    num: number;
    str: string;
    constructor(num, str) {
        this.num = num;
        this.str = str;
    }
    marshalling(messageParcel) {
        messageParcel.writeInt(this.num);
        messageParcel.writeString(this.str);
        return true;
    }
    unmarshalling(messageParcel) {
        this.num = messageParcel.readInt();
        this.str = messageParcel.readString();
        return true;
    }
}
let sequenceable = new MySequenceable(1, "aaa");
let data = rpc.MessageParcel.create();
let result = data.writeSequenceable(sequenceable);
console.log("RpcClient: writeSequenceable is " + result);
let ret = new MySequenceable(0, "");
let result2 = data.readSequenceable(ret);
console.log("RpcClient: readSequenceable is " + result2);

IRemoteBroker

遠端對象的代理持有者。用于獲取代理對象。

asObject

asObject(): IRemoteObject

需派生類實現,獲取代理或遠端對象。

系統能力 :SystemCapability.Communication.IPC.Core

返回值:

類型說明
[IRemoteObject]如果調用者是[RemoteObject]對象,則直接返回本身;如果調用者是[RemoteProxy]對象,則返回它的持有者[IRemoteObject]。

示例:

class TestAbility extends rpc.RemoteObject {
    asObject() {
        return this;
    }
}

示例:

class TestProxy {
    remote: rpc.RemoteObject;
    constructor(remote) {
        this.remote = remote;
    }
    asObject() {
        return this.remote;
    }
}

DeathRecipient

用于訂閱遠端對象的死亡通知。當被訂閱該通知的遠端對象死亡時,本端可收到消息,調用[onRemoteDied]接口。遠端對象死亡可以為遠端對象所在進程死亡,遠端對象所在設備關機或重啟,當遠端對象與本端對象屬于不同設備時,也可為遠端對象離開組網時。

onRemoteDied

onRemoteDied(): void

HarmonyOS與OpenHarmony鴻蒙文檔籽料:mau123789是v直接拿

搜狗高速瀏覽器截圖20240326151450.png

在成功添加死亡通知訂閱后,當遠端對象死亡時,將自動調用本方法。

系統能力 :SystemCapability.Communication.IPC.Core

示例:

class MyDeathRecipient {
    onRemoteDied() {
        console.log("server died");
    }
}

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 鴻蒙
    +關注

    關注

    57

    文章

    2392

    瀏覽量

    43048
收藏 人收藏

    評論

    相關推薦

    HarmonyOS跨進程通信—IPC與RPC通信開發

    一、IPC與RPC通信概述 基本概念 IPC(Inter-Process Communication)與RPC(Remote Procedure Call)用于實現跨進程通信,不同的是
    的頭像 發表于 02-02 17:47 ?1352次閱讀
    HarmonyOS跨進程<b class='flag-5'>通信</b>—IPC與<b class='flag-5'>RPC</b><b class='flag-5'>通信</b><b class='flag-5'>開發</b>

    TSMaster RPC 基礎入門:編程指導和使用說明

    另一臺計算機上的程序或服務,就像調用本地的程序一樣。RPC的主要目的是簡化分布式計算,使得開發者無需關注底層的網絡通信細節。2.什么情況下需要了解此文章?用戶基于T
    的頭像 發表于 07-13 08:21 ?950次閱讀
    TSMaster <b class='flag-5'>RPC</b> 基礎入門:編程指導和使用說明

    鴻蒙OS跨進程IPC與RPC通信

    IPC通信結束后,使用featureAbility的接口斷開連接。 import rpc from \"@ohos.rpc\" import featureAbility
    發表于 02-17 14:20

    鴻蒙原生應用元服務-訪問控制(權限)開發校驗環節

    rpc from \'@ohos.rpc\' class Stub extends rpc.RemoteObject { onRemoteRequest(code, data, reply
    發表于 04-22 17:52

    RPC的結構原理是什么?

    遠程過程調用(RPC)是一個協議,程序可以使用這個協議請求網絡中另一臺計算機上某程序的服務而不需知道網絡細節。(過程調用有時也稱作函數調用,或子例行程序調用。)RPC使用client/server模型。請求程序是client,而服務提供程序則為server。
    發表于 10-12 10:43

    直連設備怎么rpc雙向控制

    Thing***oard提供非常強大的可視化部件,除了圖表、地圖車聯網外,還有控制部件,通過mqtt rpc可以輕松實現平臺 -- 設備端 設備到平臺雙向數據傳輸及控制。Thingboard 連接
    發表于 07-12 06:55

    RPC是什么

    RPC是什么?RabbitMQ又是什么?
    發表于 10-08 09:24

    【學習打卡】OpenHarmony的RPC連接介紹

    OpenHarmony的示例中有關于RPC連接的演示,展示了同一設備中前后臺的數據交互,用戶前臺選擇相應的商品與數目,后臺計算出結果,回傳給前臺展示。今天我們就介紹以下RPC連接相關的
    發表于 07-28 18:13

    使用matlab和freemaster rpc-server進行自動數據記錄,無法打開通信端口的原因?

    rpc-server api,或者至少我找不到它。 到目前為止它已經工作,我可以讀寫變量并停止通信,但是開始通信的結構不起作用。這里有人知道這有什么問題嗎?jsonMessage2(1
    發表于 04-21 07:04

    【中秋國慶不斷更】HarmonyOS跨進程通信—IPC與RPC通信開發指導

    ,使用Proxy與遠端通信 二、IPC與RPC通信開發指導 場景介紹 IPC/RPC的主要工作是讓運行在不同進程的Proxy和Stub互相
    發表于 09-27 15:48

    什么是RPC

    什么是RPC   英文原義:Remote Procedure Call Protocol 中文釋義:(RFC-1831)遠過程調用協議 注  解:一種通過
    發表于 02-23 11:48 ?922次閱讀

    什么是RPC?為什么需要RPC

    首先要明確一點:RPC可以用HTTP協議實現,并且用HTTP是建立在 TCP 之上最廣泛使用的 RPC,但是互聯網公司往往用自己的私有協議,比如鵝廠的JCE協議,私有協議不具備通用性為什么還要用呢?因為相比于HTTP協議,RPC
    的頭像 發表于 04-16 12:49 ?1.5w次閱讀
    什么是<b class='flag-5'>RPC</b>?為什么需要<b class='flag-5'>RPC</b>?

    OpenDaylight中的RPC &amp; Notification是什么

    我們將介紹RPC和Notification,并從進程內外的通信開始,著重介紹遠程過程調用和發布-訂閱機制,然后分析MD-SAL的通信交互過程。
    的頭像 發表于 02-14 15:15 ?1004次閱讀
    OpenDaylight中的<b class='flag-5'>RPC</b> &amp; Notification是什么

    RPC 和 REST 區別是什么

    01. 既 REST ,何 RPC ? 在 OpenStack 里的進程間通信方式主要有兩種,一種是基于HTTP協議的RESTFul API方式,另一種則是RPC調用。 那么這兩種方式在應用場景上有
    的頭像 發表于 11-02 10:40 ?3222次閱讀
    <b class='flag-5'>RPC</b> 和 REST 區別是什么

    鴻蒙Ability Kit(程序框架服務)【Ability與ServiceExtensionAbility通信

    本示例展示通過[IDL的方式]和?[@ohos.rpc]?等接口實現了Ability與ServiceExtensionAbility之間的通信
    的頭像 發表于 06-05 09:28 ?533次閱讀
    <b class='flag-5'>鴻蒙</b>Ability Kit(程序框架服務)【Ability與ServiceExtensionAbility<b class='flag-5'>通信</b>】
    娱乐城百家乐可以代理吗| 百家乐全部规则| 澳门百家乐官网几副牌| 百家乐赌场娱乐| 百家乐官网游戏什么时间容易出| 黄金城百家乐官网游戏| 顶级赌场官方网站| 大三元百家乐官网的玩法技巧和规则 | 新全讯网a3322.com| 模拟百家乐游戏软件| 杨公24山属性| 海立方百家乐官网的玩法技巧和规则 | 阴宅风水24山分房| 狮威百家乐官网赌场娱乐网规则| 百家乐官网赌博大揭密| 鹰潭市| 青神县| 蒲城县| 百家乐官网食杂店| 新澳博百家乐官网现金网| 在线百家乐| 循化| 网上百家乐官网开户送现金| 百家乐官网玩法皇冠现金网| 蓝盾百家乐官网具体玩法技巧| 百家乐官网对冲套红利| 网上的百家乐官网是假的吗| 做生意人的风水| 百家乐中的小路怎样| 百家乐博彩的玩法技巧和规则| 百家乐官网看图赢钱| 正规百家乐游戏下载| 菲律宾百家乐娱乐| 百家乐桌布呢布| 三宝娱乐| 百家乐官网技巧之写路| 张家港百家乐官网赌博| 百家乐外挂程式| 百家乐娱乐城有几家| 威尼斯人娱乐网网上百家乐的玩法技巧和规则 | 澳门百家乐官网心得玩博|