`
jimmee
  • 浏览: 540713 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Can multiple threads see writes on a direct mapped ByteBuffer in Java?

 
阅读更多

原始问题:

 

http://stackoverflow.com/questions/7002510/can-multiple-threads-see-writes-on-a-direct-mapped-bytebuffer-in-java

 

具体的回复:

 

Memory mapping with the JVM is just a thin wrapper around CreateFileMapping (Windows) or mmap (posix). As such, you have direct access to the buffer cache of the OS. This means that these buffers are what the OS considers the file to contain (and the OS will eventually synch the file to reflect this). So there is no need to call force() to sync between processes. The processes are already synched (via the OS - even read/write accesses the same pages). Forcing just synchs between the OS and the drive controller (there can be some delay between the drive controller and the physical platters, but you don't have hardware support to do anything about that). Regardless, memory mapped files are an accepted form of shared memory between threads and/or processes. The only difference between this shared memory and, say, a named block of virtual memory in Windows is the eventual synchronization to disk (in fact mmap does the virtual mem without a file thing by mapping /dev/null). Reading writing memory from multiple processes/threads does still need some synch, as processors are able to do out-of-order execution (not sure how much this interacts with JVMs, but you can't make presumptions), but writing a byte from one thread will have the same guarantees as writing to any byte in the heap normally. Once yo've written to it, every thread, and every process, will see the update (even through an open/read operation). For more info, look up mmap in posix (or CreateFileMapping for Windows, which was built almost the same way.

分享到:
评论

相关推荐

    Java.Threads.3rd.Edition(chm)

    In a few areas, we present complex programs that depend on knowledge of other Java features: AWT, Swing, NIO, and so on. However, the basic principles we present should be understandable by anyone ...

    java面试题英文版及其答案

    By creating and starting multiple threads, a Java application can perform several operations simultaneously, improving overall performance and responsiveness. 6. How does garbage collection work in ...

    java7帮助文档

    Java Virtual Machine Support for Non-Java Languages: Java SE 7 introduces a new JVM instruction that simplifies the implementation of dynamically typed programming languages on the JVM. Garbage-First...

    linux实用脚本show-busy-java-threads

    本文将深入探讨标题所提及的三个实用脚本:“show-busy-java-threads”、“show-duplicate-java-classes”以及“find-in-jars”。这些脚本都是针对Java开发者和系统管理员的利器,旨在提高效率和解决问题。 1. **...

    Java.Threads.and.the.Concurrency.Utilities.1484216997

    Specifically, you learn about threads in the contexts of Swing, JavaFX, and Java 8's Streams API. What you’ll learn How to do thread runnables, synchronization, volatility, waiting and notification...

    show-busy-java-threads.sh文件

    `show-busy-java-threads.sh`脚本就是为了帮助开发者快速定位和排查这类性能问题而设计的。这个脚本主要用于监控并展示Java应用程序中的繁忙线程,从而帮助我们理解程序的执行状态,找出可能导致高CPU负载的原因。 ...

    Java Threads

    《Java Threads》是Java并发编程领域的一本经典著作,由Scott Oaks和Doug Lea合作撰写,由O'Reilly出版社出版。这本书深入浅出地讲解了Java平台上的多线程编程技术,是Java开发者深入理解并发编程的必备参考资料。在...

    微软内部资料-SQL性能优化2

    A process can leak resources such as process memory, pool memory, user and GDI objects, handles, threads, and so on. Memory Concepts (X86 Address Space) Per Process Address Space Every process ...

    Java Threads Third Edition.chm

    Java Threads Third Edition.chm

    Java - A Beginner’s Guide - Sixth Edition - Herbert Schildt

    By following the structured approach laid out in this guide, beginners can gain a solid foundation in Java and develop the skills needed to build robust and efficient applications.

    操作系统英文教学课件:Chapter 4 Threads.ppt

    Chapter 4 of the "Operating System Concepts" course material focuses on the concept of threads, which play a crucial role in modern computing. Threads are the fundamental units of CPU utilization. ...

    Concurrent, Real-Time and Distributed Programming in Java Threads, RTSJ 无水印原版pdf

    Concurrent, Real-Time and Distributed Programming in Java Threads, RTSJ and RMI 英文无水印原版pdf pdf所有页面使用FoxitReader、PDF-XChangeViewer、SumatraPDF和Firefox测试都可以打开 本资源转载自网络...

    深入java虚拟机(inside the java virtual machine)

    java虚拟机的运行机理的详细介绍 Inside the Java Virtual Machine Bill Venners $39.95 0-07-913248-0 Inside the Java Virtual Machine Acknowledgments Introduction Part One: Java's Architecture 1 ...

    Java.7.A.Comprehensive.Tutorial

    Designed as a guidebook for those who want to become a Java developer, Java 7: A Comprehensive Tutorial discusses the essential Java programming topics that you need to master in order teach other ...

    java Threads

    Java线程是多任务编程的核心概念,特别是在Java这种支持并发执行的语言中。本文将深入探讨Java线程的创建、管理以及相关同步机制,基于提供的压缩包文件中的章节名称,我们可以推测这些章节可能涵盖线程的基本概念到...

    show-busy-java-threads

    上传到 linux线上服务器,执行 chmod -R 777 show-busy-java-threads 执行权限。 ./show-busy-java-threads 查看执行占用cpu偏高的 线程,方便我们排查定位。

    Java Threads and the Concurrency Utilities

    《Java多线程与并发工具》一书深入讲解了Java中线程API和并发工具的使用,这些内容是Java语言中最强大但也最具挑战性的API和语言特性之一。对于初学者而言,利用这些特性编写正确的多线程应用程序通常是非常困难的。...

    Developing Games in Java

    Java Threads Chapter 2. 2D Graphics and Animation Chapter 3. Interactivity and User Interfaces Chapter 4. Sound Effects and Music Chapter 5. Creating a 2D Platform Game Chapter 6....

Global site tag (gtag.js) - Google Analytics