Доступ к полю Impl от закрытия до выделения поля в Rust?

Я новичок в Rust, что, вероятно, будет очевидно.

В основном у меня есть этот сценарий, который вы можете увидеть ниже, где я создаю новый тип, к которому добавлено закрытие, но это закрытие требует доступа к данным, которые еще не были созданы. Данные будут созданы к моменту вызова замыкания, но при первоначальном создании замыкания данные еще не доступны.

Как лучше всего справиться?

Мне также любопытно, если бы мое закрытие было не закрытием, а скорее частной функцией в моей реализации, как мне получить доступ к этим данным? Это закрытие / функция является обратным вызовом от WasmTime и требует явной сигнатуры метода, которая не позволяет мне добавлять к ней $self. Итак, как я могу получить доступ к полям экземпляра реализации без ссылки на $self в параметрах функции?

      pub struct EmWasmNode {
    wasmStore: Store<WasiCtx>,
    wasmTable: Table,
}

impl EmWasmNode {
    pub fn new(filePath: &str) -> Result<Self> {

        let engine = Engine::default();
        // let module = Module::from_file(&engine, "wasm/index.wast")?;
        let module = Module::from_file(&engine, filePath)?;
        let mut linker = Linker::new(&engine);
        wasmtime_wasi::add_to_linker(&mut linker, |s| s)?;

        let wasi = WasiCtxBuilder::new()
            .inherit_stdio()
            .inherit_args()?
            .build();
        let mut store = Store::new(&engine, wasi);

        linker.func_wrap("env", "emscripten_set_main_loop", |p0: i32, p1: i32, p2: i32| {
            println!("emscripten_set_main_loop {} {} {}", p0, p1, p2);
/*** How would I access wasmTable and wasmStore from here to execute more methods??? ***/

            //let browserIterationFuncOption:Option<wasmtime::Val> = Self::wasmTable.get(&mut Self::wasmStore, p0 as u32);
            // browserIterationFuncOption.unwrap().unwrap_funcref().call(&store, ());
        })?;

        let instance = linker.instantiate(&mut store, &module)?;

        let table = instance
            .get_export(&mut store, "__indirect_function_table")
            .as_ref()
            .and_then(extern_table)
            .cloned();

        let start = instance.get_typed_func::<(), (), _>(&mut store, "_start")?;

        start.call(&mut store, ())?;

        Ok(EmWasmNode {
            wasmStore: store,
            wasmTable: table.unwrap(),
        })
    }

1 ответ

Вы должны создать экземпляр структуры раньше. Я предлагаю более простой код ниже, чтобы увидеть мою идею.

      struct Atype
{
    name: String,
}

impl Atype
{
    pub fn new() -> Self
    {
        Self{ name: String::from("zeppi")}
    }
    
    pub fn test(&self) -> ()
    {
        let func = | x | { println!("{} {}", &self.name, x);};
        func(3)
    }
}

fn main() {
    let o = Atype::new();
    o.test();
}
Другие вопросы по тегам