doulu8537
2014-05-26 14:24
浏览 1.6k
已采纳

如何在Golang中使用Jar文件?

Is it possible to use jar file class methods in Go code. If so than please forward me the link for the same. I have searched the same in

GoDoc/github.com/code.google

But there was no such package build.

图片转代码服务由CSDN问答提供 功能建议

是否可以在Go代码中使用jar文件类方法。 如果是这样,请转发给我相同的链接。 我在

GoDoc / github.com / code.google

中搜索了相同的内容 没有这样的软件包构建。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • doutenglou6588 2014-05-26 14:36
    已采纳

    It's "possible" only in the extremely pedantic sense that you could theoretically write some sort of JVM environment in Go that can run JVM bytecode that happens to interact with memory allocated by Go.

    In any practical sense, Java (and Scala etc) compile in completely different ways to Go and it's not feasible to do this. This is especially complicated by Go having its own runtime which complicates the inverse as well (running Go functions from Java).

    If you need to communicate with Java code from Go, I advise looking into RPC, you can launch a Java program as a separate process and cooperatively call methods over your local network. This takes a little effort, but not very much. It's certainly easier than writing the framework to truly invoke Java methods from Go would be.

    The other option is to invoke Java programs by using os/exec, having them output to a file or command line, and then reading in that output and parsing it, but that's a lot more fragile than RPC and prone to errors and security holes.

    As Evan mentions in the comments, you can use the JNI (Java Native Interface) with a C entrypoint. So using Cgo you can launch the JVM and call Java code. This site seems to have a tutorial on how to set it up in C and C++. I'm not very familiar with using JNI from this direction so I can't really recommend it nor dissuade you from using it. It does introduce a C dependency into your build process though, so be aware of that.

    点赞 打赏 评论
  • douzhangshao6369 2018-01-11 22:44

    I have a similar usecase. I use kafka as a message bus. The producer is in scala and consumer is a go application. This works seamlessly. Best part of this is, it can scale on any distributed setup.

    点赞 打赏 评论

相关推荐 更多相似问题