30天學會ios開發(fā)"2基本語法"

大案牘術也是依靠語法

oc 語法相對比較繁復,對比新興的python,swift,kotlin 是比較啰嗦的, 90年代的發(fā)明深受當時pascal ,basic的影響.
首先說明oc類相關的內(nèi)容

簡單的類使用

初始化一個類
//兩個方法效果其實一樣
UIImageView  *bgImgV = [UIImageView new];
UIImageView  *bgImgV = [[UIImageView alloc]init];
//調(diào)用類的方法
[bgImgV  addSubview:_logoImgV];// addSubview為方法 _logoImgV為方法使用的參數(shù)
//獲取類的屬性
bgImgV.frame //用 "."調(diào)用
//設置類的屬性(2種方法)
 bgImgV.alpha = 1;
[bgImgV setAlpha:1];

注意
1 ios 調(diào)用方法有時也叫發(fā)送消息,兩者是一個意思.
2 只用公用屬性才能被訪問.
3 只用公用屬性同時沒有設置readonly才能被修改.
4 通常鼓勵在.h文件內(nèi)聲明property,方便在使用是在外部調(diào)用.

屬性聲明

@property (nonatomic,strong)UIView *volumeBarView;
@property (nonatomic,copy)NSString *str;
@property (nonatomic,assign)int count;

為什么他們的修飾符都不同呢? 在工作中上炎,字符串用copy凡蚜,基本數(shù)據(jù)類型用assign悼瓮,控件用strong趋距。每當對象alloc,retain略步,strong谅猾,copy的時候映九,引用計數(shù)會加一,dealloc沃暗,頁面釋放時候會減一月洛,引用計數(shù)為零的時候內(nèi)存便會釋放。
1 strong表示變量指針是強持有類型,在賦值之后就會指向這個對象并且讓計數(shù)器加1
2 copy 就比較復雜,分為深拷貝和淺拷貝兩種. 使用copy 的初衷就是保持賦值后,不被數(shù)據(jù)來源的更改所影響.
我這樣說你就明白了 A->B A中的一個MutableString給B中的一個Property(NSString類型)賦值 首先是能接受的孽锥,父類可以接受子類嚼黔,如果是retain,僅僅是生成一個指針惜辑,計數(shù)器加一唬涧,然后指向那個MutableString。如果MString改變盛撑,B中那個跟著改變爵卒,因為是同一塊內(nèi)存區(qū)域。而選擇Copy相當于又生成了一個NSString撵彻,與A中的MutableString獨立钓株。
下面我想通過一個最簡單的例子來說明它們的區(qū)別:
首先我們來看看使用strong會出現(xiàn)什么樣的情況:

.h

@property (nonatomic, strong) NSString *name;

.m

NSMutableString *mStr = [NSMutableString stringWithString:@"奧特曼"];

self.name = mStr;

NSLog(@"用strong第一次得到的名字:%@", self.name);

[mStr appendString:@"2"];

NSLog(@"用strong第二次得到的名字:%@", self.name);

打印結果:
2017-04-07 16:20:10.138793 copyTest[2421:682898]用strong第一次得到的名字:奧特曼
2017-04-07 16:20:10.138884 copyTest[2421:682898]用strong第二次得到的名字:奧特曼2
結論:
通過上面的例子我們可以看出,我們在沒有直接修改 self.name 的情況下 self.name 卻被修改了陌僵,就好像一個人的名字怎么能沒有經(jīng)過自己同意就被修改呢轴合?我們的初衷只是想修改mStr,但是 self.name 卻被意外的修改了碗短,而這就是我們使用strong所不想看到的受葛,它會破壞程序的封裝性。(使用strong后 self.name 和 mStr 指向的是同一片內(nèi)存偎谁,所以修改其中一個值后兩個值就都變了)
那么使用copy又會得到什么結果呢总滩?下面是使用copy的例子:

.h
@property (nonatomic, copy) NSString *name;
.m
NSMutableString *mStr = [NSMutableString stringWithString:@"奧特曼"];
self.name = mStr;
NSLog(@"用copy第一次得到的名字:%@", self.name);
[mStr appendString:@"2"];
NSLog(@"用copy第二次得到的名字:%@", self.name);

打印結果:
2017-04-07 16:35:04.012589 copyTest[2428:685221]使用copy第一次得到的名字:奧特曼
2017-04-07 16:35:04.012676 copyTest[2428:685221]使用copy第二次得到的名字:奧特曼
結論:
這個例子中我們使用了copy修飾,mStr通過copy得到了一個新的對象賦值給 self.name 這樣我們再修改mStr就跟 self.name 沒關系了巡雨,只有直接對 self.name 進行賦值才能改變它的值闰渔,這樣就保證了程序的封裝性。

原子性

你一定也注意到了 nonatomic 關鍵詞,附上官方解釋:
atomic和nonatomic的對比
1铐望、atomic和nonatomic用來決定編譯器生成的getter和setter是否為原子操作冈涧。
2茂附、atomic:系統(tǒng)生成的 getter/setter 會保證 get、set 操作的完整性督弓,不受其他線程影響营曼。getter 還是能得到一個完好無損的對象(可以保證數(shù)據(jù)的完整性),但這個對象在多線程的情況下是不能確定的愚隧,比如上面的例子蒂阱。
也就是說:如果有多個線程同時調(diào)用setter的話,不會出現(xiàn)某一個線程執(zhí)行完setter全部語句之前狂塘,另一個線程開始執(zhí)行setter情況蒜危,相當于函數(shù)頭尾加了鎖一樣,每次只能有一個線程調(diào)用對象的setter方法睹耐,所以可以保證數(shù)據(jù)的完整性辐赞。
atomic所說的線程安全只是保證了getter和setter存取方法的線程安全,并不能保證整個對象是線程安全的硝训。
3响委、nonatomic:就沒有這個保證了,nonatomic返回你的對象可能就不是完整的value窖梁。因此赘风,在多線程的環(huán)境下原子操作是非常必要的,否則有可能會引起錯誤的結果纵刘。但僅僅使用atomic并不會使得對象線程安全邀窃,我們還要為對象線程添加lock來確保線程的安全。
4假哎、nonatomic的速度要比atomic的快瞬捕。
5、atomic與nonatomic的本質(zhì)區(qū)別其實也就是在setter方法上的操作不同

在此你可以先留下印象,在學習多線程的時候會詳細講解.

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末舵抹,一起剝皮案震驚了整個濱河市肪虎,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌惧蛹,老刑警劉巖扇救,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異香嗓,居然都是意外死亡迅腔,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進店門靠娱,熙熙樓的掌柜王于貴愁眉苦臉地迎上來沧烈,“玉大人,你說我怎么就攤上這事饱岸〔舫觯” “怎么了?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵苫费,是天一觀的道長汤锨。 經(jīng)常有香客問我,道長百框,這世上最難降的妖魔是什么闲礼? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮铐维,結果婚禮上柬泽,老公的妹妹穿的比我還像新娘。我一直安慰自己嫁蛇,他們只是感情好锨并,可當我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著睬棚,像睡著了一般第煮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上抑党,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天包警,我揣著相機與錄音,去河邊找鬼底靠。 笑死害晦,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的暑中。 我是一名探鬼主播壹瘟,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼鳄逾!你這毒婦竟也來了俐筋?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤严衬,失蹤者是張志新(化名)和其女友劉穎澄者,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體请琳,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡粱挡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了俄精。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片询筏。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖竖慧,靈堂內(nèi)的尸體忽然破棺而出嫌套,到底是詐尸還是另有隱情逆屡,我是刑警寧澤,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布踱讨,位于F島的核電站魏蔗,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏痹筛。R本人自食惡果不足惜莺治,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帚稠。 院中可真熱鬧谣旁,春花似錦、人聲如沸滋早。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽杆麸。三九已至瘟判,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間角溃,已是汗流浹背拷获。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留减细,地道東北人匆瓜。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像未蝌,于是被迫代替她去往敵國和親驮吱。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容

  • Swift1> Swift和OC的區(qū)別1.1> Swift沒有地址/指針的概念1.2> 泛型1.3> 類型嚴謹 對...
    cosWriter閱讀 11,101評論 1 32
  • 今天有個突出其來的好消息狰腌,在點開簡書后收到信息說我的文章被收入專題《今日看點》除破,我想了想,昨天沒投這個欄目呀琼腔。 點...
    舒檸檬閱讀 393評論 0 2
  • http://blog.csdn.net/qq_22383951/article/details/53019034...
    wvqusrtg閱讀 2,072評論 1 1
  • 伴隨機器人有兩種瑰枫,一種是普通的小型機器人,伴隨在主人身邊丹莲,智能的幫助主人解決問題或陪伴主人光坝。 另一種是寄生機器人尸诽,...
    老祝讀書閱讀 774評論 0 0
  • Good UI是一家研究用戶體驗的設計機構。我們知道成功的頁面設計不僅有很高的轉(zhuǎn)化率更便于用戶使用盯另,既能滿足商業(yè)目...
    medesign閱讀 2,025評論 0 20