(19)【発行国】日本国特許庁(JP)
(12)【公報種別】特許公報(B2)
(11)【特許番号】
(24)【登録日】2022-03-28
(45)【発行日】2022-04-05
(54)【発明の名称】コード実行方法、装置、レンダリングデバイス、記憶媒体、及びプログラム
(51)【国際特許分類】
G06F 8/41 20180101AFI20220329BHJP
G06F 9/455 20060101ALI20220329BHJP
G06F 9/445 20180101ALI20220329BHJP
G06F 3/048 20220101ALI20220329BHJP
【FI】
G06F8/41
G06F9/455 150
G06F9/445
G06F3/048
(21)【出願番号】P 2020088761
(22)【出願日】2020-05-21
【審査請求日】2020-05-21
(31)【優先権主張番号】201911001932.7
(32)【優先日】2019-10-21
(33)【優先権主張国・地域又は機関】CN
(73)【特許権者】
【識別番号】512015127
【氏名又は名称】バイドゥ オンライン ネットワーク テクノロジー(ペキン) カンパニー リミテッド
(73)【特許権者】
【識別番号】521235408
【氏名又は名称】シャンハイ シャオドゥ テクノロジー カンパニー リミテッド
(74)【代理人】
【識別番号】100079108
【氏名又は名称】稲葉 良幸
(74)【代理人】
【識別番号】100109346
【氏名又は名称】大貫 敏史
(74)【代理人】
【識別番号】100117189
【氏名又は名称】江口 昭彦
(74)【代理人】
【識別番号】100134120
【氏名又は名称】内藤 和彦
(74)【代理人】
【識別番号】100108213
【氏名又は名称】阿部 豊隆
(72)【発明者】
【氏名】エルブイ,シェン
(72)【発明者】
【氏名】ワン,ジエ
(72)【発明者】
【氏名】ワン,ヤン
(72)【発明者】
【氏名】チャン,ユアンハン
(72)【発明者】
【氏名】カオ,ホンウェイ
【審査官】北川 純次
(56)【参考文献】
【文献】米国特許出願公開第2006/0107222(US,A1)
【文献】特表2016-514880(JP,A)
【文献】内藤 謙一,Web全盛の今だからおぼえたい 基本からしっかり学ぶJavaScript,日経ソフトウエア,日本,日経BP社,2016年04月24日,Vol. 19, No. 7,pp.102-109
(58)【調査した分野】(Int.Cl.,DB名)
G06F 8/40-8/54
G06F 9/44-9/455
G06F 3/048-3/0489
(57)【特許請求の範囲】
【請求項1】
仮想マシンに適用されるコード実行方法であって、
実行エンジンがオブジェクトコードをロードして得られた初期化指令を、前記実行エンジンから受信することと、
前記初期化指令に基づいて、
ラッパーモジュールにおいて前記オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信することと、
前記ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルにより前記オブジェクトコードに対応する実行コードを得ることと、
前記実行コードを、前記実行エンジンに実行させるように送信することと、含む、
ことを特徴するコード実行方法。
【請求項2】
前記初期化指令には、初期化すべきラッパーオブジェクトの識別子が含まれており、
前記初期化指令に基づいて、前記オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信することは、
登録すべきラッパーオブジェクトの識別子を含む前記登録指令を前記登録コンポーネントに送信し、前記登録コンポーネントが、登録すべきラッパーオブジェクトの識別子に基づいて、ラッパーモジュールにおいて対応するラッパーオブジェクトを作成すること、を含む、
ことを特徴とする請求項1に記載のコード実行方法。
【請求項3】
前記実行エンジンが前記実行コードを実行して得られた実行指令を、前記実行エンジンから受信することと、
前記実行指令に基づいて、前記ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信することと、をさらに含む、
ことを特徴とする請求項1に記載のコード実行方法。
【請求項4】
前記実行指令には、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、
前記呼び出しコンポーネントは、インヴォーカーであり、
前記実行指令に基づいて、前記ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信することは、
実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む前記呼び出し指令を前記インヴォーカーに送信し、前記インヴォーカーは、前記オペレーティングシステムにおいて実行すべきラッパーオブジェクトに対応するネイティブコードを実行するように、前記ラッパーモジュールにおいて、実行すべきラッパーオブジェクトの識別子に対応するラッパーオブジェクトを検索して得られた後、実行すべきラッパーオブジェクトのメソッド名に対応するメソッドを呼び出し、実行すべきラッパーオブジェクトのパラメータをロードすること、を含む、
ことを特徴とする請求項3に記載のコード実行方法。
【請求項5】
初期化指令を実行エンジンから受信することは、
ブリッジを介して前記初期化指令を前記実行エンジンから受信すること、を含む、
ことを特徴とする請求項1~4のいずれか1項に記載のコード実行方法。
【請求項6】
前記実行コードを、前記実行エンジンに実行させるように送信することは、
ブリッジを介して前記実行コードを前記実行エンジンに実行させるように送信すること、を含む、
ことを特徴とする請求項1~4のいずれか1項に記載のコード実行方法。
【請求項7】
前記ラッパーモジュールが前記オペレーティングシステムから取得した実行結果を含むフィードバック情報を、前記ラッパーモジュールから受信することと、
前記フィードバック情報を前記実行エンジンに送信することと、をさらに含む、
ことを特徴とする請求項1~4のいずれか1項に記載のコード実行方法。
【請求項8】
仮想マシンに適用されるコード実行装置であって、
実行エンジンがオブジェクトコードをロードして得られた初期化指令を、前記実行エンジンから受信する第1受信ユニットと、
前記初期化指令に基づいて、
ラッパーモジュールにおいて前記オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信する第1送信ユニットと、
前記ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルにより前記オブジェクトコードに対応する実行コードを得るコンパイルユニットと、
前記実行コードを、前記実行エンジンに実行させるように送信する第2送信ユニットと、を備える、
ことを特徴するコード実行装置。
【請求項9】
前記初期化指令には、初期化すべきラッパーオブジェクトの識別子が含まれており、
前記第1送信ユニットは、登録すべきラッパーオブジェクトの識別子を含む前記登録指令を前記登録コンポーネントに送信することにさらに用いられ、
前記登録コンポーネントは、登録すべきラッパーオブジェクトの識別子に基づいて、ラッパーモジュールにおいて対応するラッパーオブジェクトを作成する、
ことを特徴とする請求項8に記載のコード実行装置。
【請求項10】
前記実行エンジンが前記実行コードを実行して得られた実行指令を、前記実行エンジンから受信する第2受信ユニットと、
前記実行指令に基づいて、前記ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信する第3送信ユニットと、をさらに備える、
ことを特徴とする請求項8に記載のコード実行装置。
【請求項11】
前記実行指令には、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、
前記呼び出しコンポーネントは、インヴォーカーであり、
前記第3送信ユニットは、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む前記呼び出し指令を前記インヴォーカーに送信することにさらに用いられ、
前記インヴォーカーは、前記ラッパーモジュールにおいて、前記オペレーティングシステムにおいて実行すべきラッパーオブジェクトに対応するネイティブコードを実行するように、実行すべきラッパーオブジェクトの識別子に対応するラッパーオブジェクトを検索して得られた後、実行すべきラッパーオブジェクトのメソッド名に対応するメソッドを呼び出し、実行すべきラッパーオブジェクトのパラメータをロードする、
ことを特徴とする請求項10に記載のコード実行装置。
【請求項12】
前記ラッパーモジュールが前記オペレーティングシステムから取得した実行結果を含むフィードバック情報を、前記ラッパーモジュールから受信する第3受信ユニットと、
前記フィードバック情報を前記実行エンジンに送信する第4送信ユニットと、をさらに備える、
ことを特徴とする請求項8~11のいずれか1項に記載のコード実行装置。
【請求項13】
実行エンジンと、仮想マシンと、登録コンポーネントと、を備え、
前記実行エンジンは、オブジェクトコードをロードして得られた初期化指令を、仮想マシンに送信し、前記仮想マシンから返された、前記オブジェクトコードに対応する実行コードを受信することに用いられ、
前記仮想マシンは、請求項1~7のいずれかの1項に記載のコード実行方法を実行することに用いられ、
前記登録コンポーネントは、前記オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を前記仮想マシンから受信することに用いられる、
ことを特徴するレンダリングデバイス。
【請求項14】
前記実行エンジンは、前記実行コードを実行して得られた実行指令を前記仮想マシンに送信することにさらに用いられ、
前記レンダリングデバイスは、
ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を前記仮想マシンから受信する呼び出しコンポーネントと、
前記オブジェクトコードの実行に要する少なくとも1つのラッパーオブジェクトを含むラッパーモジュールと、をさらに備える、
ことを特徴とする請求項13に記載のレンダリングデバイス。
【請求項15】
前記実行エンジンからの前記初期化指令を前記仮想マシンに送信し、前記仮想マシンからの前記実行コードを前記実行エンジンに送信するブリッジをさらに備える、
ことを特徴とする請求項13または14に記載のレンダリングデバイス。
【請求項16】
1つ又は複数のプロセッサと、
前記1つ又は複数のプロセッサに通信接続されるメモリと、を備え、
前記メモリには、前記1つ又は複数のプロセッサにより実行可能なコマンドを記憶しており、
前記1つ又は複数のプロセッサは、前記1つ又は複数のコマンドを実行する場合、請求項1~7のいずれか1項に記載のコード実行方法を実行させる、
ことを特徴とする電子デバイス。
【請求項17】
請求項1~7のいずれか1項に記載のコード実行方法をコンピュータに実行させるためのコンピュータコマンドを記憶した非一過性のコンピュータ可読記憶媒体。
【請求項18】
コンピュータにおいて、プロセッサにより実行される場合、請求項1~7のいずれか1項に記載のコード実行方法を実現することを特徴とするプログラム。
【発明の詳細な説明】
【技術分野】
【0001】
本発明は、コンピュータ技術分野に関し、特にコンピュータ表示技術分野に関する。
【背景技術】
【0002】
レンダリングエンジンの主な役割は、リソースファイルをユーザから見える結果に変換することである。従来技術では、レンダリング効果を実現するために、デバイス端末においてレンダリングエンジンにより、リソースファイルをコンパイルしている。但し、レンダリングエンジンのコンパイルには、大量の計算を行う必要があるため、レンダリング速度が遅くなるなどの問題が存在する。
【発明の概要】
【発明が解決しようとする課題】
【0003】
本発明は、従来技術における1つ又は複数の技術的課題を解決するためのコード実行方法、装置、レンダリングデバイス、及び記憶媒体を提供する。
【課題を解決するための手段】
【0004】
本発明は、コード実行方法を提供し、当該コード実行方法は、仮想マシンに適用し、
実行エンジンがオブジェクトコードをロードして得られた初期化指令を、実行エンジンから受信することと、
初期化指令に基づいて、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信することと、
ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得ることと、
実行コードを、実行エンジンに実行させるように送信することと、含む。 本発明の実施形態によれば、仮想マシンが登録コンポーネントに既にラッピングされたラッパーオブジェクトを作成させるように制御し、仮想マシンにオブジェクトコードのコンパイル作業を実行させることにより、実行エンジンが主にコードの実行を制御するようになるため、コードの実行効率を向上させることができる。
【0005】
1つの実施形態において、初期化指令には、初期化すべきラッパーオブジェクトの識別子が含まれており、初期化指令に基づいて、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信することは、
登録すべきラッパーオブジェクトの識別子を含む登録指令を登録コンポーネントに送信し、登録コンポーネントが、登録すべきラッパーオブジェクトの識別子に基づいて、ラッパーモジュールにおいて対応するラッパーオブジェクトを作成すること、を含む。
【0006】
上記の実施形態において、仮想マシンが登録コンポーネントにラッパーモジュールにおけるラッパーオブジェクトを作成させるように制御することにより、ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得ることができる。これにより、コードのコンパイル効率及び実行効率の向上に役立つことができる。
【0007】
1つの実施形態において、該コード実行方法は、
実行エンジンが実行コードを実行して得られた実行指令を、実行エンジンから受信することと、実行指令に基づいて、ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信することと、をさらに含む。
【0008】
上記の実施形態において、仮想マシンは、実行エンジンの実行指令を受信した後に、呼び出しコンポーネントに、作成されたラッパーオブジェクトを呼び出させるように制御し、さらにオペレーティングシステムに、呼び出されたラッパーオブジェクトに対応するネイティブコードを実行させることができる。このように、コードのコンパイル及び実行が分けられているため、コードのコンパイル効率及び実行効率を向上させることができる。
【0009】
1つの実施形態において、実行指令には、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、前記呼び出しコンポーネントは、インヴォーカーであり、実行指令に基づいて、ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信することは、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む呼び出し指令をインヴォーカーに送信し、インヴォーカーは、オペレーティングシステムにおいて実行すべきラッパーオブジェクトに対応するネイティブコードを実行するように、ラッパーモジュールにおいて、実行すべきラッパーオブジェクトの識別子に対応するラッパーオブジェクトを検索して得られた後、実行すべきラッパーオブジェクトのメソッド名に対応するメソッドを呼び出し、実行すべきラッパーオブジェクトのパラメータをロードすること、を含む。
【0010】
上記の実施形態において、オペレーティングシステムにおいて各ラッパーオブジェクトに対応するネイティブコードを実行するために、仮想マシンがラッパーオブジェクトの識別子、メソッド名、及びパラメータを用いてラッパーモジュールにおいて各ラッパーオブジェクトを呼び出させるようにインヴォーカーを制御することにより、コードのマッピング及び呼び出しを分けることができ、複数のラッパーオブジェクトを連続的に呼び出すことができるため、オブジェクトの再利用を実現し、さらにコードの実行効率を向上させることができる。
【0011】
1つの実施形態において、初期化指令を実行エンジンから受信することは、ブリッジを介して初期化指令を実行エンジンから受信することを含む。
【0012】
1つの実施形態において、実行コードを、実行エンジンに実行させるように送信することは、ブリッジを介して実行コードを実行エンジンに実行させるように送信することを含む。
【0013】
上記の実施形態において、実行エンジンと仮想マシンとの間に、ブリッジを介してメッセージのやり取りを行うことにより、オブジェクトコードとネイティブコードとのメッセージ転送を実現することができる。これにより、オペレーティングシステム自体の能力を十分に活用するため、コードの実行効率を向上させるとともに、安全性を確保することができる。
【0014】
1つの実施形態において、該コード実行方法は、ラッパーモジュールがオペレーティングシステムから取得した実行結果を含むフィードバック情報を、ラッパーモジュールから受信することと、
フィードバック情報を実行エンジンに送信することと、をさらに含む。
【0015】
上記の実施形態において、仮想マシンは、ラッパーモジュールのフィードバック情報を受信することができ、仮想マシンを介してオペレーティングシステムの実行結果などを実行エンジンにフィードバックすることで、実行エンジンにフィードバック情報と合わせて、後続の実行コードを続けて実行させることができる。 本発明の実施形態は、コード実行装置をさらに提供し、当該コード実行装置は、仮想マシンに適用し、
実行エンジンがオブジェクトコードをロードして得られた初期化指令を、実行エンジンから受信するための第1受信ユニットと、
初期化指令に基づいて、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信するための第1送信ユニットと、
ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得るためのコンパイルユニットと、
実行コードを実行エンジンに実行させるように送信するための第2送信ユニットと、を備える。
【0016】
1つの実施形態において、初期化指令には、初期化すべきラッパーオブジェクトの識別子が含まれており、第1送信ユニットは、登録すべきラッパーオブジェクトの識別子を含む登録指令を登録コンポーネントに送信することにさらに用いられ、登録コンポーネントは、登録すべきラッパーオブジェクトの識別子に基づいて、ラッパーモジュールにおいて対応するラッパーオブジェクトを作成する。 1つの実施形態において、該コード実行装置は、
実行エンジンが実行コードを実行して得られた実行指令を、実行エンジンから受信するための第2受信ユニットと、
実行指令に基づいて、ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信する第3送信ユニットと、をさらに備える。
【0017】
1つの実施形態において、実行指令には、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、呼び出しコンポーネントは、インヴォーカーであり、第3送信ユニットは、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む呼び出し指令をインヴォーカーに送信することにさらに用いられ、インヴォーカーは、オペレーティングシステムにおいて実行すべきラッパーオブジェクトに対応するネイティブコードを実行するように、ラッパーモジュールにおいて、実行すべきラッパーオブジェクトの識別子に対応するラッパーオブジェクトを検索して得られた後、実行すべきラッパーオブジェクトのメソッド名に対応するメソッドを呼び出し、実行すべきラッパーオブジェクトのパラメータをロードする。
【0018】
1つの実施形態において、該コード実行装置は、
ラッパーモジュールにより前記オペレーティングシステムから取得した実行結果を含むフィードバック情報を、ラッパーモジュールから受信するための第3受信ユニットと、
フィードバック情報を実行エンジンに送信するための第4送信ユニットと、をさらに備える。
【0019】
本発明の実施形態は、レンダリングデバイスをさらに提供し、当該レンダリングデバイスは、実行エンジンと、仮想マシンと、登録コンポーネントと、を備え、
実行エンジンは、オブジェクトコードをロードして得られた初期化指令を、仮想マシンに送信し、仮想マシンから返された、オブジェクトコードに対応する実行コードを受信することに用いられ、
仮想マシンは、本発明のいずれか1つの実施形態に記載のコード実行方法を実行することに用いられ、
登録コンポーネントは、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を仮想マシンから受信することに用いられる。
【0020】
1つの実施形態において、実行エンジンは、実行コードを実行して得られた実行指令を仮想マシンに送信することにさらに用いられ、
レンダリングデバイスは、
ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を仮想マシンから受信するための呼び出しコンポーネントと、
オブジェクトコードの実行に要する少なくとも1つのラッパーオブジェクトを含むラッパーモジュールと、をさらに備える。
【0021】
1つの実施形態において、当該レンダリングデバイスは、実行エンジンからの初期化指令を仮想マシンに送信し、仮想マシンからの実行コードを実行エンジンに送信するためのブリッジをさらに備える。
【0022】
本発明の実施形態は、電子デバイスをさらに提供し、当該電子デバイスは、
1つ又は複数のプロセッサと、
1つ又は複数のプロセッサに通信接続されるメモリと、を含み、
メモリには、1つ又は複数のプロセッサにより実行可能なコマンドを記憶しており、1つ又は複数のプロセッサは、1つ又は複数のコマンドを実行する場合、本発明のいずれか1つの実施形態におけるコード実行方法を実行させる。
【0023】
本発明の実施形態は、コンピュータコマンドが記憶された非一過性のコンピュータ可読記憶媒体をさらに提供し、当該コンピュータコマンドはコンピュータに本発明のいずれか1つの実施形態におけるコード実行方法を実行させるために用いられる。
【発明の効果】
【0024】
上記本発明の実施形態のうちの少なくとも1つの実施形態は、下記のメリット及び有益な効果を有する。 本発明の実施形態に係るコード実行方法によれば、仮想マシンが登録コンポーネントに既にラッピングされたラッパーオブジェクトを作成させるように制御し、仮想マシンにオブジェクトコードのコンパイル作業を実行させることにより、実行エンジンが主にコードの実行を制御するようになるため、コードの実行効率を向上させることができる。
【0025】
上記の選択可能な実施形態によるその他の効果は、具体的な実施形態とあわせて後述する。
【図面の簡単な説明】
【0026】
添付図面は、本開示の理解を促すためのものであり、いかなる限定を目的としない。
【
図1】本発明の実施形態によるコード実行方法のフローチャートである。
【
図2A】本発明の実施形態によるコード実行方法におけるコードを示す図である。
【
図2B】本発明の実施形態によるコード実行方法におけるコードを示す図である。
【
図3】本発明の実施形態によるコード実行方法の適用例を示す図である。
【
図4】本発明の実施形態によるコード実行方法のフローチャートである。
【
図5】本発明の実施形態によるコード実行方法のフローチャートである。
【
図6】本発明の実施形態によるコード実行装置の構成のブロック図である。
【
図7】本発明の実施形態によるコード実行装置の構成のブロック図である。
【
図8】本発明の実施形態によるレンダリングデバイスの構成のブロック図である。
【
図9】本発明の実施形態によるレンダリングデバイスの構成のブロック図である。
【
図10】本発明の実施形態によるレンダリングデバイスのラッパーインターフェースを示す図である。
【
図11】本発明の実施形態によるレンダリングデバイスの適用シーンを示す図である。
【
図12】本発明の実施形態によるコード実行方法を実現するための電子デバイスのブロック図である。
【発明を実施するための形態】
【0027】
以下、図面を参照しながら本発明の例示的な実施形態を説明するが、本発明の実施形態の様々な詳細が理解を容易にするために含まれており、それらは単なる例示的と考えられるべきである。したがって、当業者は、本発明の範囲及び旨から逸脱することなく、本発明明細書に記載された実施形態に対して様々な変更及び修正を行うことができることを理解すべきである。同様に、以下の説明では、公知な機能及び構造についての説明は、明瞭かつ簡明のために省略される。
【0028】
図1は、本発明の実施形態によるコード実行方法のフローチャートである。
図1に示すように、このコード実行方法は、仮想マシンに適用することができ、以下のステップS11~S14を含むことができる。
【0029】
ステップS11において、実行エンジンがオブジェクトコードをロードして得られた初期化指令を、実行エンジンから受信する。
【0030】
ステップS12において、初期化指令に基づいて、ラッパーモジュールにおいてオブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信する。ここで、ラッパーオブジェクトは、オペレーティングシステムのネイティブコードに基づいて、事前にラッピングして得られたものである。
【0031】
ステップS13において、ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得る。
【0032】
ステップS14において、実行コードを実行エンジンに実行させるように送信する。
【0033】
本発明の実施形態では、実行エンジンは、オブジェクトコードを初期化させ、オブジェクトコードに対応する実行コードを実行することができる。オブジェクトコードは、例えば、レンダリング効果などの機能を実現するのに必要なコードを含んでもよい。例えば、
図2Aに示すように、オブジェクトコードには、あるイメージコンポーネント(Image,ピクチャコンポーネントとも言う)のレンダリングに要するコードが含まれてもよく、このコードには、当該イメージコンポーネントのタイプ「type」、イメージアドレス「source」、伸縮方式「scale」、幅「width」、高さ「height」などの属性が含まれてもよい。また、
図2Bに示すように、オブジェクトコードには、あるスライドウィンドウコンポーネント(ScrollView)のレンダリングに要するコードが含まれてもよく、このコードには、当該スライドウィンドウコンポーネントのタイプ「type」、項目「item」などの属性が含まれてもよく、方向「direction」、幅「width」、高さ「height」などの属性が含まれてもよい。
【0034】
一例では、サーバにおいてレンダリングテンプレートを用いて、デバイス端末の実行しやすいオブジェクトコードを生成することができる。デバイス端末は、オブジェクトコードを受信した後、これらのコードを実行し、スクリーンに表示することができる。
図3に示すように、実行エンジン31は、JavaScript(JSと略称される)フォーマットのオブジェクトコード、例えばプロダクトコード(product code)を受信した後に、当該オブジェクトコードのロード中において、仮想マシン32(例えば、Atom VM)に初期化指令を送信することができる。
【0035】
本発明の実施形態では、仮想マシンが登録コンポーネントに既にラッピングされたラッパーオブジェクトを作成させるように制御し、仮想マシンにオブジェクトコードのコンパイル作業を実行させることにより、実行エンジンが主にコードの実行を制御するようになるため、コードの実行効率を向上させることができる。レンダリング効果を実現するオブジェクトコードとして、レンダリング速度を向上させ、レンダリング効果を最適化することができる。
【0036】
一実施形態では、初期化指令には、初期化すべきラッパーオブジェクトの識別子が含まれている。他の実施形態では、初期化指令には、ラッパーオブジェクトの識別子に加えて、ラッパーオブジェクトのメソッド名及び/又はパラメータが含まれてもよい。ここで、異なるオブジェクトコードについて、初期化すべきラッパーオブジェクトの数量及びタイプは異なる場合がある。1つのラッパーオブジェクトには、1つまたは複数のメソッド名が含まれてもよく、各メソッド名は、オペレーティングシステムにおける、やり取りに関するある関数名に対応してもよい。例えば、1つのピクチャのラッパーオブジェクトとして、Androidシステムにおいて対応するものは、Image(イメージコンポーネント)となり、イメージリソースを設置する方法は、ImageオペレーティングシステムにおけるsetImageメソッドに対応する。パラメータには、あるメソッド名に対応するメソッドの実行に要するリソース、例えば、あるイメージのユニフォームリソースロケータ(uniform resource locator、URL)アドレスが含まれてもよい。
【0037】
ステップS12において、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、初期化指令に基づいて登録コンポーネントに登録指令を送信することは、登録すべきラッパーオブジェクトの識別子を含む登録指令を登録コンポーネントに送信し、登録コンポーネントが、登録すべきラッパーオブジェクトの識別子に基づいて、ラッパーモジュールにおいて対応するラッパーオブジェクトを作成することを含む。仮想マシンが登録コンポーネントにラッパーモジュールにおいてラッパーオブジェクトを作成させるように制御することにより、ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得るため、コードのコンパイル効率及び実行効率の向上に役立つことができる。
【0038】
他の実施形態では、登録指令には、ラッパーオブジェクトの識別子に加えて、ラッパーオブジェクトのメソッド名及び/又はパラメータが含まれてもよい。また、初期化指令と登録指令との内容やフォーマットは、同じでも異なっていてもよい。つまり、仮想マシンは、受信した初期化指令の内容及びフォーマットを修正して登録コンポーネントに送信してもよいし、修正せずに初期化指令を登録指令として登録コンポーネントに直接転送してもよい。
【0039】
一例では、
図3に示すように、仮想マシン32は、初期化指令を受信した後に、登録指令を登録コンポーネント33、例えば、ラッパーレジストリコンポーネント(Wrapper Registry)に送信してもよい。登録コンポーネント33は、登録指令を受信した後に、ラッパーモジュール(Wrapper)34に作成指令を送信することができ、作成指令には、オブジェクトコードに登録すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれる。ラッパーモジュール34は、この作成指令に基づいて、オブジェクトコードの実行に要するラッパーオブジェクト341を作成することができる。ラッパーオブジェクトのタイプは、複数があり、イメージコンポーネント(Image)、ビューコンポーネント(View)、テキストコンポーネント(Text)、イメージビューコンポーネント(ImageView)、ページコンポーネント(Pager)、ページマネージャコンポーネント(PageManager)、コンテナコンポーネント(Container)、スライドウィンドウコンポーネント(ScrollView)、フレームコンポーネント(Frame)、リストコンポーネント(List)、ネットワークコンポーネント(Network)などを含むが、これに限定されない。
【0040】
一例では、あるオブジェクトコードの一部に対応するラッパーオブジェクトがイメージコンポーネント(Image)である場合、該ラッパーオブジェクトの識別子は、「Image」であってもよく、メソッド名は、setImageであってもよく、パラメータとして、幅、長さ、及びURLアドレスなどを含んでもよい。
【0041】
ラッパーモジュールにおいて各ラッパーオブジェクトを作成することで、各ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係を得ることができる。ラッパーオブジェクトが登録かつ作成された後、ラッパーモジュールがマッピング関係を登録コンポーネントに返し、登録コンポーネントが該マッピング関係を仮想マシンに返し、仮想マシンが該マッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得ることができる。その後、仮想マシンは、該実行コードを実行エンジンに実行させるように送信することができる。
【0042】
一実施形態では、
図4に示すように、当該コード実行方法は、下記のステップS15~S16をさらに含む。
【0043】
ステップS15において、実行エンジンが実行コードを実行して得られた実行指令を、実行エンジンから受信する。
【0044】
ステップS16において、実行指令に基づいて、ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信し、さらにオペレーティングシステムに呼び出されたラッパーオブジェクトに対応するネイティブコードを実行させる。仮想マシンは、実行エンジンの実行指令を受信した後、呼び出しコンポーネントに、作成されたラッパーオブジェクトを呼び出させるように制御し、さらにオペレーティングシステムに、呼び出されたラッパーオブジェクトに対応するネイティブコードを実行させることができる。このように、コードのコンパイルと実行が分けられているため、コードのコンパイル効率及び実行効率を向上させることができる。
【0045】
本発明の実施形態では、オブジェクトコードの実行に要するラッパーオブジェクトは、1つまたは複数ある場合がある。オブジェクトコードの実行に要するラッパーオブジェクトが複数である場合、登録と呼び出しの実行は、シリアルであってよいし、パラレルであってもよい。
図3に示すように、仮想マシン32は、登録コンポーネントによってすべてのラッパーオブジェクトをシリアルに作成した後、インヴォーカー(Invoker)35などの呼び出しコンポーネントによって各ラッパーオブジェクトを呼び出してもよいし、登録コンポーネントによって各ラッパーオブジェクトを作成するプロセスにおいて、呼び出しコンポーネントによって作成されたラッパーオブジェクトをパラレルに呼び出してもよい。
【0046】
一実施形態では、実行指令には、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、呼び出しコンポーネントは、インヴォーカー(Invoker)であり、ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、実行指令に基づいて呼び出しコンポーネントに呼び出し指令を送信する。このステップは、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む呼び出し指令をインヴォーカーに送信することを含む。インヴォーカーは、オペレーティングシステムにおいて実行すべきラッパーオブジェクトに対応するネイティブコードを実行するように、ラッパーモジュールにおいて、実行すべきラッパーオブジェクトの識別子に対応するラッパーオブジェクトを検索して得た後に、実行すべきラッパーオブジェクトのメソッド名に対応するメソッドを呼び出し、実行すべきラッパーオブジェクトのパラメータをロードする。オペレーティングシステムにおいて各ラッパーオブジェクトに対応するネイティブコードを実行するように、仮想マシンが、ラッパーオブジェクトの識別子、メソッド名、及びパラメータを用いてラッパーモジュールにおける各ラッパーオブジェクトの呼び出すように、インヴォーカーを制御することにより識別子、コードのマッピング及び呼び出しを分けることができ、複数のラッパーオブジェクトを連続的に呼び出すことができるため、オブジェクトの再利用を実現し、さらにコードの実行効率を向上させることができる。
【0047】
実行エンジンは、この実行コードの実行において、仮想マシンに実行指令を送信することができる。仮想マシンは、実行指令を受信した後、実行指令におけるラッパーオブジェクトの識別子、メソッド名、及びパラメータに基づいて、インヴォーカーに呼び出し指令を送信することができる。例えば、実行コードの一部に含まれているラッパーオブジェクトの識別子が「Image」、メソッド名がsetImage、パラメータが幅、長さ、URLアドレスである場合、インヴォーカーは、呼び出し指令を受信した後、ラッパーモジュールにおいて、実行すべきラッパーオブジェクトの識別子「Image」に対応するラッパーオブジェクトやイメージコンポーネントを検索して得ることができる。そして、そのイメージコンポーネントのメソッド名に対応するメソッドを呼び出し、そのイメージコンポーネントの長さ、幅、及びURLアドレスにおけるイメージなどをロードする。さらに、オペレーティングシステムにおいてイメージコンポーネントを必要とするネイティブコードを実行することにより、このイメージコンポーネントのレンダリング効果をスクリーンに表示する。
【0048】
本発明の実施形態では、実行指令と呼び出し指令との内容及びフォーマットは、同じであってもよいし、異なっていてもよい。つまり、仮想マシンは、受信した実行指令の内容及びフォーマットを修正して呼び出しコンポーネントに送信してもよいし、修正せずに実行指令を呼び出し指令として呼び出しコンポーネントに直接転送してもよい。
【0049】
実行コードにおいて実行すべき複数のラッパーオブジェクトが含まれている場合、実行エンジンは実行コードの論理的な順序で仮想マシンに複数の実行指令を送信し、さらに、仮想マシンはインヴォーカーに複数の呼び出し指令を送信し、これらのラッパーオブジェクトを順次に呼び出すことができる。例えば、実行すべきラッパーオブジェクトにイメージコンポーネント、スライドウィンドウコンポーネント、及びリストコンポーネントが含まれている場合、実行エンジンは、実行コードの論理的な順序に従って、イメージコンポーネント、スライドウィンドウコンポーネント、リストコンポーネントという順番で表示するようにこれらのコンポーネントの呼び出しを制御することができる。実行エンジンは、仮想マシンとインヴォーカーを介して、この順番でこれらのイメージコンポーネント、スライドウィンドウコンポーネント、及びリストコンポーネントを順次に呼び出すことができる。
【0050】
1つの実施形態では、
図5に示すように、該コード実行方法は、下記のステップS17~S18をさらに含む。
【0051】
ステップS17において、ラッパーモジュールがオペレーティングシステムから取得した実行結果を含むフィードバック情報を、ラッパーモジュールから受信する。
【0052】
ステップS18において、フィードバック情報を実行エンジンに送信する。
【0053】
ラッパーモジュールは、オペレーティングシステムからラッパーオブジェクトに対応するネイティブコードの実行結果を取得した後に、その実行結果を含むフィードバック情報を仮想マシンに送信することができる。オペレーティングシステムに他の変化があり、例えば、システムの電力量が低い場合、ラッパーモジュールは、フィードバック情報を介してこの変化を仮想マシンに送信することもできる。その後、仮想マシンは、フィードバック情報を実行エンジンに送信することができる。実行エンジンは、フィードバック情報と合わせて後続の実行コードを続けて実行することができる。例えば、実行エンジンは、システムの電力量が低いというフィードバックメッセージを受信した後、現在のコードを実行した時点で、電力量が低いというメッセージをユーザーにフィードバックする。
【0054】
一実施形態では、ステップS11において、実行エンジンからの初期化指令を受信することは、ブリッジを介して実行エンジンからの初期化指令を受信することを含む。
【0055】
一実施形態では、ステップS14において、実行コードを実行エンジンに送信することは、ブリッジを介して実行コードを実行エンジンに実行させるように送信することを含む。
【0056】
図3に示すように、実行エンジンと仮想マシンとの間に、ブリッジを介してメッセージのやり取りを行うことにより、オブジェクトコードとネイティブコードとのメッセージ転送を実現することができる。これにより、オペレーティングシステム自体の能力を十分に活用するため、コードの実行効率を向上させるとともに、安全性を確することができる。仮想マシンは、ブリッジを介して実行エンジンから初期化指令及び実行指令を受信する。仮想マシンは、ブリッジを介してコンパイルし得られた実行コードと、オペレーティングシステムから取得された様々なフィードバック情報とを実行エンジンに送信することにより、実行エンジンにフィードバック情報と合わせて後続の実行コードを続けて実行させることができる。
【0057】
図6は、本発明の実施形態によるコード実行装置の構成のブロック図である。
図6に示すように、該コード実行装置は、仮想マシンに適用することができる。該装置は、
実行エンジンがオブジェクトコードをロードして得られた初期化指令を、実行エンジンから受信するための第1受信ユニット61と、
初期化指令に基づいて、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を登録コンポーネントに送信するための第1送信ユニット62と、
ラッパーオブジェクトとオペレーティングシステムのネイティブコードとのマッピング関係に基づいて、コンパイルによりオブジェクトコードに対応する実行コードを得るためのコンパイルユニット63と、
実行コードを実行エンジンに実行させるように送信するための第2送信ユニット64と、を備える。
【0058】
一実施形態では、初期化指令には、初期化すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、第1送信ユニット62は、登録すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む登録指令を、登録コンポーネントに送信することにさらに用いられ、登録コンポーネントは、登録すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータに基づいて、ラッパーモジュールにおいて、対応するラッパーオブジェクトを作成する。
【0059】
一実施形態では、
図7に示すように、該装置は、
実行エンジンが上記の実行コードを実行して得られた実行指令を、実行エンジンから受信するための第2受信ユニット71と、
実行指令に基づいて、ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を呼び出しコンポーネントに送信して、オペレーティングシステムに呼び出されたラッパーオブジェクトに対応するネイティブコードを実行させるための第3送信ユニット72と、を備える。
【0060】
一実施形態では、実行指令には、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれており、呼び出しコンポーネントは、インヴォーカーである。第3送信ユニット72は、実行すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む呼び出し指令をインヴォーカーに送信するためにさらに用いられる。インヴォーカーは、オペレーティングシステムにおいて実行すべきラッパーオブジェクトに対応するネイティブコードを実行するように、ラッパーモジュールにおいて実行すべきラッパーオブジェクトの識別子に対応するラッパーオブジェクトを検索して得られた後、実行すべきラッパーオブジェクトのメソッド名に対応するメソッドを呼び出し、実行すべきラッパーオブジェクトのパラメータをロードする。
【0061】
一実施形態では、該装置は、
ラッパーモジュールがオペレーティングシステムから取得した実行結果を含むフィードバック情報を、前記ラッパーモジュールから受信するための第3受信ユニット73と、
フィードバック情報を実行エンジンに送信するための第4送信ユニット74と、をさらに備える。
【0062】
本発明の実施形態によるコード実行装置における各ユニットの機能は、前述のコード実行方法における対応の説明を参照することができるため、ここでは説明を省略する。
【0063】
図8は、本発明の実施形態によるレンダリングデバイスの構成のブロック図である。
図8に示すように、該レンダリングデバイスは、実行エンジン81と、仮想マシン82と、登録コンポーネント83と、を備え、
実行エンジン81は、オブジェクトコードをロードして得られた初期化指令を、仮想マシンに送信し、仮想マシンから返された、オブジェクトコードに対応する実行コードを受信することに用いられ、
仮想マシン82は、本発明のいずれか1つの実施形態によるコード実行方法を実行することに用いられ(具体的には前述のコード実行方法における対応説明を参照することができるため、ここでは説明を省略する。)、
登録コンポーネント83は、オブジェクトコードの実行に要するラッパーオブジェクトを作成するように、登録指令を仮想マシンから受信することに用いられる。
【0064】
一実施形態では、実行エンジン81は、実行エンジンが上記の実行コードを実行して得られた実行指令を仮想マシンに送信することにさらに用いられる。
【0065】
1つの実施形態では、
図9に示すように、レンダリングデバイスは、
ラッパーモジュールにおけるラッパーオブジェクトを呼び出すように、呼び出し指令を仮想マシンから受信する呼び出しコンポーネント84と、
オブジェクトコードの実行に要する少なくとも1つのラッパーオブジェクト851を含むラッパーモジュール85と、をさらに備える。
【0066】
一実施形態では、レンダリングデバイスは、
実行エンジンからの初期化指令を仮想マシンに送信し、仮想マシンからの実行コードを実行エンジンに送信するためのブリッジ86をさらに備え、
ブリッジ86は、実行エンジンの実行指令を仮想マシンに送信し、仮想マシンから返された実行結果を受信することもできる。
【0067】
一適用例では、
図3に示すように、レンダリングデバイスは、実行エンジン31、仮想マシン32、ラッパーレジストリコンポーネント(wrapper registry)33、インヴォーカー(Invoker)35、及びブリッジ(Bridge)37などを含んでもよい。実行エンジンがV8エンジンで、仮想マシンがAtomVMである場合を例として、レンダリングデバイスがオブジェクトコードを実行するプロセスを説明する。この例では、主にV8エンジンのコード実行機能を利用して、仮想マシンによってコードのコンパイルを完成する。
【0068】
実行エンジン31には、オブジェクトコードがロードされ、初期化指令が作成される。仮想マシン32は、ラッパー(wrapper)オブジェクトを管理し、オブジェクトコードからデバイス端末へのラッパー(wrapper)オブジェクトのマッピングを実現することができる。また、仮想マシン32は、v8エンジンの初期化、フレームワーク(framework)の初期化などを実行するエンジンやオブジェクトコードの実行環境を管理することもできる。仮想マシンは、ブリッジを介してオブジェクトコードとの情報のやり取りを行い、ブリッジ37は、オブジェクトコードとネイティブコードとの間の唯一のメッセージ経路である。
【0069】
実行エンジン31は、オブジェクトコードをロードし、デバイス端末のどのラッパー(wrapper)オブジェクトを呼び出すべきかを決定した後、ブリッジ37を介して初期化指令を仮想マシン32に送信することができる。ここで、各指令は、オブジェクト識別子(Identification、id)、メソッド名、及びパラメータを含んでもよい。例えば、オブジェクト識別子は「image」で、メソッド名は「setImage」で、パラメータは{a,b,c}である。
【0070】
仮想マシン32は、オブジェクト識別子に基づいて対応するラッパーオブジェクト341を検索し得ることができ、インヴォーカー35により、ラッパーオブジェクト341のメソッド名から対応するネイティブコードへの呼び出しを実現し、メソッド名に基づいて対応するメソッドの呼び出しを完成する。
【0071】
メソッドを呼び出した後に、実行結果が呼び出されてオブジェクトコードに返される場合がある。ラッパーオブジェクト341には、さまざまなデバイス端末のイベントが発生する場合もある。この2つの場合は、いずれもVMの統一経路(ブリッジ)を介してメッセージをオブジェクトコードに転送することができる。
【0072】
本発明の実施形態は、仮想マシンに実行エンジンとネイティブコードとのラッピングマッピングを統合することにより、オブジェクトコードの実行効率を確保しながら、システムの安全性を確保することができる。
【0073】
一実施形態では、
図10に示すように、デバイス端末のオペレーティングシステムにおけるネイティブコードを事前にラッピングした後、各ラッパーオブジェクトに対応する識別子及びメソッド名を得ることができる。例えば、ラッパー(wrapper)クラスによって、デバイス端末のコンポーネント及び能力をラッピングすることで、上位層の呼び出しに適すインターフェースを提供し、デバイス端末のラッパーオブジェクトの管理を容易にする。ラッパー(wrapper)オブジェクトは、内部実現とサードパーティ開発者拡張を含むことができる。ラッパーレジストリコンポーネント(wrapper registry)33が各ラッパーオブジェクトを上位層に登録できるようにすることにより、実行エンジンに、特定のラッパーオブジェクトがどのコンポーネントを含むか、及びラッパーオブジェクトにおいてどのようなメソッドがあるかを知らせることができる。ラッパーレジストリコンポーネント(wrapper registry)は、ラッパーモジュール34において各種のラッパーオブジェクト341を作成できるように、各種のラッパーオブジェクトを作成するためのインターフェースも提供している。ラッパーオブジェクトが作成された後、実行エンジン31は、仮想マシン32とインヴォーカー35とを介してラッパーオブジェクトを操作し、ラッパーオブジェクト341のメソッドを呼び出すことができる。
【0074】
上記のオペレーティングシステムにおけるすべてのラッパーオブジェクトは、ラッパーオブジェクトプールを構成している。異なるオブジェクトコードは、異なるラッパーオブジェクトを作成すべき場合がある。オブジェクトコードに基づいて作成された、1つまたは複数のラッパーオブジェクトを含む動的モジュールは、ラッパーモジュール34と呼ばれてもよい。
図10に示すように、ラッパーモジュール34は、作成インターフェース342、呼び出しインターフェース343、及びフィードバックインターフェース344などの複数のAPI(application programming interface、アプリケーション・プログラムイ・ンタフェース)を提供することができる。ラッパーレジストリコンポーネント33が提供できるAPIは、登録インターフェース331である。ラッパーレジストリコンポーネント33は、登録インターフェース331を介して仮想マシンからの登録指令を受信することができる。登録指令には、オブジェクトコードにおける登録すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータが含まれてもよい(登録指令には、ラッパーオブジェクトの識別子のみが含まれてもよく、またはラッパーオブジェクトの識別子及びメソッド名のみが含まれてもよく、またはラッパーオブジェクトの識別子及びパラメータのみが含まれてもよい)。ラッパーレジストリコンポーネント33は、作成インターフェース342を介して、オブジェクトコードにおける登録すべきラッパーオブジェクトの識別子、メソッド名、及びパラメータを含む作成指令(登録指令には、ラッパーオブジェクトの識別子のみが含まれてもよく、またはラッパーオブジェクトの識別子及びメソッド名のみが含まれてもよく、またはラッパーオブジェクトの識別子及びパラメータのみが含まれてもよい)をラッパーモジュール34に送信することができる。ラッパーモジュール34は、オブジェクトコードにおける登録すべき各ラッパーオブジェクトの識別子、メソッド名、及びパラメータに基づいて、ラッパーモジュール34において対応する各ラッパーオブジェクト341を作成する。登録が完了した後、ラッパーモジュール34は、作成インターフェース342を介して、作成されたラッパーオブジェクトとネイティブコードとのマッピング関係をラッパーレジストリコンポーネント33に返すことができる。ラッパーレジストリコンポーネント33は、登録インターフェース331を介して、作成されたラッパーオブジェクトとネイティブコードとのマッピング関係を仮想マシン32に返す。仮想マシン32は、上記のマッピング関係に基づいてコンパイルによりオブジェクトコードに対応する実行コードを得る。また、仮想マシンは、インヴォーカー35に呼び出し指令を送信することもできる。インヴォーカー35は、呼び出しインターフェース343を介して、ラッパーモジュール34における作成されたラッパーオブジェクト341を呼び出し、ラッパーオブジェクトのオペレーティングシステム36における対応するネイティブコードを実行する。
【0075】
本発明の実施形態では、登録指令と作成指令との内容及びフォーマットは、同一であってもよいし、異なっていてもよい。つまり、登録コンポーネントは、受信した登録指令の内容やフォーマットを修正してラッパーモジュールに送信してもよいし、修正せずに登録指令を作成指令としてラッパーモジュールに直接転送してもよい。
【0076】
本発明の実施形態では、ネイティブコードを直接ラッピングし、登録メカニズムを通じて、登録と呼び出しを外部に開放している。動的登録であるため、ネイティブコードに対するマッチングアップグレードが容易になる。上記のオペレーティングシステムには、例えば、アンドロイド(Android)システム、iOSシステム、またはLinuxベースの他のシステムが含まれるが、これに限定されない。
【0077】
図11は、本発明の実施形態によるレンダリングデバイスを示す図である。このレンダリングシステムは、スマート音声デバイス向けの可視レンダリングシステムであってもよい。このレンダリングシステムは、技能サービス、対話型AIシステム、独立レンダリングサービス、CDNサービス、及びスマート音声デバイスなどを含んでもよい。
【0078】
ビジネスプロセスの全体は、以下のとおりである。
【0079】
1)ユーザは、音声でスマート音声デバイスに質問をし、スマート音声デバイスは、ユーザの質問を対話型AIシステムに伝送する。スマート音声デバイスは、上述の実施形態におけるデバイス端末である。デバイス端末は、スクリーン付きであってもよい。
【0080】
2)対話型AIシステムでは、自動音声認識(Automatic Speech Recognition、ASR)、自然言語理解(Natural Language Understanding、NLU)の処理を経て、意図を技能サービスに送信する。技能サービスとは、上記の実施形態におけるレンダリングすべき内容を提供するサーバである。
【0081】
3)技能サービスは、内容とリソースを含むレンダリングすべき内容を対話型AIシステムに返す。
【0082】
4)対話型AIシステムは、レンダリングすべき内容、スマート音声デバイスの情報、技能サービスの情報を独立レンダリングサーバに送信する。
【0083】
5)独立レンダリングサービスは、レンダリングすべき内容の静的データを内容配信ネットワーク(Content Delivery Network、CDN)サービスに送信する。
【0084】
6)独立レンダリングサービスは、ステップ4)において受信した内容に基づいて、スマート音声デバイスに適したレンダリングテンプレートを選択し、選択したレンダリングテンプレートを用いてレンダリングすべき内容をレンダリングし、スマート音声デバイスの実行に便利なオブジェクトコードを生成し、オブジェクトコードを対話型AIシステムに返す。
【0085】
7)対話型AIシステムは、受信したオブジェクトコード及び関連するコンテキスト情報などのデータをスマート音声デバイスに返す。
【0086】
8)スマート音声デバイスにおけるレンダリング実行エンジンは、上記のオブジェクトコードを実行し、スクリーンに表示する。スマート音声デバイスは、レンダリングすべき内容における静的なリソースを、CDNから直接引き出すことができる。
【0087】
ここで、レンダリング実行エンジンの構成については、前述の実施形態におけるレンダリングデバイスを参照してもよい。例えば、
図3に示すように、レンダリング実行エンジンは、実行エンジン31、仮想マシン32、ラッパーレジストリコンポーネント33、インヴォーカー35、及びブリッジ37などを含む。実行エンジン31には、オブジェクトコードがロードされ、ブリッジを介して仮想マシン32にオブジェクトコードの実行に要するラッパーオブジェクトの識別子、メソッド名、及びパラメータが送信される。仮想マシン32は、ラッパーレジストリコンポーネント33を介してラッパーモジュール34において各ラッパーオブジェクトを作成する。作成が完成した後、仮想マシン32は、インヴォーカー35によってラッパー(wrapper)オブジェクト341を呼び出し、ラッパーオブジェクト341のメソッド名から対応するネイティブコードへの呼び出しを実現し、さらにメソッド名に基づいて対応するメソッドの呼び出しを完成することができる。メソッドを呼び出した後、実行結果が呼び出されてオブジェクトコードに返される場合がある。ラッパーオブジェクト341には、さまざまなデバイス端末のイベントが発生する場合もある。ラッパーモジュールがこれらのメッセージを仮想マシンにフィードバックした後、仮想マシンは、ブリッジを介してこれらのメッセージを実行エンジンに送信する。
【0088】
レンダリング実行エンジンの具体的な動作原理については、前述の実施形態におけるコード実行方法、コード実行装置、及びレンダリングデバイス、並びに
図3、
図10、
図11などの関連する説明を参照してもよい。
【0089】
本発明に係る実施形態では、電子デバイスと非一過性のコンピュータ可読取記録媒体をさらに提供する。
図12は、本発明の実施形態によるコード実行方法を実現するための電子デバイスのブロック図である。電子デバイスは、ラップトップコンピュータ、デスクトップコンピュータ、ワークステーション、パーソナルデジタルアシスタント、サーバ、ブレードサーバ、大型コンピュータ、および他の適切なコンピュータのような様々な形態のデジタルコンピュータを表すことができる。また、電子デバイスはパーソナルデジタル処理、携帯電話、スマートフォン、装着可能デバイス、およびその他の類似のコンピューティングデバイスなどの様々な形態のモバイルデバイスを表すことができる。ここで示した構成要素、それらの接続と関係、およびそれらの機能は例示的なものに過ぎず、本明細書に説明されたものおよび/または要求される本発明の実施を制限する意図がない。
【0090】
図12に示すように、当該電子デバイスは、1つ又は複数のプロセッサ401と、メモリ402と、各構成要素を接続するための高速インターフェースと低速インターフェースとを含むインターフェースとを含む。各構成要素は、異なるバスを用いて互いに接続し、共通のマザーボードに取り付けられてもよいし、必要に応じて他の方法で取り付けられてもよい。プロセッサは、電子デバイス内で実行される命令を処理してもよく、また、外部入出力デバイス(例えば、インターフェースに接続された表示デバイス)にグラフィックユーザインターフェース(Graphical User Interface,GUI)を表示するための、メモリまたはメモリ上に記憶されたグラフィカル情報の命令を含む。他の実施形態では、必要に応じて、複数のプロセッサおよび/または複数のバスを複数のメモリおよび複数のメモリとともに使用することができる。同様に、複数の電子デバイスを接続してもよく、各デバイスは、部分的に必要な動作(例えば、サーバアレイ、ブレードサーバのセット、またはマルチプロセッサシステムとして)を提供する。
図12においてプロセッサ901を例とする。
【0091】
メモリ902は、本発明にて提供された非一過性のコンピュータ可読記憶媒体である。メモリは、本発明で提供されるコード実行方法を少なくとも1つのプロセッサに実行させるように、少なくとも1つのプロセッサによって実行されることができる指令を記憶する。本発明における非一過性のコンピュータ可読記憶媒体は、本発明で提供されたコード実行方法をコンピュータに実行させるためのコンピュータ指令を記憶する。
【0092】
メモリ902は、非一過性のコンピュータ可読記憶媒体として、非一過性のソフトウェアプログラム、非一過性のコンピュータ実行可能なプログラム及びモジュールを記憶するために使用されてもよく、本発明の実施形態におけるコード実行方法に対応するプログラム指令/モジュール(例えば、
図6に示される第1受信ユニット61、第1送信ユニット62、コンパイルユニット63、及び第2送信ユニット64)のようなものである。プロセッサ901は、メモリ902に記憶されている非一過性のソフトウェアプログラム、指令及びモジュールを実行することにより、サーバの様々な機能アプリケーション及びデータ処理、すなわち上述した方法に関する実施形態に係るコード実行方法を実行する。
【0093】
メモリ902は、オペレーティングシステムや少なくとも1つの機能に必要なアプリケーションを記憶することができるプログラムの記憶領域と、コード実行方法に係る電子デバイスの使用によって作成されたデータなどを記憶することができるデータの記憶領域と、を含むことができる。さらに、メモリ902は、高速ランダムアクセスメモリを含んでもよく、非一過性の固体記憶装置を含んでもよい。例えば、少なくとも1つの磁気ディスク記憶装置、フラッシュメモリ装置、または他の非一過性の固体記憶装置を含むことができる。いくつかの実施形態では、メモリ902はオプションとして、プロセッサ901に対して遠隔的に設定されたメモリを含み、これらの遠隔メモリは、ネットワークを介してコード実行方法に係る電子デバイスに接続されてもよい。上記のネットワークの例は、インターネット、企業内ネットワーク、ローカルネットワーク、モバイル通信ネットワーク及びその組み合わせを含むが、これらに限定されない。
【0094】
コード実行方法に係る電子デバイスは、入力装置903と出力装置904とをさらに含むことができる。プロセッサ901、メモリ902、入力装置903、及び出力装置904は、バスまたは他の方法で接続されてもよく、
図12ではバスを介して接続されている。
【0095】
入力装置903は、入力された数字または文字を受信し、コード実行方法に係る電子デバイスのユーザ設定及び機能制御に関するキー信号入力を生成することができ、例えば、タッチパネル、キーパッド、マウス、トラックボード、タッチパッド、指示棒、1つまたは複数のマウスボタン、トラックボール、ジョイスティックなどを含むことができる。出力装置904は、表示装置、補助照明装置(例えばLED)、及び触覚フィードバック装置(例えば、振動モータ)などを含むことができる。この表示装置は、液晶ディスプレイ(Liquid Crystal Display、LCD)、発光ダイオード(Light Emitting Diode、LED)ディスプレイ及びプラズマディスプレイを含むことができるがこれらに限定されない。いくつかの実施形態では、表示装置はタッチパネルであってもよい。
【0096】
本発明におけるシステム及び技術に係る様々な実施形態は、デジタル電子回路システム、集積回路システム、専用集積回路(Application Specific Integrated Circuits、ASIC)、コンピュータハードウェア、ファームウェア、ソフトウェア、及び/又はこれらの組み合わせによって実現されることができる。これらの様々な実施形態は、1つまたは複数のコンピュータプログラムにおいて実装されてもよく、この1つまたは複数のコンピュータプログラムは、少なくとも1つのプログラマブルプロセッサを含むプログラム可能なシステム上で実行されてもよく、及び/又は解釈されてもよく、このプログラマブルプロセッサは、専用または汎用のプログラマブルプロセッサであってもよく、記憶システム、少なくとも1つの入力装置、及び少なくとも1つの出力装置より、データとコマンドを受信し、記憶システム、少なくとも1つの入力装置、及び少なくとも1つの出力装置に、データとコマンドを送信する。
【0097】
これらの計算プログラム(プログラム、ソフトウェア、ソフトウェアアプリケーション、またはコードともいう)は、プログラマブルプロセッサのマシンコマンドを含み、プロセス指向及び/又はオブジェクト指向プログラミング言語、及び/又はアセンブリ/マシン言語を用いてこれらの計算プログラムを実施することができる。本発明で使用されるように、「機械可読媒体」及び「コンピュータ可読媒体」という用語は、マシンコマンド及び/又はデータをプログラマブルプロセッサに提供するための任意のコンピュータプログラム製品、デバイス、及び/又は装置(例えば、磁気ディスク、光ディスク、メモリ、編集可能論理デバイス(programmable logic device、PLD)を意味し、機械読み取り可能な信号としてのマシンコマンドを受信する機械可読媒体を含む。「機械読み取り可能な信号」という用語は、マシンコマンド及び/又はデータをプログラマブルプロセッサに提供するための任意の信号を意味する。
【0098】
ユーザとのイントラクションを提供するために、本発明で説明されているシステムや技術は、コンピュータ上で実施されてもよく、また、ユーザに情報を表示するための表示装置(例えば、CRT(Cathode Ray Tube、ブラウン管)またはLCD(液晶ディスプレイ)モニタ)と、入力をコンピュータに提供するためのキーボード及びポインティングデバイス(例えば、マウスまたはトラックボール)とを備えてもよい。他の種類の装置も、ユーザとのイントラクションを提供するために使用され得る。例えば、ユーザに提供されたフィードバックは、任意の形態のセンシングフィードバック(例えば、視覚フィードバック、聴覚フィードバック、または触覚フィードバック)であってもよく、ユーザからの入力は、いかなる形式(音響入力、音声入力、または触覚入力を含む)で受信されてもよい。
【0099】
本発明で説明されているシステム及び技術は、バックグラウンド構成要素を含む計算システム(例えば、データサーバとして)、または中間部構成要素を含む計算システム(例えば、アプリケーションサーバ)、または、フロントエンド構成要素を含む計算システム(例えば、グラフィカルユーザインターフェースまたはネットワークブラウザを備えたユーザコンピュータであって、ユーザがこのグラフィカルユーザインターフェースまたはネットワークブラウザを介して本発明で説明されたシステム及び技術に係る実施形態とインタラクションを行うことができるユーザコンピュータ)に実行されてもよく、または、このようなバックグラウンド構成要素、中間部構成要素、またはフロントエンド構成要素の任意の組合せを含む計算システムにおいて実行されてもよい。システムの構成要素は、任意の形態または媒体のデジタルデータ通信(例えば、通信ネットワーク)によって相互に接続されてもよい。通信ネットワークの例えとして、ローカルネットワーク(Local Area Network、LAN)、広域ネットワーク(Wide Area Network、WAN)及びインターネットを含む。 コンピュータシステムは、デバイス端末及びサーバを含むことができる。デバイス端末とサーバは一般的に相互に離れており、通信ネットワークを介してインタラクションを行う。デバイス端末とサーバとの関係を持つコンピュータプログラムがそれぞれのコンピュータ上で実行されることによって、デバイス端末とサーバとの関係は構築される。
【0100】
本発明の実施形態に係るコード実行方法によれば、仮想マシンが登録コンポーネントに既にラッピングされたラッパーオブジェクトを作成させるように制御し、仮想マシンにオブジェクトコードのコンパイル作業を実行させることにより、実行エンジンが主にコードの実行を制御するようになるため、コードの実行効率を向上させることができる。
【0101】
上記の様々な態様のフローを用いて、ステップを新たに順序付け、追加、または削除することが可能であることを理解すべきである。例えば、本発明で記載された各ステップは、並列に実行しても良いし、順次に実行しても良いし、異なる順序で実行しても良い。本発明で開示された技術案が所望する結果を実現することができる限り、本発明ではこれに限定されない。 上記具体的な実施形態は、本発明の保護範囲に対する限定を構成するものではない。当業者は、設計事項やその他の要因によって、様々な修正、組み合わせ、サブ組み合わせ、及び代替が可能であることを理解するべきである。本発明の要旨及び原則内における変更、均等な置換及び改善等は、いずれも本発明の保護範囲に含まれるべきである。