Share via


FileLock 클래스

정의

파일 영역에 대한 잠금을 나타내는 토큰입니다.

[Android.Runtime.Register("java/nio/channels/FileLock", DoNotGenerateAcw=true)]
public abstract class FileLock : Java.Lang.Object, IDisposable, Java.Interop.IJavaPeerable, Java.Lang.IAutoCloseable
[<Android.Runtime.Register("java/nio/channels/FileLock", DoNotGenerateAcw=true)>]
type FileLock = class
    inherit Object
    interface IAutoCloseable
    interface IJavaObject
    interface IDisposable
    interface IJavaPeerable
상속
FileLock
특성
구현

설명

파일 영역에 대한 잠금을 나타내는 토큰입니다.

파일 잠금 개체는 클래스의 또는 메서드 중 하나 또는 클래스의 FileChannel#lock(long,long,boolean) lockFileChannel 메서드를 통해 파일에 잠금을 AsynchronousFileChannel#lock(long,long,boolean,Object,CompletionHandler) lockAsynchronousFileChannel#tryLock(long,long,boolean) tryLockAsynchronousFileChannel 가져올 때마다 만들어집니다.FileChannel#tryLock(long,long,boolean) tryLock

파일 잠금 개체는 처음에 유효합니다. 메서드를 호출하거나, 잠금을 획득하는 #release release 데 사용된 채널을 닫거나, Java 가상 머신이 종료될 때까지 잠금이 해제될 때까지 유효합니다. 잠금의 유효성은 해당 #isValid isValid 메서드를 호출하여 테스트할 수 있습니다.

파일 잠금은 배타 적이거나 공유됩니다. 공유 잠금은 동시에 실행되는 다른 프로그램이 겹치는 배타적 잠금을 획득하는 것을 방지하지만 겹치는 공유 잠금을 획득할 수 있습니다. 배타적 잠금은 다른 프로그램이 두 형식의 겹치는 잠금을 획득하지 못하도록 합니다. 잠금이 해제되면 잠금은 다른 프로그램에서 획득할 수 있는 잠금에 더 이상 영향을 주지 않습니다.

잠금이 배타적인지 공유되는지 여부는 해당 #isShared isShared 메서드를 호출하여 확인할 수 있습니다. 일부 플랫폼에서는 공유 잠금을 지원하지 않습니다. 이 경우 공유 잠금 요청이 배타적 잠금 요청으로 자동으로 변환됩니다.

단일 Java 가상 머신이 특정 파일에 보관하는 잠금은 겹치지 않습니다. 메서드를 #overlaps overlaps 사용하여 후보 잠금 범위가 기존 잠금과 겹치는지 여부를 테스트할 수 있습니다.

파일 잠금 개체는 잠금이 유지되는 파일, 잠금의 형식 및 유효성, 잠긴 영역의 위치 및 크기에 대한 파일 채널을 기록합니다. 잠금의 유효성만 시간이 지남에 따라 변경될 수 있습니다. 잠금 상태의 다른 모든 측면은 변경할 수 없습니다.

파일 잠금은 전체 Java 가상 머신을 대신하여 유지됩니다. 동일한 가상 머신 내의 여러 스레드에서 파일에 대한 액세스를 제어하는 데 적합하지 않습니다.

파일 잠금 개체는 여러 동시 스레드에서 사용하기에 안전합니다.

"pdep"><h2> 플랫폼 종속성 </h2>

이 파일 잠금 API는 기본 운영 체제의 네이티브 잠금 시설에 직접 매핑하기 위한 것입니다. 따라서 파일에 보관된 잠금은 해당 프로그램이 작성된 언어에 관계없이 파일에 액세스할 수 있는 모든 프로그램에 표시되어야 합니다.

잠금이 실제로 다른 프로그램이 잠긴 지역의 콘텐츠에 액세스하는 것을 방지하는지 여부는 시스템에 따라 달라지므로 지정되지 않습니다. 일부 시스템의 네이티브 파일 잠금 기능은 단지 권고에 불과하므로 프로그램은 데이터 무결성을 보장하기 위해 알려진 잠금 프로토콜을 협조적으로 관찰해야 합니다. 다른 시스템에서는 네이티브 파일 잠금이 필수입니다. 즉, 한 프로그램에서 파일 영역을 잠그면 다른 프로그램이 잠금을 위반하는 방식으로 해당 지역에 실제로 액세스하지 못하게 됩니다. 그러나 다른 시스템에서는 네이티브 파일 잠금이 권고 또는 필수인지 여부를 파일별로 구성할 수 있습니다. 플랫폼 간에 일관되고 올바른 동작을 보장하려면 이 API에서 제공하는 잠금을 권고 잠금인 것처럼 사용하는 것이 좋습니다.

일부 시스템에서는 파일 영역에 대한 필수 잠금을 획득하면 해당 지역이 이 되는 것을 java.nio.channels.FileChannel#map <i>mapped into memory</i>방지하고 그 반대의 경우도 마찬가지입니다. 잠금 및 매핑을 결합하는 프로그램은 이 조합이 실패할 수 있도록 준비해야 합니다.

일부 시스템에서는 채널을 닫으면 해당 채널을 통해 잠금을 획득했는지 또는 같은 파일에서 열려 있는 다른 채널을 통해 잠금을 획득했는지 여부에 관계없이 기본 파일에서 Java 가상 머신이 보유한 모든 잠금이 해제됩니다. 프로그램 내에서 고유한 채널을 사용하여 지정된 파일의 모든 잠금을 획득하는 것이 좋습니다.

일부 네트워크 파일 시스템은 잠긴 영역이 페이지 정렬되고 기본 하드웨어의 페이지 크기의 전체 배수인 경우에만 메모리 매핑 파일과 함께 파일 잠금을 사용할 수 있도록 허용합니다. 일부 네트워크 파일 시스템은 특정 위치(종종 2 sup 30</sup> 또는><2<sup>31</sup>)를 지나 확장되는 지역에서 파일 잠금을 구현하지 않습니다. 일반적으로 네트워크 파일 시스템에 있는 파일을 잠글 때는 주의해야 합니다.

1.4에 추가되었습니다.

에 대한 Java 설명서입니다 java.nio.channels.FileLock.

이 페이지의 일부는 만들고 공유하며 에 설명된 조건에 따라 사용되는 작업을 기반으로 수정됩니다.

생성자

FileLock(AsynchronousFileChannel, Int64, Int64, Boolean)

이 클래스의 새 인스턴스를 초기화합니다.

FileLock(FileChannel, Int64, Int64, Boolean)

이 클래스의 새 인스턴스를 초기화합니다.

FileLock(IntPtr, JniHandleOwnership)

JNI 개체의 관리형 표현을 만들 때 사용되는 생성자입니다. 런타임에서 호출합니다.

속성

Class

Object의 런타임 클래스를 반환합니다.

(다음에서 상속됨 Object)
Handle

기본 Android instance 대한 핸들입니다.

(다음에서 상속됨 Object)
IsShared

이 잠금이 공유되는지 여부를 알려줍니다.

IsValid

이 잠금이 유효한 파일 잠금인지 여부를 나타냅니다.

JniIdentityHashCode

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
JniPeerMembers

파일 영역에 대한 잠금을 나타내는 토큰입니다.

PeerReference

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
ThresholdClass

이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다.

ThresholdType

이 API는 Android용 Mono 인프라를 지원하며 코드에서 직접 사용할 수 없습니다.

메서드

AcquiredBy()

이 잠금을 획득한 파일이 있는 채널을 반환합니다.

Channel()

이 잠금을 획득한 파일이 있는 파일 채널을 반환합니다.

Clone()

이 개체의 복사본을 만들고 반환합니다.

(다음에서 상속됨 Object)
Close()

이 메서드는 메서드를 #release 호출합니다.

Dispose()

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
Dispose(Boolean)

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
Equals(Object)

다른 개체가 이 개체와 "같음"인지 여부를 나타냅니다.

(다음에서 상속됨 Object)
GetHashCode()

개체의 해시 코드 값을 반환합니다.

(다음에서 상속됨 Object)
JavaFinalize()

가비지 수집에서 개체에 대한 참조가 더 이상 없다고 판단할 때 개체의 가비지 수집기에서 호출됩니다.

(다음에서 상속됨 Object)
Notify()

이 개체의 모니터에서 대기 중인 단일 스레드를 해제합니다.

(다음에서 상속됨 Object)
NotifyAll()

이 개체의 모니터에서 대기 중인 모든 스레드를 해제합니다.

(다음에서 상속됨 Object)
Overlaps(Int64, Int64)

이 잠금이 지정된 잠금 범위와 겹치는지 여부를 알려줍니다.

Position()

잠긴 영역의 첫 번째 바이트 파일 내의 위치를 반환합니다.

Release()

이 잠금을 해제합니다.

SetHandle(IntPtr, JniHandleOwnership)

Handle 속성을 설정합니다.

(다음에서 상속됨 Object)
Size()

잠긴 영역의 크기를 바이트 단위로 반환합니다.

ToArray<T>()

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
ToString()

이 잠금의 범위, 형식 및 유효성을 설명하는 문자열을 반환합니다.

UnregisterFromRuntime()

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
Wait()

현재 스레드가 깨어날 때까지 대기하게 합니다( 일반적으로 <알림을 받><거나 <>중단/>em>)합니다<.

(다음에서 상속됨 Object)
Wait(Int64)

현재 스레드가 깨어날 때까지 대기하게 합니다. 일반적으로 <>알림을 받<거나 <중단</>내보내>>거나 일정량의 실시간이 경과할 때까지 대기합니다.

(다음에서 상속됨 Object)
Wait(Int64, Int32)

현재 스레드가 깨어날 때까지 대기하게 합니다. 일반적으로 <>알림을 받<거나 <중단</>내보내>>거나 일정량의 실시간이 경과할 때까지 대기합니다.

(다음에서 상속됨 Object)

명시적 인터페이스 구현

IJavaPeerable.Disposed()

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
IJavaPeerable.DisposeUnlessReferenced()

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
IJavaPeerable.Finalized()

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
IJavaPeerable.JniManagedPeerState

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
IJavaPeerable.SetJniIdentityHashCode(Int32)

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
IJavaPeerable.SetJniManagedPeerState(JniManagedPeerStates)

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)
IJavaPeerable.SetPeerReference(JniObjectReference)

파일 영역에 대한 잠금을 나타내는 토큰입니다.

(다음에서 상속됨 Object)

확장 메서드

JavaCast<TResult>(IJavaObject)

Android 런타임 확인 형식 변환을 수행합니다.

JavaCast<TResult>(IJavaObject)

파일 영역에 대한 잠금을 나타내는 토큰입니다.

GetJniTypeName(IJavaPeerable)

파일 영역에 대한 잠금을 나타내는 토큰입니다.

적용 대상