const簡介:之前常用的字符串常量,一般是抽成宏蛹疯,但是蘋果不推薦我們抽成宏,推薦我們使用const常量热监。
編譯時刻:宏是預編譯(編譯之前處理)捺弦,const是編譯階段。
編譯檢查:宏不做檢查孝扛,不會報編譯錯誤列吼,只是替換,const會編譯檢查苦始,會報編譯錯誤寞钥。
宏的好處:宏能定義一些函數(shù),方法陌选。 const不能理郑。
宏的壞處:使用大量宏,容易造成編譯時間久咨油,每次都需要重新替換您炉。
注意:很多Blog都說使用宏,會消耗很多內(nèi)存役电,我這驗證并不會生成很多內(nèi)存赚爵,宏定義的是常量,常量都放在常量區(qū)法瑟,只會生成一份內(nèi)存冀膝。
Snip20151014_1.png
// 常見的常量:抽成宏
#define XMGAccount @"account"
#define XMGUserDefault [NSUserDefaults standardUserDefaults]
// 字符串常量
staticNSString*constaccount =@"account";
- (void)viewDidLoad {
[superviewDidLoad];
// 偏好設置存儲
// 使用宏
[XMGUserDefault setValue:@"123"forKey:XMGAccount];
// 使用const常量
[[NSUserDefaultsstandardUserDefaults] setValue:@"123"forKey:account];
}
1.const僅僅用來修飾右邊的變量(基本數(shù)據(jù)變量p霎挟,指針變量*p)
2.被const修飾的變量是只讀的窝剖。
const基本使用
- (void)viewDidLoad {
? ? [super viewDidLoad];
// 定義變量
inta =1;
// 允許修改值
a =20;
// const兩種用法
// const:修飾基本變量p
// 這兩種寫法是一樣的,const只修飾右邊的基本變量b
constintb =20;// b:只讀變量
intconstb =20;// b:只讀變量
// 不允許修改值
b =1;
// const:修飾指針變量*p氓扛,帶*的變量枯芬,就是指針變量.
// 定義一個指向int類型的指針變量,指向a的地址
int*p = &a;
intc =10;
? ? p = &c;
// 允許修改p指向的地址采郎,
// 允許修改p訪問內(nèi)存空間的值
*p =20;
// const修飾指針變量訪問的內(nèi)存空間千所,修飾的是右邊*p1,
// 兩種方式一樣
constint*p1;// *p1:常量 p1:變量
intconst*p1;// *p1:常量 p1:變量
// const修飾指針變量p1
int*constp1;// *p1:變量 p1:常量
// 第一個const修飾*p1 第二個const修飾 p1
// 兩種方式一樣
constint*constp1;// *p1:常量 p1:常量
intconst*constp1;// *p1:常量 p1:常量
}
1.需求1:提供一個方法淫痰,這個方法的參數(shù)是地址,里面只能通過地址讀取值,不能通過地址修改值
2.需求2:提供一個方法整份,這個方法的參數(shù)是地址,里面不能修改參數(shù)的地址。
@implementation ViewController
// const放*前面約束參數(shù)奋渔,表示*a只讀
// 只能修改地址a,不能通過a修改訪問的內(nèi)存空間
- (void)test:(constint* )a
{
//? ? *a = 20;
}
// const放*后面約束參數(shù)晋控,表示a只讀
// 不能修改a的地址,只能修改a訪問的值
- (void)test1:(int*const)a
{
intb;
// 會報錯
? ? a = &b;
*a =2;
}
- (void)viewDidLoad {
[superviewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
inta =10;
// 需求1:提供一個方法蛹头,這個方法的參數(shù)是地址,里面只能通過地址讀取值,不能通過地址修改值。
// 這時候就需要使用const适瓦,約束方法的參數(shù)只讀.
[selftest:&a];
// 需求2:提供一個方法,這個方法的參數(shù)是地址谱仪,里面不能修改參數(shù)的地址玻熙。
[selftest1:&a];
}
@end
四、static和extern簡單使用(要使用一個東西疯攒,先了解其作用)
static作用:
修飾局部變量:
1.延長局部變量的生命周期,程序結束才會銷毀嗦随。
2.局部變量只會生成一份內(nèi)存,只會初始化一次。
3.改變局部變量的作用域敬尺。
修飾全局變量
1.只能在本文件中訪問,修改全局變量的作用域,生命周期不會改
2.避免重復定義全局變量
extern作用:
只是用來獲取全局變量(包括全局靜態(tài)變量)的值枚尼,不能用于定義變量
extern工作原理:
先在當前文件查找有沒有全局變量,沒有找到筷转,才會去其他文件查找姑原。
// 全局變量:只有一份內(nèi)存,所有文件共享呜舒,與extern聯(lián)合使用锭汛。
inta =20;
// static修飾全局變量
staticintage =20;
- (void)test
{
// static修飾局部變量
staticintage =0;
? ? age++;
NSLog(@"%d",age);
}
- (void)viewDidLoad {
[superviewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
[selftest];
[selftest];
externintage;
NSLog(@"%d",age);
}
I
static與const作用:聲明一個只讀的靜態(tài)變量
開發(fā)使用場景:在一個文件中經(jīng)常使用的字符串常量袭蝗,可以使用static與const組合
// 開發(fā)中常用static修飾全局變量,只改變作用域
// 為什么要改變?nèi)肿兞孔饔糜蚧脚梗乐怪貜吐暶魅肿兞俊?/p>
// 開發(fā)中聲明的全局變量,有些不希望外界改動到腥,只允許讀取朵逝。
// 比如一個基本數(shù)據(jù)類型不希望別人改動
// 聲明一個靜態(tài)的全局只讀常量
staticconstinta =20;
// staic和const聯(lián)合的作用:聲明一個靜態(tài)的全局只讀常量
// iOS中staic和const常用使用場景,是用來代替宏乡范,把一個經(jīng)常使用的字符串常量配名,定義成靜態(tài)全局只讀變量.
// 開發(fā)中經(jīng)常拿到key修改值,因此用const修飾key,表示key只讀晋辆,不允許修改渠脉。
staticNSString*constkey =@"name";
// 如果 const修飾 *key1,表示*key1只讀,key1還是能改變瓶佳。
staticNSStringconst*key1 =@"name";
開發(fā)中使用場景:在多個文件中經(jīng)常使用的同一個字符串常量,可以使用extern與const組合。
原因:
static與const組合:在每個文件都需要定義一份靜態(tài)全局變量为朋。
extern與const組合:只需要定義一份全局變量臂拓,多個文件共享。
全局常量正規(guī)寫法:開發(fā)中便于管理所有的全局變量习寸,通常搞一個GlobeConst文件胶惰,里面專門定義全局變量,統(tǒng)一管理霞溪,要不然項目文件多不好找童番。
GlobeConst.h
/*******************************首頁****************************/
externNSString*constnameKey =@"name";
/*******************************首頁****************************/
GlobeConst.m
#import
/*******************************首頁****************************/
NSString*constnameKey =@"name";
/*******************************首頁****************************/