go语言与java结合 go vs java

golang调用javagolang调用java是什么,让我们一起了解一下?
golang是一种静态强类型、编译型语言 。功能上有:内存安全,GC(垃圾回收),结构形态及 CSP-style 并发计算 , golang调用java就是接收一个参数 , 然后输出一行结果 。
由于Java世界里有非常丰富的开源应用模型和轮子,而这些正是Go世界里面最缺乏的东西 , 所以我首先考虑的就是如何在Go里面调用现有的Java代码 。
我们用一个简单的Go调用Java的例子,来进行测试 。(在winxp环境下能够正常运行)这段代码比较简单,就是在Go代码里面去call一个叫Hello的java对象 。而这个Hello .java功能也非常简单,就是接收一个参数,然后输出一行结果 。
// run_javapackage mainimport ("fmt""os/exec")/*** 调用一个Hello.class , 并接收一个参数*/func callJava(){cmd := exec.Command("java","Hello","tom")out,err := cmd.Output()if err != nil {println("error:",err.Error())}fmt.Printf("call java class Hello: %q\n", string(out))}func main() {fmt.Println("Test Call Java function!")callJava()}/* Hello.javapublic class Hello{public static void main(String[] args){if(args.length==0)System.out.println("hello my world!");elseSystem.out.println("hello my world! "+args[0]);}}*/
注意:
为了能够运行我的例子,需要把Hello.class放在和 run_java的可执行文件同样的目录下 。例如,run_java.exe在d:\goproject下,那么Hello.class也要在d:\goproject下 。
java怎么调用golang的接口1 接口的定义与理解
接口是一个自定义类型,它是一组方法的集合 。从定义上来看,接口有两个特点 。第一,接口本质是一种自定义类型,因此不要将golang中的接口简单理解为C++/Java中的接口,后者仅用于声明方法签名 。第二,接口是一种特殊的自定义类型 , 其中没有数据成员,只有方法(也可以为空) 。
接口是完全抽象的,因此不能将其实例化 。然而 , 可以创建一个其类型为接口的变量,它可以被赋值为任何满足该接口类型的实际类型的值 。接口的重要特性是:
(1)只要某个类型实现了接口要的方法,那么我们就说该类型实现了此接口 。该类型的值可以赋给该接口的值;
(2)作为1的推论,任何类型的值都可以赋值给空接口interface{}
注意:这只是golang中接口的特性,为非所有类型的特性(接口是一种特殊的类型) 。
接口的特性是golang支持鸭子类型的基础,即“如果它走起来像鸭子,叫起来像鸭子(实现了接口要的方法) , 它就是一只鸭子(可以被赋值给接口的值)” 。凭借接口机制和鸭子类型,golang提供了一种有利于类、继承、模板之外的更加灵活强大的选择 。
2 例子
type Exchanger interface {
exchange()
}
type StringPair struct {
first, second string
}
type Point[2]int
func (sp *StringPair) exchange() {
sp.first, sp.second = sp.second, sp.first
}
func (p *Point) exchange() {
p[0], p[1] = p[1], p[0]
}
func exchangeThese(exchangers ...Exchanger) {
for _, exchanger := range exchangers {
exchanger.exchange()
}
}
func main() {
pair1 := StringPair{"abc","def"}
pair2 := StringPair{"ghi","jkl"}
point := Point{5, 7}
fmt.Println(pair1, pair2, point)
pair1.exchange()
pair2.exchange()
point.exchange()
fmt.Println(pair1, pair2, point)
// exchangeThese(pair1, pair2) //wrong
exchangeThese(pair1, pair2)
fmt.Println(pair1, pair2)
}
运行结果
在本例中,自定义类型StringPair和Point指针实现了接口Exchanger所需的方法,因此该类型的值可以被赋值给接口的值 。

推荐阅读