• <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

            它指出,在賦值時使用傳入值的一份拷貝??截惞ぷ饔?/span>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 逛奔的蝸牛 閱讀(763) 評論(0)  編輯 收藏 引用 所屬分類: Cocoa
            欧美久久亚洲精品| 国产精品久久久久影视不卡| 亚洲一区精品伊人久久伊人| 欧美精品乱码99久久蜜桃| 久久亚洲精品中文字幕| 国产午夜久久影院| 国产精品久久婷婷六月丁香| 精品久久久久久国产潘金莲| 精品无码人妻久久久久久| 久久亚洲国产精品成人AV秋霞| 九九精品99久久久香蕉| 久久免费视频一区| 国产69精品久久久久777| 久久精品国产欧美日韩| 欧美牲交A欧牲交aⅴ久久| 亚洲美日韩Av中文字幕无码久久久妻妇 | 久久777国产线看观看精品| 精品久久综合1区2区3区激情| 亚洲精品乱码久久久久久按摩| 国产精品欧美久久久天天影视 | 国产AⅤ精品一区二区三区久久| 久久精品国产亚洲av麻豆蜜芽| 久久精品无码一区二区三区日韩| 无码国产69精品久久久久网站| 一本久久综合亚洲鲁鲁五月天| 国产成人久久777777| 久久99热国产这有精品| 久久久一本精品99久久精品88| 无码人妻久久一区二区三区蜜桃| 国产福利电影一区二区三区久久久久成人精品综合 | 亚洲国产天堂久久久久久 | 久久精品国产99国产精品亚洲| 久久综合日本熟妇| 人妻精品久久久久中文字幕 | 久久精品国产亚洲AV蜜臀色欲| 久久毛片一区二区| 精品一二三区久久aaa片| 国产精品成人久久久| 狠狠色丁香婷婷久久综合| 中文字幕亚洲综合久久菠萝蜜| 中文精品久久久久人妻|