wpf-MVVM绑定时可能出现的内存泄漏问题

本文探讨了WPF中View直接引用Model可能导致的内存泄漏问题,介绍了正确使用ViewModel层以避免静态变量强引用的示例,并指出滥用ObservableCollection结构对MVVM架构的影响。
摘要由CSDN通过智能技术生成

坚持记录实属不易,希望友善多金的码友能够随手点一个赞。
共同创建氛围更加良好的开发者社区!
谢谢~

引言

正确结构:

Model <——> ViewModel <——> View

但很多时候,很容易出现 View上直接引用Model数据的情况;当这种情况发生时,WPF将创建静态变量绑定源(即ViewModel)的强引用,导致内存泄漏。

错误示范

出现的问题:

此时,由于 view上绑定的数据 是直接到 model 上获取的,因此会造成内存泄漏的问题。

class Model
{
	public int Age{get;set;}
	public string Name{get;set;}
	
	public Model(){}
}

public ViewModel
{
	public ObservableCollection<Model> ItemSource = new ObservableCollection<Model>();
	
	.....
}


xmal:

<ListView>
    <ListView.View>
        <GridView>
        	<GridViewColumn Header = "年龄“ DisplayMemberBinding="{Binding Age}"/>
        	<GridViewColumn Header = "姓名" DisplayMemberBinding = "{Binding Name}/>
        </GridView>
    </ListView.View>
</ListView>

示例1

在Xmal文件不变动的情况下;可以 ViewModel 套用ViewModel形式。

是否调用Propertychanged实际上不重要,重要是该类是从INotifyPropertyChanged派生的,因为这回告诉WPF不要创建强引用。

class ViewModel2:INotifyPropertyChanged
{
	//propfull属性,实现INotifyPropertyChanged
	
	private int age;
	public int Age
	{
		get
		{
			return age;
		}
		set
		{
			age = value;
			PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(Age)));
		}
	}
	
	public Model(){}
}

public ViewModel
{
	public ObservableCollection<ViewModel2> ItemSource = new ObservableCollection<ViewModel2>();
	
	.....
}


xmal:

<ListView>
    <ListView.View>
        <GridView>
        	<GridViewColumn Header = "年龄“ DisplayMemberBinding="{Binding Age}"/>
        	<GridViewColumn Header = "姓名" DisplayMemberBinding = "{Binding Name}/>
        </GridView>
    </ListView.View>
</ListView>

示例2

会极大的破坏mvvm结构,在功能较小时,可以试用
使用 T:ObservableCollection 结构


public ViewModel:ObservableCollection<ViewModel>
{
//此时具有列表的属性
	public int Age{get;set;}
	public string Name{get;set;}
}


xmal.cs:

ViewModel ViewModel = new ViewModel();
//初始化时
listView.ItemsSource = ViewModel;


xmal:

<ListView x:Name = "listVeiw">
    <ListView.View>
        <GridView>
        	<GridViewColumn Header = "年龄“ DisplayMemberBinding="{Binding Age}"/>
        	<GridViewColumn Header = "姓名" DisplayMemberBinding = "{Binding Name}/>
        </GridView>
    </ListView.View>
</ListView>
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

默九思

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值