0

私はRustが初めてで、2つのFnvHashMapを反復処理して違いを見つけるコードを次に示します

impl SaveChanges for Employee{
    type Item = Employee;
    type List = FnvHashMap<(i32, i32), Employee>;
    type Id = (i32, i32);

    fn find_changes(
        old: &FnvHashMap<(i32, i32), Employee>,
        new: FnvHashMap<(i32, i32), Employee>,
    ) -> Changes<Employee, (i32, i32)> {
  let deleted = second
            .iter()
            .filter(|(a, _)| !new.contains_key(a))
            .map(|(&a, _)| a)
            .collect();

for (_, employee1) in &first {
    for (_, employee2) in &second {
        if employee1.emp_id == employee2.emp_id && employee1.lang_id == employee2.lang_id {
            
                    values.push(OldNew {
                        old: employee2,
                        new: employee1,
                    });
        }
    }
}
     let new = first
            .into_iter()
            .filter(|(a, _)| !old.contains_key(a))
            .map(|(_, a)| a)
            .collect();


 
 Changes {
            deleted,
            new,
            values,
        }
}

pub struct Changes<T, I> {
    pub deleted: Vec<I>,
    pub new: Vec<T>,
    pub values: Vec<OldNew<T>>,
}

これらの値を別のベクトルに追加すると、Rust がコンパイル エラーをスローする

values,
expected struct `organization::models::employee_stat::Employee`, found `&organization::models::employee_stat::Employee`

どんな助けでも本当に感謝しています。ありがとう

4

1 に答える 1