这个问题和如何系统的测试一个字符集的压缩率一样……
本质上语言和性能是八杆子打不着的东西……就算你规定运行时,那怎么写还是自由的。一定要测试,那测出来的也是这个运行时或者说语言实现上对于单元测试的支持力度,例如是不是支持SIMD、内嵌汇编又或者是C互操作性啥的。这跟语言又有什么关系呢?
举个极端的例子,假设我们设计一个测试用例用来测试两个32位整数相乘的性能。这里有两个语言,一个支持乘法,一个不支持乘法,是不是直觉上认为支持乘法的语言必然会在性能上好更多?
特错大错,如果支持乘法的语言的编译器和运行时不支持乘法,那编译出来实际执行的指令仍然是大量的加法。而不支持乘法的语言的编译器和运行时支持将相同数连续累加优化成乘法,那反而可以执行乘法的指令。
觉得不可能吗,那请问目前主流的编程语言里面几个有SIMD语法的?
所以你搞反了,你测的就是运行时和编译器,语言只是编译器的一个特性而已……
有的编译器还支持多种语言编译呢,譬如说roslyn……
虽然我没有仔细看代码,但是感觉上roslyn里面http://VB.NET和C#就前端不一样。换句话说,AST是同一个……
说白了,要支持Java,不考虑基础类库的话,比支持http://VB.NET还简单,把C#的前端改改就行了。