Java OSHI(操作系统和硬件信息)库NoSuchMethodError。

3

当我使用OSHI API(https://github.com/oshi/oshi)时,我收到以下错误。

在我的Maven项目中,我有以下依赖项(我根据其他Stack Overflow帖子添加了SLF4J以修复错误,但没有起作用):

<!-- https://mvnrepository.com/artifact/com.github.oshi/oshi-core -->
<dependency>
    <groupId>com.github.oshi</groupId>
    <artifactId>oshi-core</artifactId>
    <version>6.2.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-api -->
<!-- OSHI requires it!-->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-api</artifactId>
    <version>1.7.36</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.slf4j/slf4j-simple -->
<dependency>
    <groupId>org.slf4j</groupId>
    <artifactId>slf4j-simple</artifactId>
    <version>1.7.36</version>
    <scope>test</scope>
</dependency>

这是我如何使用OSHI:

package controller;

import oshi.SystemInfo;
import oshi.hardware.CentralProcessor;
import oshi.hardware.HardwareAbstractionLayer;

public class SystemLoad extends Thread {

    public SystemLoad() {
    }

    @Override
    public void run(){
        while(true) {
            SystemInfo si = new SystemInfo();
            HardwareAbstractionLayer hal = si.getHardware();
            CentralProcessor cpu = hal.getProcessor();
            System.out.println( String.valueOf(cpu.getSystemCpuLoad(100)) );
        }
    }
}

这是我收到的错误代码:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Exception in thread "Thread-0" java.lang.NoSuchMethodError: 'void com.sun.jna.Memory.close()'
    at com.github.oshi@6.2.2/oshi.util.Util.freeMemory(Util.java:112)
    at com.github.oshi@6.2.2/oshi.jna.ByRef$CloseableLONGLONGByReference.close(ByRef.java:101)
    at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfDataUtil.updateQueryTimestamp(PerfDataUtil.java:174)
    at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfCounterQueryHandler.updateQuery(PerfCounterQueryHandler.java:134)
    at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfCounterWildcardQuery.queryInstancesAndValuesFromPDH(PerfCounterWildcardQuery.java:164)
    at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfCounterWildcardQuery.queryInstancesAndValues(PerfCounterWildcardQuery.java:87)
    at com.github.oshi@6.2.2/oshi.driver.windows.perfmon.ProcessorInformation.queryProcessorCounters(ProcessorInformation.java:167)
    at com.github.oshi@6.2.2/oshi.hardware.platform.windows.WindowsCentralProcessor.queryProcessorCpuLoadTicks(WindowsCentralProcessor.java:349)
    at com.github.oshi@6.2.2/oshi.util.Memoizer$1.get(Memoizer.java:87)
    at com.github.oshi@6.2.2/oshi.hardware.common.AbstractCentralProcessor.getProcessorCpuLoadTicks(AbstractCentralProcessor.java:204)
    at com.github.oshi@6.2.2/oshi.hardware.platform.windows.WindowsCentralProcessor.querySystemCpuLoadTicks(WindowsCentralProcessor.java:221)
    at com.github.oshi@6.2.2/oshi.util.Memoizer$1.get(Memoizer.java:87)
    at com.github.oshi@6.2.2/oshi.hardware.common.AbstractCentralProcessor.getSystemCpuLoadTicks(AbstractCentralProcessor.java:192)
    at com.github.oshi@6.2.2/oshi.hardware.CentralProcessor.getSystemCpuLoad(CentralProcessor.java:189)
    at hu.jhasher/controller.SystemLoad.run(SystemLoad.java:24)
    Suppressed: java.lang.NoSuchMethodError: 'void com.sun.jna.Memory.close()'
        at com.github.oshi@6.2.2/oshi.util.Util.freeMemory(Util.java:112)
        at com.github.oshi@6.2.2/oshi.jna.ByRef$CloseableHANDLEByReference.close(ByRef.java:115)
        at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfCounterQueryHandler.removeAllCounters(PerfCounterQueryHandler.java:112)
        at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfCounterQueryHandler.close(PerfCounterQueryHandler.java:166)
        at com.github.oshi@6.2.2/oshi.util.platform.windows.PerfCounterWildcardQuery.queryInstancesAndValuesFromPDH(PerfCounterWildcardQuery.java:146)
        ... 10 more

1
NoSuchMethodError与SLF4J无关。这意味着您的类路径上可能有错误(太旧)版本的JNA(Java Native Access)。以“SLF4J”为前缀的行只是警告,表示您没有为SLF4J配置适当的日志记录库。 - Mark Rotteveel
我更改了JNA版本,但仍然有一些问题。请检查我的更新。谢谢! - Thend
这表示问题已经解决。如果你指的是那些SLF4J行,正如我所说,以SLF4J为前缀的日志行是由于你没有为SLF4J配置适当的日志记录库(你只在测试范围内有slf4j-simple,因此主范围内没有日志记录库)所致。 - Mark Rotteveel
在任何情况下,那是一个不同的问题,我会回滚你的编辑,因为你不应该改变问题的目标。关于SLF4J行的问题已经有多个问题在Stack Overflow上得到了解决,比如这个 - Mark Rotteveel
这个回答解决了你的问题吗?jna-platform中的NoSuchMethodError - Daniel Widdis
1个回答

4

OSHI 6.2.2 需要 JNA(Java Native Access)5.12.1,但是看起来您的 classpath 上有一个旧版本的 JNA。 Memory.close() 方法是在 JNA 5.12.0 中引入的。

使用 mvn dependency:tree 检查哪些依赖项被拉入了 net.java.dev.jna:jnanet.java.dev.jna:jna-platform,然后在您自己的 POM(在dependencyManagement中)中添加显式依赖关系,或者从拉入旧版本的库中排除它,以便拉取 OSHI 定义的版本。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接