• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            逛奔的蝸牛

            我不聰明,但我會很努力

               ::  :: 新隨筆 ::  ::  :: 管理 ::
            我們知道在Objective-C中,使用@property配合@synthesize可以讓編譯器自動實現getter/setter方法,使用的時候也很方便,可以直接使用對象.屬性的方法調用。
            NSString*    name;
            NSUInteger    age;

            @property(nonatomic,copy)NSString
            *            name;
            @property(assign)NSUInteger                    age;

            @synthesize name;

            @synthesize age;  


            那如果我們想要對象.方法的方式來調用一個方法并獲取到方法的返回值,那就需要使用@property配合@dynamic了。

            @property(readonly)NSString*    firstArrayValue;

            @dynamic    firstArrayValue;

            - (NSString*)firstArrayValue
            {
                
            return [_array objectAtIndex:0];


             這樣就可以使用對象.firstArrayValue來獲取到_array數組中的第一個值了,很顯然,這種方法并不適用于需要傳遞參數的方法。

             

            其實使用@dynamic關鍵字是告訴編譯器由我們自己來實現訪問方法。

            如果使用的是@synthesize,那么這個工作編譯器就會幫你實現了。 這時候你也可以自己實現此屬性的Accessor,系統會調用你的實現代替系統的實現。雖然使用@property減少了代碼,但是在我們的代碼中,為了統一,最好還是使用[obj attribute]的方式來調用Accessors,不要一會使用obj.attribute,一會使用[obj attribute],讓代碼不夠統一。

             

            說明:代碼只為示例代碼,實際使用時每句代碼要放到相應位置的。

             

            ===== 最后轉載下關于@property(*)括號中的屬性內容介紹 =====

            readonly

            此標記說明屬性是只讀的,默認的標記是讀寫,如果你指定了只讀,在@implementation中只需要一個讀取器。或者如果你使用@synthesize關鍵字,也是有讀取器方法被解析。而且如果你試圖使用點操作符為屬性賦值,你將得到一個編譯錯誤。

             

            readwrite

            此標記說明屬性會被當成讀寫的,這也是默認屬性。設置器和讀取器都需要在@implementation中實現。如果使用@synthesize關鍵字,讀取器和設置器都會被解析。

             

            assign

            此標記說明設置器直接進行賦值,這也是默認值。在使用垃圾收集的應用程序中,如果你要一個屬性使用assign,且這個類符合NSCopying協議,你就要明確指出這個標記,而不是簡單地使用默認值,否則的話,你將得到一個編譯警告。這再次向編譯器說明你確實需要賦值,即使它是可拷貝的。

             

            retain

            指定retain會在賦值時喚醒傳入值的retain消息。此屬性只能用于Objective-C對象類型,而不能用于Core Foundation對象。(原因很明顯,retain會增加對象的引用計數,而基本數據類型或者Core Foundation對象都沒有引用計數——譯者注)

             

            copy

            它指出,在賦值時使用傳入值的一份拷貝。拷貝工作由copy方法執行,此屬性只對那些實行了NSCopying協議的對象類型有效。更深入的討論,請參考復制部分。

             

            nonatomic

            指出訪問器不是原子操作,而默認地,訪問器是原子操作。這也就是說,在多線程環境下,解析的訪問器提供一個對屬性的安全訪問,從獲取器得到的返回值或者通過設置器設置的值可以一次完成,即便是別的線程也正在對其進行訪問。如果你不指定nonatomic,在自己管理內存的環境中,解析的訪問器保留并自動釋放返回的值,如果指定了nonatomic,那么訪問器只是簡單地返回這個值。

            From: http://www.cnblogs.com/kaixuan/archive/2011/03/02/1969072.html

            #import <Foundation/Foundation.h>


            @interface Employee : NSObject {

                NSString *firstName;

                NSString *lastName;

            }


            @property (retain, readwrite, nonatomic) NSString *firstName;

            @property (retain, readwrite, nonatomic) NSString *lastName;


            @end


            //

            //  Employee.m

            //  PropertyTest

            //

            //  Created by Biao Huang on 12/15/11.

            //  Copyright (c) 2011 __MyCompanyName__. All rights reserved.

            //


            #import "Employee.h"


            @implementation Employee


            @dynamic firstName;

            @synthesize lastName;


            - (id)init {

                self = [super self];

                

                if (self) {

                    // 測試代碼,三種形式都可以使用

                    self.firstName = @"biao";

                    NSLog(@"%@", firstName);

                    NSLog(@"%@", [self firstName]);

                    NSLog(@"%@", self.firstName);

                }

                

                return self;

            }


            - (void)setFirstName:(NSString *)newFirstName {

                NSLog(@"[Employee setFirstName:]");

                [newFirstName retain];

                [firstName release];

                firstName = newFirstName;

            }


            - (NSString *)firstName {

                NSLog(@"[Employee firstName]");

                return firstName;

            }


            @end


            posted on 2011-12-15 22:53 逛奔的蝸牛 閱讀(752) 評論(0)  編輯 收藏 引用 所屬分類: Cocoa
            人妻精品久久无码区| 无码人妻久久一区二区三区免费丨| 久久婷婷五月综合97色| 亚洲国产精品无码久久| 国产成人久久激情91| 国産精品久久久久久久| 亚洲中文久久精品无码ww16| 久久精品国内一区二区三区| 欧洲性大片xxxxx久久久| 久久久一本精品99久久精品66| 亚洲综合精品香蕉久久网97| 国产69精品久久久久APP下载| 久久国产精品成人免费| 亚洲va久久久噜噜噜久久狠狠| 久久99国产精一区二区三区| 久久精品中文无码资源站| 99热都是精品久久久久久| 久久精品无码一区二区无码 | 国产精品激情综合久久| 无码人妻久久一区二区三区蜜桃 | 午夜精品久久久久久| 成人久久精品一区二区三区| 国产99久久久国产精品小说| 久久免费视频一区| 久久99精品久久久久久不卡| 72种姿势欧美久久久久大黄蕉| 亚洲AV日韩精品久久久久久| 国产精品久久新婚兰兰| 一本一本久久a久久精品综合麻豆| 伊人久久大香线蕉影院95| 996久久国产精品线观看| 亚洲午夜久久久久久噜噜噜| 狠狠色丁香婷婷久久综合| 免费一级欧美大片久久网| 久久91这里精品国产2020| 精品免费久久久久国产一区| 久久WWW免费人成—看片| 久久国产美女免费观看精品| 久久久久国产精品嫩草影院| 久久久久久噜噜精品免费直播| 久久天天躁狠狠躁夜夜2020 |