Struct shmem_bind::ShmemConf
source · pub struct ShmemConf { /* private fields */ }Implementations§
source§impl ShmemConf
impl ShmemConf
sourcepub unsafe fn boxed<T>(self) -> ShmemBox<T>
pub unsafe fn boxed<T>(self) -> ShmemBox<T>
§Safety
this is unsafe because there is no guarantee that the referred T is initialized. the caller must ensure that the value behind the pointer is initialzed before use
Examples found in repository?
examples/message-passing.rs (line 32)
19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
fn main() -> Result<(), Box<dyn Error>> {
// create new shared memory pointer with desired size
//
// first call to this function with the same FILE_LINK_ID would result in creating a new shared
// memory file and owning it. this would result in deleting the shared memory when the variable
// goes out of scope.
// the second call to this function will only open shared memory and would not delete it.
let shared_mem = shmem::Builder::new("shmem-example_message-passing.shm")
.with_size(mem::size_of::<Message>() as i64)
.open()?;
// wrap the raw shared memory ptr with desired Boxed type
// user must ensure that the data the pointer is pointing to is initialized and valid for use
let mut message = unsafe { shared_mem.boxed::<Message>() };
let mut args = std::env::args();
let num_args = args.len();
match num_args {
// parent process
1 => {
// ensure that first process owns the shared memory (used for cleanup)
let mut message = ShmemBox::own(message);
// initiate the data behind the boxed pointer
message.val = 1;
let binary_path = args.next().unwrap();
let new_val = 5;
// create new process to mutate the shared memory
let mut handle = Command::new(&binary_path)
.arg(format!("{new_val}"))
.spawn()
.unwrap();
handle.wait()?;
// assert that the new process mutated the shared memory
assert_eq!(message.val, new_val);
// message is dropped here, shared memory IS deallocated
}
// child process
2 => {
let value = std::env::args().last().unwrap().parse()?;
message.val = value;
// message is dropped here, shared memory IS NOT deallocated
}
_ => unimplemented!(),
}
Ok(())
}Trait Implementations§
Auto Trait Implementations§
impl Freeze for ShmemConf
impl RefUnwindSafe for ShmemConf
impl !Send for ShmemConf
impl !Sync for ShmemConf
impl Unpin for ShmemConf
impl UnwindSafe for ShmemConf
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more