added associated function Box::leak
This commit is contained in:
parent
7ca430df71
commit
360ce780fd
1 changed files with 41 additions and 0 deletions
|
|
@ -364,6 +364,47 @@ impl<T: ?Sized> Box<T> {
|
|||
pub fn into_unique(b: Box<T>) -> Unique<T> {
|
||||
unsafe { mem::transmute(b) }
|
||||
}
|
||||
|
||||
/// Consumes and leaks the `Box`, returning a static reference,
|
||||
/// `&'static T`.
|
||||
///
|
||||
/// This function is mainly useful for data that lives for the remainder of
|
||||
/// the programs life. Dropping the returned reference will cause a memory
|
||||
/// leak. If this is not acceptable, the reference should first be wrapped
|
||||
/// with the [`Box::from_raw`] function producing a `Box` which can then be
|
||||
/// dropped which will properly destroy `T` and release the memory.
|
||||
///
|
||||
/// Note: this is an associated function, which means that you have
|
||||
/// to call it as `Box::leak(b)` instead of `b.leak()`. This
|
||||
/// is so that there is no conflict with a method on the inner type.
|
||||
///
|
||||
/// [`Box::from_raw`]: struct.Box.html#method.from_raw
|
||||
///
|
||||
/// # Examples
|
||||
///
|
||||
/// Simple usage:
|
||||
///
|
||||
/// ```
|
||||
/// let x = Box::new(41);
|
||||
/// let static_ref = Box::leak(x);
|
||||
/// *static_ref += 1;
|
||||
/// assert_eq!(*static_ref, 42);
|
||||
/// ```
|
||||
///
|
||||
/// Unsized data:
|
||||
///
|
||||
/// ```
|
||||
/// let x = vec![1, 2, 3].into_boxed_slice();
|
||||
/// let static_ref = Box::leak(x);
|
||||
/// static_ref[0] = 4;
|
||||
/// assert_eq!(*static_ref, [4, 2, 3]);
|
||||
/// ```
|
||||
#[unstable(feature = "box_leak", reason = "needs an FCP to stabilize",
|
||||
issue = "0")]
|
||||
#[inline]
|
||||
pub fn leak(b: Box<T>) -> &'static mut T {
|
||||
unsafe { &mut *Box::into_raw(b) }
|
||||
}
|
||||
}
|
||||
|
||||
#[stable(feature = "rust1", since = "1.0.0")]
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue