@Name(value="c10::intrusive_ptr<c10::RRefInterface>") @NoOffset @Properties(inherit=torch.class) public class RRefInterfacePtr extends Pointer
Pointer.CustomDeallocator, Pointer.Deallocator, Pointer.NativeDeallocator, Pointer.ReferenceCounter
Constructor and Description |
---|
RRefInterfacePtr() |
RRefInterfacePtr(long size)
Native array allocator.
|
RRefInterfacePtr(Pointer p)
Pointer cast constructor.
|
RRefInterfacePtr(PointerPointer arg0) |
RRefInterfacePtr(RRefInterface target,
DontIncreaseRefcount arg1) |
RRefInterfacePtr(RRefInterfacePtr rhs) |
Modifier and Type | Method and Description |
---|---|
RRefInterface |
access() |
boolean |
asBoolean() |
boolean |
defined() |
RRefInterface |
get() |
RRefInterfacePtr |
getPointer(long i) |
RRefInterface |
multiply() |
RRefInterfacePtr |
position(long position) |
RRefInterfacePtr |
put(RRefInterfacePtr rhs) |
static RRefInterfacePtr |
reclaim_copy(RRefInterface owning_ptr)
Takes an owning pointer to TTarget* and creates an intrusive_ptr
representing a new reference, i.e.
|
static RRefInterfacePtr |
reclaim(RRefInterface owning_ptr)
Takes an owning pointer to TTarget* and creates an intrusive_ptr that takes
over ownership.
|
RRefInterface |
release()
Returns an owning (!) pointer to the underlying object and makes the
intrusive_ptr instance invalid.
|
void |
reset() |
void |
swap(RRefInterfacePtr rhs) |
boolean |
unique() |
static RRefInterfacePtr |
unsafe_adapt_non_heap_allocated(RRefInterface raw_ptr,
long expected_decrefs)
Turn an instance of TTarget that should not be reference counted
(e.g., allocated into an arena with placement new) into an
intrusive_ptr.
|
static RRefInterfacePtr |
unsafe_reclaim_from_nonowning(RRefInterface raw_ptr)
Turn a **non-owning raw pointer** to an intrusive_ptr.
|
static RRefInterfacePtr |
unsafe_steal_from_new(RRefInterface raw_ptr)
Turn a new instance of TTarget (e.g., literally allocated
using new TTarget(...) into an intrusive_ptr.
|
long |
use_count() |
long |
weak_use_count() |
address, asBuffer, asByteBuffer, availablePhysicalBytes, calloc, capacity, capacity, close, deallocate, deallocate, deallocateReferences, deallocator, deallocator, equals, fill, formatBytes, free, getDirectBufferAddress, getPointer, getPointer, getPointer, hashCode, interruptDeallocatorThread, isNull, isNull, limit, limit, malloc, maxBytes, maxPhysicalBytes, memchr, memcmp, memcpy, memmove, memset, offsetAddress, offsetof, offsetof, parseBytes, physicalBytes, physicalBytesInaccurate, position, put, realloc, referenceCount, releaseReference, retainReference, setNull, sizeof, sizeof, toString, totalBytes, totalCount, totalPhysicalBytes, withDeallocator, zero
public RRefInterfacePtr(Pointer p)
Pointer(Pointer)
.public RRefInterfacePtr(long size)
Pointer.position(long)
.public RRefInterfacePtr()
public RRefInterfacePtr(@ByVal @Cast(value="std::nullptr_t*") PointerPointer arg0)
public RRefInterfacePtr(RRefInterface target, @ByVal DontIncreaseRefcount arg1)
public RRefInterfacePtr(@ByRef(value=true) RRefInterfacePtr rhs)
public RRefInterfacePtr position(long position)
public RRefInterfacePtr getPointer(long i)
getPointer
in class Pointer
@ByRef @Name(value="operator =") @NoException(value=true) public RRefInterfacePtr put(@ByRef(value=true) RRefInterfacePtr rhs)
@NoException(value=true) public RRefInterface get()
@ByRef @Name(value="operator *") @NoException(value=true) public RRefInterface multiply()
@Name(value="operator ->") @NoException(value=true) public RRefInterface access()
@Cast(value="bool") @Name(value="operator bool") @NoException(value=true) public boolean asBoolean()
@NoException(value=true) public void reset()
@NoException(value=true) public void swap(@ByRef RRefInterfacePtr rhs)
@Cast(value="bool") @NoException(value=true) public boolean defined()
@Cast(value="size_t") @NoException(value=true) public long use_count()
@Cast(value="size_t") @NoException(value=true) public long weak_use_count()
@Cast(value="bool") @NoException(value=true) public boolean unique()
@NoException(value=true) public RRefInterface release()
@ByVal public static RRefInterfacePtr reclaim(RRefInterface owning_ptr)
@ByVal public static RRefInterfacePtr reclaim_copy(RRefInterface owning_ptr)
@ByVal public static RRefInterfacePtr unsafe_steal_from_new(RRefInterface raw_ptr)
@ByVal public static RRefInterfacePtr unsafe_adapt_non_heap_allocated(RRefInterface raw_ptr, @Cast(value="size_t") long expected_decrefs)
expected_decrefs
is a debugging parameter: it indicates the
number of strong owners the intrusive_ptr_target in question is
expected to get. In most use cases, this will likely be 1.
The reason this method exists is for manually sharing
StorageImpls across Tensors in the static runtime. It needs
access to private intrusive_ptr members so that the refcounts can
be initialized to custom values.@ByVal public static RRefInterfacePtr unsafe_reclaim_from_nonowning(RRefInterface raw_ptr)
Copyright © 2024. All rights reserved.