I've got a vector of mutable references:
struct T;
let mut mut_vec: Vec<&mut T> = vec![];
How can I pass (a copy of) it into a function that takes a vector of immutable references?
fn cool_func(mut immut_vec: Vec<&T>) {}
I've got a vector of mutable references:
struct T;
let mut mut_vec: Vec<&mut T> = vec![];
How can I pass (a copy of) it into a function that takes a vector of immutable references?
fn cool_func(mut immut_vec: Vec<&T>) {}
You can dereference and reborrow the mutable references, then add them to a new Vec
:
fn main() {
let mut st = String::new();
let mut_vec = vec![&mut st];
let immut_vec = mut_vec.into_iter().map(|x| &*x).collect();
cool_func(immut_vec);
}
fn cool_func(_: Vec<&String>) {}
Note however, that this consumes the original Vec
- you can't really get around this, as if the original Vec
still existed, you'd have both mutable and immutable references to the same piece of data, which the compiler will not allow.
If you need to actually convert, see Joe Clay's answer. However, you might not need to convert in the first place!
Instead of changing the argument, change the function so that it accepts both mutable and immutable references. Here we use Borrow
to abstract over both:
use std::borrow::Borrow;
fn main() {
let mut st = String::new();
let mut_vec = vec![&mut st];
cool_func(mut_vec);
let immut_vec = vec![&st];
cool_func(immut_vec);
}
fn cool_func<S>(_: Vec<S>)
where
S: Borrow<String>,
{
}
See also: