草庐IT

rmtree_unsafe

全部标签

java - 为 Unsafe.putOrdered*() 的发布实现获取?

您认为在Java中实现发布/获取对的获取部分的最佳正确方法是什么?我正在尝试使用经典的发布/获取语义(没有StoreLoad并且没有跨线程的顺序一致性)对我的应用程序中的一些操作进行建模。有几种方法可以在JDK中实现大致相当于商店发布的效果。java.util.concurrent.Atomic*.lazySet()和底层sun.misc.Unsafe.putOrdered*()是最常被引用的方法。但是,没有明显的方法来实现加载获取。允许lazySet()的JDKAPI大多在内部使用volatile变量,因此它们的存储发布与易变加载配对。从理论上讲,volatile加载应该比加载获取更

java - 使用 Unsafe.getUnsafe().throwException 抛出异常

我在java.lang.Class#newInstance0中发现了一些有趣的代码://Runconstructortry{returntmpConstructor.newInstance((Object[])null);}catch(InvocationTargetExceptione){Unsafe.getUnsafe().throwException(e.getTargetException());//Notreachedreturnnull;}查看Unsafe.getUnsafe().throwException语句。看起来一个已检查的异常是从一个没有声明要抛出的方法中抛出的!

java - 为什么 JNI 调用本地方法比 sun.misc.Unsafe 中的类似方法慢?

我正在开发一个类似于sun.misc.Unsafe但具有扩展内存管理的JNI实现。为什么来自sun.misc.Unsafe和我开发的库的本地方法的调用时间截然不同?一些数字:sun.misc.Unsafe.getInt(address)需要~1ns当我的类似方法需要~10ns两种实现方式大体相同,都沿用了OpenJDK的源码,只是通过指针返回变量。两者的注册方式相同。如何加速JNI调用?是什么让不安全性能如此特别?谢谢,尤里/ 最佳答案 如果您在Unsafe类中寻找native方法的来源,您会发现它不使用JNI实现。相反,不安全的方

java - 为什么 sun.misc.Unsafe 存在,如何在现实世界中使用它?

前几天我遇到了sun.misc.Unsafe包,并对它的功能感到惊讶。当然,这个类没有记录,但我想知道是否有充分的理由使用它。您可能会在哪些情况下需要使用它?在现实场景中如何使用它?此外,如果您确实需要它,这是否表明您的设计可能有问题?为什么Java甚至包含这个类? 最佳答案 例子虚拟机“内在化”。即CAS(Compare-And-Swap)用于Lock-FreeHashTables例如:sun.misc.Unsafe.compareAndSwapInt它可以对包含CAS特殊指令的native代码进行真正的JNI调用在这里阅读更多关

导致虚拟机故障的 Java 映射/nio/NFS 问题 : "a fault occurred in a recent unsafe memory access operation in compiled Java code"

我已经为特定的二进制格式(nfdump如果有人感兴趣)编写了一个解析器类,它使用了java.nio的MappedByteBuffer。读取每个几GB的文件。二进制格式只是一系列header和大部分固定大小的二进制记录,通过调用nextRecord()将其馈送到被调用方,nextRecord()会推送状态机,完成后返回null。它表现良好。它在开发机器上运行。在我的生产主机上,它可以运行几分钟或几小时,但似乎总是抛出“java.lang.InternalError:afaultoccurredinarecentunsafememoryaccessoperationincompiledJa

java - 我可以用 sun.misc.Unsafe 覆盖对象吗?

如果一个对象是同一类的实例,它们的大小相同,我可以使用sun.misc.Unsafe覆盖另一个对象吗?编辑:“覆盖”是指“删除”第一个对象,用第二个对象填充内存。可能吗? 最佳答案 By"override"Imeanto"delete"firstobject,anttofillthememorywiththesecondone.Isitpossible?是也不是。是-如果您使用Unsafe分配一些内存并写入long,然后在其中写入另一个long(例如),那么是的,您已经删除了第一个对象并用第二个对象填充了内存。这类似于您可以使用By

java - 为什么 XX :MaxDirectMemorySize can't limit Unsafe. 分配内存?

下面的代码将分配大量直接内存但不会导致java.lang.OutOfMemoryError:Directbuffermemory://JVMargs:-Xms10m-Xmx10m-XX:MaxDirectMemorySize=10mpublicclassDirectMemoryOOM{publicstaticvoidmain(String[]args)throwsNoSuchFieldException,IllegalAccessException{Fieldf=Unsafe.class.getDeclaredFields()[0];f.setAccessible(true);Unsa

git clone失败无错误信息或报penSSL/3.1.1: error:0A000152:SSL routines::unsafe legacy renegotiation disabled

问题出现前景:新笔记本win11系统安装gitclone无任何反应也没有报错信息,尝试各种方式无果,在升级最新版本git拉代码时会报gitclone报OpenSSL/3.1.1:error:0A000152:SSLroutines::unsafelegacyrenegotiationdisabled,也是尝试各种方式无果,解决方法:怀疑是win11系统兼容git的问题,尝试着换了git最稳定版本Git-2.30.2-64-bit:后竟解决折磨我两天的兼容问题。使用win11安装git亲测不能用太旧或最新版本的包,已将这个版本的git安装包上传我的资源,希望可以帮助出现相同问题的人。Git-2.

c++ - tbb::concurrent_unordered_map::unsafe_erase 是否会使任何现有的迭代器失效?

我看到tbb::concurrent_unordered_map与std::unordered_map非常接近,同时对于并发是安全的。我也知道unsafe_erase对于insert等不是并发安全的。迭代器文档还声明任何现有的迭代器对于insert仍然有效,查找等问题是,unsafe_erase是否会使除被要求删除的迭代器之外的任何其他迭代器失效?std::unordered_map和std::map当然有这种行为,但它没有在任何地方的concurrent_unordered_map文档中指定。 最佳答案 tbb::unsafe_e

c++ - 为什么 “strcat” 被认为是 “unsafe” ?

这个问题在这里已经有了答案:关闭11年前。PossibleDuplicate:WhydoesMSVC++consider“std::strcat”tobe“unsafe”?(C++)这是我的代码:charsentence[100]="";char*article[5]={"the","a","one","some","any"};lexeme=rand()%4;//randomlexemestrcat(sentence,article[lexeme]);strcat(sentence,"");在MSVC++中调试时,它会给我这些警告消息:Warning1warningC4996:'st