[−][src]Struct internment::Intern
A pointer to an interned object.
The interned object will be held in memory indefinitely. On the
plus side, this means that lifetime issues are simple when using
Intern.
Example
use internment::Intern; let x = Intern::new("hello"); let y = Intern::new("world"); assert_ne!(x, y); assert_eq!(x, Intern::new("hello")); assert_eq!(*x, "hello"); // dereference an Intern like a pointer
Methods
impl<T: Eq + Hash + Send + 'static> Intern<T>[src]
pub fn new(val: T) -> Intern<T>[src]
Intern a value. If this value has not previously been
interned, then new will allocate a spot for the value on the
heap. Otherwise, it will return a pointer to the object
previously allocated.
Note that Intern::new is a bit slow, since it needs to check
a HashSet protected by a Mutex.
pub fn num_objects_interned(&self) -> usize[src]
See how many objects have been interned. This may be helpful in analyzing memory use.
Trait Implementations
impl<T: Eq + Hash + Send + 'static> From<T> for Intern<T>[src]
impl<T> Clone for Intern<T>[src]
fn clone(&self) -> Self[src]
fn clone_from(&mut self, source: &Self)1.0.0[src]
impl<T: Eq + Hash + Send + Default + 'static> Default for Intern<T>[src]
impl<T: PartialOrd> PartialOrd<Intern<T>> for Intern<T>[src]
fn partial_cmp(&self, other: &Self) -> Option<Ordering>[src]
fn lt(&self, other: &Self) -> bool[src]
fn le(&self, other: &Self) -> bool[src]
fn gt(&self, other: &Self) -> bool[src]
fn ge(&self, other: &Self) -> bool[src]
impl<T> Send for Intern<T>[src]
impl<T> Sync for Intern<T>[src]
impl<T> AsRef<T> for Intern<T>[src]
impl<T> Copy for Intern<T>[src]
An Intern is Copy, which is unusal for a pointer. This is safe
because we never free the data pointed to by an Intern.
impl<T> Eq for Intern<T>[src]
impl<T: Ord> Ord for Intern<T>[src]
fn cmp(&self, other: &Self) -> Ordering[src]
fn max(self, other: Self) -> Self1.21.0[src]
fn min(self, other: Self) -> Self1.21.0[src]
fn clamp(self, min: Self, max: Self) -> Self[src]
impl<T> PartialEq<Intern<T>> for Intern<T>[src]
impl<T> Deref for Intern<T>[src]
impl<T: Debug> Debug for Intern<T>[src]
impl<T: Display> Display for Intern<T>[src]
impl<T> Hash for Intern<T>[src]
The hash implementation returns the hash of the pointer value, not the hash of the value pointed to. This should be irrelevant, since there is a unique pointer for every value, but it is observable, since you could compare the hash of the pointer with hash of the data itself.
fn hash<H: Hasher>(&self, state: &mut H)[src]
fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher, 1.3.0[src]
H: Hasher,
impl<T> Pointer for Intern<T>[src]
impl<T> Borrow<T> for Intern<T>[src]
impl<T: Debug> Fits64 for Intern<T>[src]
The Fits64 implementation for Intern<T> is designed to
normally give (relatively) small numbers, by XORing with a fixed
pointer that is also on the heap. This should make the most
significant bits of the resulting u64 be zero, which will mean
that Set64 (which is space-efficient in storing small integers)
can store this result in fewer than 8 bytes.
impl<T: Serialize> Serialize for Intern<T>[src]
impl<'de, T: Eq + Hash + Send + 'static + Deserialize<'de>> Deserialize<'de> for Intern<T>[src]
fn deserialize<D: Deserializer<'de>>(deserializer: D) -> Result<Self, D::Error>[src]
Auto Trait Implementations
impl<T> Unpin for Intern<T>
impl<T> RefUnwindSafe for Intern<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<T> UnwindSafe for Intern<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
Blanket Implementations
impl<T> From<T> for T[src]
impl<T, U> Into<U> for T where
U: From<T>, [src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone, [src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T[src]
fn clone_into(&self, target: &mut T)[src]
impl<T> ToString for T where
T: Display + ?Sized, [src]
T: Display + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>, [src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>, [src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]
impl<T> BorrowMut<T> for T where
T: ?Sized, [src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T[src]
impl<T> Borrow<T> for T where
T: ?Sized, [src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T> DeserializeOwned for T where
T: Deserialize<'de>, [src]
T: Deserialize<'de>,