Android デバイスで ZeroMQ をプログラムしようとしていますが、ZeroMQ の使用方法を知っています (C++、Php、.Net から、私は常にそれを使用しています)。これまでに行ったことをリストすると:
- Android Studio の依存関係から、maven セントラル検索からorg.zeromq:jeromq:0.3.5を追加しました。
- その後、次のようなコードを入れます。
try
{
ZMQ.Context context = ZMQ.context(1);
// Socket to talk to server
System.out.println("Connecting to hello world server...");
ZMQ.Socket requester = context.socket(ZMQ.REQ);
requester.connect("tcp://192.168.2.127:5555");
for (int requestNbr = 0; requestNbr != 10; requestNbr++) {
String request = "Hello";
System.out.println("Sending Hello " + requestNbr);
requester.send(request.getBytes(), 0);
byte[] reply = requester.recv(0);
System.out.println("Received " + new String(reply) + " " + requestNbr);
}
requester.close();
context.term();
}
catch (Exception e)
{
Log.e("Error", "Exception : " + e.getMessage());
}
これを実行すると、次のような例外が発生しました。
01-03 02:20:55.200 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.os.PersistableBundle', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.200 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.os.PersistableBundle', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.200 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.media.session.MediaController', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.210 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.widget.Toolbar', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.220 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.app.ActivityManager$TaskDescription', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.230 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.app.SharedElementCallback', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.230 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.os.PersistableBundle', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.240 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.app.SharedElementCallback', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.250 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.app.assist.AssistContent', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.260 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.view.SearchEvent', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:20:55.270 12562-12562/mia.face.id.zeromq E/dalvikvm: Could not find class 'android.os.PersistableBundle', referenced from method mia.face.id.zeromq.MainActivity.access$super
01-03 02:21:08.080 12562-12562/mia.face.id.zeromq E/Error: Exception : null
私は実際にはプログラミングの新人ではありませんが、Android/Java のスタッフです。この問題を解決する方法がわかりません。インターネットで検索しましたが、何かを見つけることができませんでした。
あなたが私を助けることができれば、私はとても喜んでいます。
前もって感謝します。
(さらに、これを含めるのを忘れています:)
01-03 03:12:58.430 1374-1374/mia.face.id.zmqtestest E/Error: Exception
android.os.NetworkOnMainThreadException
at android.os.StrictMode$AndroidBlockGuardPolicy.onNetwork(StrictMode.java:1145)
at libcore.io.BlockGuardOs.sendto(BlockGuardOs.java:168)
at libcore.io.IoBridge.sendto(IoBridge.java:490)
at java.nio.SocketChannelImpl.writeImpl(SocketChannelImpl.java:391)
at java.nio.SocketChannelImpl.write(SocketChannelImpl.java:349)
at java.nio.PipeImpl$PipeSinkChannel.write(PipeImpl.java:114)
at zmq.Signaler.send(Signaler.java:121)
at zmq.Mailbox.send(Mailbox.java:85)
at zmq.Ctx.sendCommand(Ctx.java:388)
at zmq.ZObject.sendCommand(ZObject.java:362)
at zmq.ZObject.sendPlug(ZObject.java:171)
at zmq.ZObject.sendPlug(ZObject.java:161)
at zmq.Own.launchChild(Own.java:126)
at zmq.SocketBase.addEndpoint(SocketBase.java:550)
at zmq.SocketBase.connect(SocketBase.java:542)
at org.zeromq.ZMQ$Socket.connect(ZMQ.java:1246)
at mia.face.id.zmqtestest.MainActivity$1.onClick(MainActivity.java:34)
at android.view.View.performClick(View.java:4438)
at android.view.View$PerformClick.run(View.java:18422)
at android.os.Handler.handleCallback(Handler.java:733)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:813)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:629)
at dalvik.system.NativeStart.main(Native Method)