使用ceil函数获取大于当前值的最小整数,虽然返回值和输入值是一致的,但是返回值小数位都为0
float a = ceil(0.5)
float a = 1
//拓展
int abs(int i) 返回整型参数i的绝对值
double cabs(struct complex znum) 返回复数znum的绝对值
double fabs(double x) 返回双精度参数x的绝对值
long labs(long n) 返回长整型参数n的绝对值
double ceil(double x) 返回大于或等于x的最小整数(向上取整)
double floor(double x)返回小于或等于x的最大整数(向下取整)
0xFF0000 >> 16
算数右移十六位,不足的补0
iOS系统保持屏幕常量
[UIApplication sharedApplication].idleTimerDisabled = NO;//这个页面屏幕取消常亮
[UIApplication sharedApplication].idleTimerDisabled = YES;//保持常亮
判断iOS系统版本
if([[UIDevice currentDevice].systemVersion floatValue]>= 10.0)
@()
强转基本类型为NSNumber类型或nsvalue
instancetype 只能作为函数的返回值,返回类型是该方法所在类的类型
手动实现@property所有属性(get、set)时,需要在.m文件中声明
@synthesize name = _name;
获取手机基站信号强度
UIApplication *app = [UIApplicationsharedApplication];
NSArray *children = [[[app valueForKeyPath:@"statusBar"] valueForKeyPath:@"foregroundView"] subviews];
for (id child in children) {
if ([child isKindOfClass:NSClassFromString(@"UIStatusBarSignalStrengthItemView")]) {
type = [child valueForKeyPath:@"signalStrengthRaw"];
break;
}
}
NSInteger signalStregth=[type integerValue];
if (signalStregth<0){
self.showLabel.text=[NSString stringWithFormat: @"%ld", (long)signalStregth];
}
导包
#import <系统提供.h>
#import "自定义的头文件.h"
变量访问权限
目的:数据的封装性,便于数据的保护
@public 共有类型,所有类都可以访问
@protected 保护类型,该类,和该类的子类可以访问
@private 私有类型,只有该类可以访问
默认类型protected
const关键字
(1) const用来修饰右边的基本变量或指针变量
(2) 被修饰的变量只读,不能被修改
int a = 10,b=20;
int const *p = &a; //定义的时候 *p代表地址,定义完之后 p 代表地址 *p 是 10,p可以修改,*p不可以修改
int * const p = &a;// *p 可以修改,而且顺便把a的值也改了
const int *p; //*p只读
const int * const p; //p和*p都只读
int const * const p; //p和*p都只读
string * const name = “name"; //name 不可以在赋值其他的数
static关键字
作用:
1、修饰局部变量 :保证局部变量永远只初始化一次,在程序的运行过程中永远只有一份内存, 生命周期类似全局变量了,但是作用域不变。
2、使全局变量的作用域仅限于当前文件内部,即当前文件内部才能访问该全局变量。
3、static修饰函数时,被修饰的函数被称为静态函数,使得外部文件无法访问这个函数,仅本文件可以访问。
extern关键字
用来声明外部全局变量或函数,注意extern只能声明不能实现,表示该变量或函数在其他地方已经实现,这里只是引用而已
宏定义
#pragma mark 代码标记
#pragma mark - 代码块标记(一般都是给函数分界)
KVC底层实现
当一个对象调用setValue方法时,方法内部会做如下操作:
1、检查是否存在相应的key的set方法,如果存在就调用set方法
2、如果不存在set方法,就会查找与key相同名称,并且带下划线的成员属性,如果有,就直接给成员属性赋值
3、如果没有_key,就会查找key同名称不带下划线的属性,有就赋值
4、如果也没有就会调用valueForUndefinedKey:和setValue:forUndefinedKey:方法,这些方法的默认实现都是抛出异常,可以按需重写他们
KVO底层实现
1、kvo基于runtime机制实现
2、使用了isa混写(isa-swizzling),当一个对象(假设是person对象,person的类是MYPerson)的属性值(如age)发生变化的时候,系统会自动生成一个类,继承自MYPerson,NSKVONotifying_MYPerson:MYPerson,在这个类的setAge中,调用[self willChangeValueForKey:"age"],[super setAge:age],[self didchangeValueForKey:"age"],这两个change方法会调用监听者内部的-observeValueForKeyPath这个方法