草庐IT

linux-native-library

全部标签

java - 使用 MTJ/Netlib( native )的缓慢矩阵乘法性能

我需要将大小为5000x5000的大矩阵乘以20000x20000。我在寻找具有稀疏矩阵但可以进行快速乘法的库时遇到问题。首先,我阅读了上一个关于Java矩阵库性能的问题(PerformanceofJavamatrixmathlibraries?)。基于那里的最佳答案,我决定使用JBLAS,因为它是最快的之一。在我的例子中,乘以5000x5000矩阵大约需要50秒左右,这比Matlab慢很多,但仍然可以接受。问题是矩阵可能非常大(高达20kx20k或更多),但它们通常是稀疏的。矩阵中只有30%的元素是非零元素。JBLAS不提供任何稀疏矩阵实现,因此存储大型密集矩阵所需的内存占用量可能会

java - 如何使用 Java native 接口(interface)将字节数组传递给以 char* 作为参数的 C 函数?

所以我需要使用JNI从java调用C函数。当传入不同的数据类型(创建native变量、头文件、共享库等等)时,我已经能够成功地做到这一点,但无法让它与字节数组一起工作。这是我的C函数:#includevoidencrypt(intsize,unsignedchar*buffer);voiddecrypt(intsize,unsignedchar*buffer);voidencrypt(intsize,unsignedchar*buffer){for(inti=0;i这是我的java代码(我知道在从中生成头文件后,我必须用头文件中的JNI代码替换C函数声明)classTester{pub

java - "Native library location"条目在 Eclipse 中有什么作用?

如果在Eclipse中添加用户定义的库,可以设置“native库位置”。此字段允许输入一些目录路径。这条路径什么时候起作用? 最佳答案 Eclipse在启动Java程序时使用此信息构建java.library.path。背景:一些Java框架依赖于native代码。此代码通常以native共享库(*.so、*.dll)的形式出现。在Java中,您可以看到具有属性native的方法。该代码将使用System.loadLibrary()加载共享库。为了使代码独立于绝对路径,您只需将共享库的名称传递给System.loadLibrary(

java - 内存泄漏在 MAT 中显示为 GC root : Native Stack

我有一些我运行的第三个库代码,一段时间后我遇到了OutOfMemoryError。所以我启动了EclipseMAT并分析了内存。现在似乎无法释放内存,因为有一个对象显示为GCroot:NativeStack。阅读documentation:Inoroutparametersinnativecode,suchasuserdefinedJNIcodeorJVMinternalcode.ThisisoftenthecaseasmanymethodshavenativepartsandtheobjectshandledasmethodparametersbecomeGCroots.Forexa

java - 设置 WebLogic Server 11g (10.3.6) : Native Library to read the password securely from commandline is not found 时出错

我正在尝试在Windows中为开发人员10.3.6(11g)配置我的Weblogic服务器。从自述文件中,我在以下步骤中遇到错误:CreateanewWLSdomainandstartWLS.(ItisrecommendedthatyoucreatethedomainsoutsidetheMW_HOME)Windows$mkdirC:\home\myhome\mydomain$cdC:\home\myhome\mydomain$%JAVA_HOME%\bin\java.exe-Xmx1024m-XX:MaxPermSize=128mweblogic.Server我在(C:/WebLog

java - 如何编写响应 `Thread.interrupt()` 的 native 代码?

在Java中,所有标准的阻塞方法都可以通过调用Thread.interrupt()来中断,但是如果我们有Java绑定(bind)包装一个自己执行I/O的本地库呢?那么native代码应该如何挂接到线程并响应对Thread.interrupt()的调用? 最佳答案 示例代码有关完整的文章,包括可运行的示例代码,请参阅https://github.com/NWilson/javaInterruptHook.Thread.interrupt()是如何工作的?在Sun的JRE(和OpenJDK)中,interrupt()能够自行唤醒一些低级

java - 'java' 和 'libjvm.so' (Linux) 或 'jvm.dll' (Windows) 之间的区别?

通过普通java命令启动应用程序与通过libjvm.so(Linux中的libjvm.so或Windows中的jvm.dll)直接调用JVM有什么区别?最近在论坛上看到说用dll或.so文件启动eclipse性能会更好。我想知道这是怎么发生的。谢谢。 最佳答案 如果人们想围绕Java核心包装他们自己的功能,通常他们会针对jvm.dll进行构建,有时很难做一些看起来来自Java的“本地”事情。一个很好的例子确实是Eclipse,他们想在其中弹出启动画面并在启动之前执行一些其他操作。对于其他产品,Java只是他们工作量的一小部分(例如:

java - guava-libraries : Is Objects. hashCode(Object[]) 碰撞安全吗?

在查看覆盖hashCode()的不同选项时,我被定向到GoogleGuava库中的Objects.hashCode(Object[])(javadoc).javadoc声明它委托(delegate)给Arrays.hashCode(Object[])。在许多不同的对象类型中使用此方法是否安全?这是否容易发生哈希冲突,或者这不太可能仅仅是因为容器通常只包含一种类型的对象?作为一个简单的例子,考虑以下类,publicclassStudent{privatefinalStringname;publicStudent(Stringname){this.name=name;}@Overridep

java - JPA native 查询中的位置参数问题

我正在尝试:Stringsql="SELECTemailFROMusersWHERE(typelike'B')AND(usernamelike'?1')";Listresults=em.createNativeQuery(sql).setParameter(1,username).getResultList();但是我收到IllegalArgumentException,它告诉我参数超出范围。我做错了什么? 最佳答案 参数周围不应有引号。试试这个:Stringsql="SELECTemailFROMusersWHERE(typeli

java - 带有 $LD_LIBRARY_PATH 的 Eclipse

我在目录/usr/local/lib/中有一些使用JNI构建的库文件。如果我从luncher启动Eclipse,Eclipse永远不会选择该路径,因此我需要为运行配置指定-Djava.library.path。但是如果我从命令行启动Eclipse。看起来工作正常。有谁知道为什么它会这样,以及如何将它配置为从luncher知道/usr/local/lib/路径。谢谢。我在Ubuntu操作系统上使用EclipseSDK版本:3.6.2。 最佳答案 这可能是因为您的shell在其中一个启动脚本中执行了exportLD_LIBRARY_PA