构造函数是在文件中所有 其他函数(包括main) 开始执行之前被调用的,而对应的析构函数是在终止main之后调用的。
Demo(int,string); //构造函数
~Demo(); //析构函数
在析构方法中:移除通知!!(❌❌❌使定时器 失效❌❌❌)
- (void)dealloc{ //移除指定的通知,不然会造成内存泄露 [[NSNotificationCenter defaultCenter] removeObserver:self name:@"nameValueNotification" object:nil]; //⭐️Children对象⭐️ 可以 添加多个通知 [[NSNotificationCenter defaultCenter] removeObserver:self];//移除本类(⭐️Children中⭐️)所有通知 }
/** 释放定时器 **/
- (void)deallocTimer{
[_updateDataTimer invalidate]; //定时器失效
_updateDataTimer = nil;
}
视图控制器在自动调用dealloc前,会判断有没有未销毁的NSTimer对象,如果有就不调用dealloc方法。
会导致视图控制器即使出栈了,也没 释放内存。
构造函数:
- (id)init; //不带参 构造函数
- (id)initWithname:(NSString *)name; //带参 构造函数
析构函数:
声明为“- (void)dealloc”,在对象要死的时候自己运行。
-
1.ARC模式下,不能添加“[super dealloc]”。
-
2.MRC模式下,必须添加“[super dealloc]”:(必须在末尾调用“[super dealloc]”。)
- (void)dealloc { [XXX release]; [super dealloc]; ...... }
dealloc使用:
- 1.通知的观察者,或 KVO的观察者
- 2.对象委托/强引用的强解除强(例如:的delegateQueue)
三方库GCDAsyncSocket的参考: </br></br> github地址:
- 3.做一些其他的注销之类的操作(关闭 一些“程序运行期间 没有使用的资源”)。
Tips:Exit() 与 abort()
头文件:
#include <stdlib.h>
头文件:
#include <stdlib.h>
abort()函数首先解除进程对SIGABRT信号的阻止,然后向调用进程发送该信号。abort()函数会导致进程的异常终止除非SIGABRT信号被捕捉并且信号处理句柄没有返回。