草庐IT

jvm-bytecode

全部标签

c# - 从 Java 调用 .NET 程序集 : JVM crashes

我有一个第三方.NET程序集和一个大型Java应用程序。我需要从Java应用程序调用.NET类库提供的方法。该程序集未启用COM。我已经在网上搜索过,到目前为止我有以下内容:C#代码(cslib.cs):usingSystem;namespaceCSLib{publicclassCSClass{publicstaticvoidSayHi(){System.Console.WriteLine("Hi");}}}编译(使用.net3.5,但使用2.0时也是如此):csc/target:librarycslib.csC++代码(clib.cpp):#include#usingusingnam

java - 如何在 Windows 中查看正在执行的 java 程序的类路径和 jvm args

在*nix中,我只是执行ps-ef|grepjava查看正在执行的java程序的jvmargs和类路径。如何在Windows命令提示符中看到它?我想看看某些jar是否真的在正在运行的weblogic服务器的类路径中。 最佳答案 我会在命令行中使用jinfo这将为您提供这些信息以及更多信息 关于java-如何在Windows中查看正在执行的java程序的类路径和jvmargs,我们在StackOverflow上找到一个类似的问题: https://stackov

聊聊JVM优化的常用指令

一、jpsjps是(javaprocessStatusTool),Java版的ps命令,查看java进程及其相关的信息,如果你想找到一个java进程的pid,那可以用jps命令替代linux中的ps命令了,简单而方便。jps[options][hostid]options参数解释:-l:显示进程id,显示主类全名或jar路径-q:显示进程id-m:显示进程id,显示JVM启动时传递给main()的参数-v:显示进程id,显示JVM启动时显示指定的JVM参数hostid:主机或其他服务器ip最常用示例:jps-l输出jar包路径,类全名jps-m输出main参数jps-v输出JVM参数二、jin

java - 如何删除 JVM 属性 "https.proxyHost"?

我出于某种目的在我的系统上使用了代理。但是现在我没有在我的系统上设置任何代理,也没有从AndroidStudio代理设置中删除代理并将其设置为无代理。但我不断收到以下错误:YouhaveJVMproperty"https.proxyHost"setto....Thismayleadtoincorrectbehavior.ProxyshouldbesetinSettings|HTTPProxy同样,当我尝试在没有代理服务器的情况下构建/同步Gradle文件时,文件不会被编译,并说请检查我有互联网连接的网络连接。 最佳答案 如果有人仍在

Java:在运行时从同一 JVM 中获取类的字节码

相关:Isthereawaytoobtainthebytecodeforaclassatruntime?我正在为Clojure添加持久性,我终于准备好添加函数了。在Clojure中,函数被字节编译为具有调用方法(以及其他方法)的类。这样,功能是一流的。为了使这些持久化,我需要序列化和反序列化这些类。如何在无法访问.class文件的情况下获取类的字节码?如果我弄错了,请纠正我,但使用代理需要生成一个单独的VM,该代理连接到第一个VM。我需要从同一个VM执行此操作。仅仅使用Serializable来设置和获取Class对象是不够的。反序列化后,我需要加载该类,并且在后续的VM实例中,可能会

java - 为什么 JVM 不预先编译整个程序,而是一段一段地编译呢?

对于这个主题,HerbertSchildt写道:ItisimportanttounderstandthatitisnotpracticaltocompileanentireJavaprogramintoexecutablecodeallatonce,becauseJavaperformsvariousrun-timechecksthatcanbedoneonlyatruntime.他指的是什么运行时检查?请说明是逐段编译字节码的原因,而不是整个程序。 最佳答案 逐个编译它可能有几个原因(这是我想到的前两个):优化多次使用的代码,不需

java - 当 JVM 在垃圾收集期间崩溃(段错误)时,我如何才能找出正在收集的内容?

我在应用程序的同一阶段大致在我的JVM中遇到段错误,但在崩溃报告中有不同的堆栈跟踪。然而,它似乎总是在GC期间发生。由于崩溃发生在我尝试过的所有三个JVM(OpenJDK6、Oracle1.6.0_25和1.7.0)中,每个都有两个GC(并行收集器和CMS),并且它发生在应用程序的同一区域,我我想,如果我能找到GC试图收集的内容,我可能会在我的代码中发现导致这次崩溃的一些特殊之处。是否存在众所周知的GC问题编码实践?有哪些方法可用于诊断此问题?我能否对在我的应用程序中触发此问题的位置做出任何有根据的猜测?我可以使用哪些(GC调整)参数来缩小问题范围?有没有办法在堆转储中发现(可能)有问

java - cucumber JVM 未定义的步骤

我无法使用Cucumber为项目执行简单测试。我在使用Cucumber插件的Intellij13社区。我在我的功能目录中写了我的功能文件,我也实现了我的步骤,在插件的帮助下创建它们。并且我在特征文件中的步骤被intellij识别,它可以导航并转到步骤实现。但是当我尝试运行我的场景时,它总是失败,因为对于每个步骤,它都显示“未定义的步骤:”。以下是我的项目的组织方式:正如我之前所说,您可以看到我的步骤已被Intellij识别:这怎么可能,我该如何纠正?任何帮助都会很棒!编辑现在我已经为我的运行者添加了选项:@CucumberOptions(monochrome=true,features

java - 相当于 JVM 的 DLR?

JVM上是否有等效的DLR(.NET动态语言运行时)?我知道我可以去实现我自己的动态绑定(bind)并用Java发出我自己的字节码。但是是否有任何预先构建的框架(如DLR)所以我不必重新发明轮子? 最佳答案 DLR是几种不同的东西,其中一些在Java中有直接的等价物,其中一些以不同的形式存在,还有一些没有等价物。一些具有等价物的平台已经是平台的一部分,一些将成为Java7的一部分,还有一些可以从第三方获得。运行时绑定(bind)器和缓存基础架构DLR具有运行时绑定(bind)和缓存基础结构,这使得动态调度快速高效。如何让动态分派(d

java - JVM/GC 是否在程序/线程退出时调用 `finalize()`?

PS:我确实知道如何正确清理,而不依赖于finalize()。Java是否不保证在程序退出时会进行适当的垃圾回收?例如可以说我在缓存中保留了一些数据而不是经常序列化它,我还实现了finalize()希望如果由于任何原因(崩溃除外)我的程序正常退出,然后缓存将由我在finalize()方法中的代码写入DB/file/some-storage。但是根据下面的小实验,JVM似乎并没有“优雅地”清理内存,它只是退出了。Javaspec(参见程序退出)没有说明退出时如何处理内存/gc。还是我应该查看规范的不同部分?以Windows7上使用1.6.0.2764位的以下示例(末尾的输出)为例publ