当前位置:  开发笔记 > 编程语言 > 正文

两个单独的Java桌面应用程序之间的通

如何解决《两个单独的Java桌面应用程序之间的通》经验,为你挑选了5个好方法。

我正在寻找开发两个独立(但相关)的Java桌面应用程序.

我希望一个应用程序能够触发另一个应用程序,传入可以编辑和传回的数据,即通信将是双向的.如果另一个应用程序已在运行,我希望它们只是进行通信,即我不想只是通过命令行传递参数等.

一般来说,为了实现这一目标,我应该考虑哪些策略/技巧?



1> mhaller..:

为了说明让两个应用程序相互通信是多么容易,请使用JGroups查看此网络剪贴板演示.只需启动两个实例并开始将文件放入其中一个实例中.第二个实例将立即显示相同的文件.

import java.io.Serializable;
import java.awt.*;
import java.awt.datatransfer.*;
import javax.swing.*;
import org.jgroups.*;

public class JGroupsTest {

    public static void main(String[] args) throws Exception {
        final JFrame frame = new JFrame();
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        frame.setVisible(true);
        frame.setSize(500, 300);
        final DefaultListModel listModel = new DefaultListModel();
        final JList panel = new JList(listModel);
        panel.setBackground(new Color(128, 0, 40));
        panel.setForeground(new Color(240, 240, 240));
        frame.add(panel);
        System.setProperty("java.net.preferIPv4Stack", "true");
        final JChannel channel = new JChannel("udp.xml");
        channel.connect("networkclipboard");
        channel.setReceiver(new ReceiverAdapter() {
            @Override
            public void viewAccepted(View newView) {
                frame.setTitle("Network Clipboard - " + channel.getLocalAddress());
            }

            @Override
            public void receive(Message msg) {
                listModel.addElement(msg.getObject());
            }
        });

        panel.setTransferHandler(new TransferHandler() {
            @Override
            public boolean importData(JComponent comp, Transferable t) {
                DataFlavor[] transferDataFlavors = t.getTransferDataFlavors();
                for (DataFlavor flavor : transferDataFlavors) {
                    try {
                        Object data = t.getTransferData(flavor);
                        if (data instanceof Serializable) {
                            Serializable serializable = (Serializable) data;
                            Message msg = new Message();
                            msg.setObject(serializable);
                            channel.send(msg);
                        }
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
                return super.importData(comp, t);
            }

            @Override
            public boolean canImport(TransferSupport support) {
                return true;
            }

            @Override
            public boolean canImport(JComponent comp, DataFlavor[] transferFlavors) {
                return true;
            }

        });
    }

}



2> iirekm..:

这取决于您希望如何传达这两个程序:

如果只需要进程间信号量,请在/ tmp中的某个位置创建一个文件并将其锁定.

如果只需要进程间同步消息传递(远程过程调用),则RMI应该是最简单的.

如果需要异步进程间消息传递,JMS应该是最简单的.

如果需要进程间共享内存,请使用映射文件.

如果您需要以上所有内容,Terracotta(http://www.terracotta.org/)是最简单的方法:在相同甚至不同计算机上的不同JVM上的Java程序看到彼此就好像它们是在一个JVM中执行的机.将一个程序拆分成几个甚至不需要任何代码更改 - 这足以编写XML配置文件.



3> BalusC..:

他们每个人都可以听一听Socket.本教程很适合入门.



4> Jé Queue..:

您还应该考虑好的经典RMI.



5> pgras..:

看看JavaGroups,它将解决您的通信问题,并帮助您检测其他应用程序是否正在运行.如果应用程序没有运行,则必须使用java.lang.Runtime.exec()为它启动新的JVM ...

推荐阅读
mobiledu2402852413
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有