弱引用-ios 与xib视图加载相关的内存管理问题

问题描述

ios 与xib视图加载相关的内存管理问题

在通过xib加载视图的时候,我们遵循一个准侧
那就是顶层视图 我们的成员变量要是强引用 若是非顶层视图,而是顶层视图的子视图,为了防止顶层视图被释放以后,字视图还存在而造成的内存泄漏,我们把这字视图的成员变量定义为弱饮用
现在问题是,在ARC模式下,假如我有个视图控制起ViewController,然后有个UIButton子视图
@interface ViewController:UIViewController
{
weak/strong IBOutlet UIButton* button;

这时,在ARC模式下,无论我是指定它是强引用,还是弱引用,在加载了xib文件中(xib中设置了button和一个UIButton的关联),用
NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)button));方法查看button的retainCount,都一样是3

所以我就不了解了,不是强应用会使对象的retainCount加1,而弱引用不会影响对象的retainCount吗?怎么无论用strong还是weak,得到的retainCount都是相同值呢?
在加载xib文件时,底层到底是怎样给button赋值的?

真的想不明白,请各位大神指教一下,不胜感激

解决方案

这个跟你是不是 xib 没关系的, 就算你用代码创建也是一样,对于你的问题,给你看个例子

     UILabel *label = [[UILabel alloc] initWithFrame:CGRectMake(0, 40, 30, 30)];
    label.backgroundColor = [UIColor yellowColor];
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)label));
    [self.view addSubview:label];
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)label));
    __weak UILabel *aLabel = label;
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)label));
    NSLog(@"Retain count is %ld", CFGetRetainCount((__bridge CFTypeRef)aLabel));

输出是:1,2,2,3
这跟我们以前的理解方式很不同,它仅仅是 weak 变量的 retainCount +1 ,而没有影响到其他变量。所以 weak 的 retainCount 管理是独立的。当只剩下 weak 引用时,就会被自动清零并释放

解决方案二:

weak修饰非基本数据类型,还是会影响retainCount的计数,跟strong的区别是释放的点不一样(什么时候被释放),weak修饰基本数据类型时,才不影响retainCount。

解决方案三:

weak 是会影响 retainCount,但不影响对象的释放,这点跟 assign 不同,assign 类型的属性被赋值时 retainCount 不变, 但 weak 类型会导致 retainCount +1,这里 retainCount 变化并不是由于 retain 引起的。它仅仅是修改计数,当 retainCount == weak引用的数量时,对象就会被释放

时间: 2024-10-18 06:14:45

弱引用-ios 与xib视图加载相关的内存管理问题的相关文章

IOS中使用UIWebView 加载网页、文件、 html的方法_IOS

 UIWebView 是用来加载加载网页数据的一个框.UIWebView可以用来加载pdf word doc 等等文件 生成webview 有两种方法: 1.通过storyboard 拖拽 2.通过alloc init 来初始化 创建webview,下列文本中 _webView.dataDetectorTypes = UIDataDetectorTypeAll; 是识别webview中的类型,例如 当webview中有电话号码,点击号码就能直接打电话 - (UIWebView *)webView

IOS中的webView加载HTML_IOS

在日常开发中,我们为了效率会用到很多很多的WebView,比如在做某个明细页面的时候我们返回给你的可能是一个html字符串,我们就需要将当前字符串展示到webView上面,所以我们对HTML标签需要有一定的认识,下面我们来一起用html标签和JS写一个打地鼠游戏,这里我们主要讲解HTML标签的书写,只要如何和webView适配涉及到响应式布局我们下次讲解: 1.首先我们先新建一个html文件 2 完整html标签并且设置编码格式为UTF-8 3 在body里面增加十只老鼠图片,并且增加点击事件,

图片搜索-<img>图片什么时候加载相关问题

问题描述 <img>图片什么时候加载相关问题 文档中有这样一个图片元素,一般来说,该元素被浏览器解析后就会加载src中的链接的图片. 如果,在img的样式表中将图片元素显示为不可见,img{display:none},或者img{visibility:hidden}, 那么,img元素中src链接的图片会照样加载还是不会加载 解决方案 不管显示不显示,都是会加载的,你可以通过浏览器的开发人员工具(一般来说是F12)查看页面请求时浏览器发起的所有请求 解决方案二: 当然加载..还有Image对象

内存泄漏-IE8 使用img对象动态加载图片,内存一直增长

问题描述 IE8 使用img对象动态加载图片,内存一直增长 最近使用一个图片插件,在IE8使用img对象动态加载图片的时候,内存不断增长,不会释放,直到内存不够用,系统卡死,求大大解决 解决方案 0最近使用一个图片插件,在IE8使用img对象动态加载图片的时候,内存不断增长,不会释放,直到内存不够用,系统卡死,求大大解决

tomcat5-类加载机制 Tomcat5 shared目录下加载的Spring如何管理Tomcat中部署的多个项目

问题描述 类加载机制 Tomcat5 shared目录下加载的Spring如何管理Tomcat中部署的多个项目 20C 我们知道Tomcat5.x类加载体系结构如下:不同的类加载器加载不同路径上的类或jar包. Bootstrap | System | Common / Catalina Shared / Webapp1 Webapp2有这样一个场景,在Tomcat5.x下部署了10个项目,每个项目都是用Spring来组织和管理的,可以吧Spring放到Tomcat的Common或Shared目

android-Android 通过RGB_565加载图片在内存中占用大小

问题描述 Android 通过RGB_565加载图片在内存中占用大小 我有一张 420*210 的png图片,放在assets 目录下.通过如下方式加载到内存中: BitmapFactory.Options options =new BitmapFactory.Options(); options.inPreferredConfig = Bitmap.Config.RGB_565; Bitmap bitmap = BitmapFactory.decodeStream(getClassLoader

[Android]异步加载图片,内存缓存,文件缓存,imageview显示图片时增加淡入淡出动画

以下内容为原创,欢迎转载,转载请注明 来自天天博客:http://www.cnblogs.com/tiantianbyconan/p/3574131.html  这个可以实现ImageView异步加载图片,内存缓存,文件缓存,imageview显示图片时增加淡入淡出动画. github地址:https://github.com/wangjiegulu/ImageLoaderSample 解决了: 1. listview加载oom问题 2. listview加载时卡顿的现象 3. listview

iOS中UIWebView网页加载组件的基础及使用技巧实例_IOS

基本用法示例 - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. UIWebView * webView = [[UIWebView alloc]initWithFrame:CGRectMake(0, 20, ScreenWidth, ScreenHeight-20)]; // 自动队页面进行缩放以适应屏幕 webView.scalesPageToFit = Y

WPF循环加载图片导致内存溢出如何解决

程序场景:一系列的图片,从第一张到最后一张依次加载图片,形成"动画". 生成BitmapImage的方法有多种: 1.var source=new BitmapImage(new Uri("图片路径",UriKind.xxx)); 一般的场景使用这种方法还是比较方便快捷,但是对于本场景,内存恐怕得爆.2. var data =File.ReadAllBytes("图片路径"); var ms = new System.IO.MemoryStrea