ios 筆試題3

1.main()c++

 { 程序員

   int a[5]={1,2,3,4,5}; objective-c

   int *ptr=(int *)(&a+1);  編程

   printf("%d,%d",*(a+1),*(ptr-1));設計模式

}數組

答:2,5網絡

     *(a+1)就是a[1],*(ptr-1)就是a[4],執行結果是2,5,&a+1不是首地址+1,系統會認爲加一個a數組的偏移,是偏移了一個數組的大小(本例是5個int)數據結構

int *ptr=(int *)(&a+1);則ptr實際 是&(a[5]),也就是a+5
多線程

緣由以下:&a是數組指針,其類型爲 int (*)[5];而指針加1要根據指針類型加上必定的值,不一樣類型的指針+1以後增長的大小不一樣。a是長度爲5的int數組指針,因此要加 5*sizeof(int),因此ptr實際是a[5],可是prt與(&a+1)類型是不同的(這點很重要)
   因此prt-1只會減去sizeof(int*)併發

   a,&a的地址是同樣的,但意思不同,a是數組首地址,也就是a[0]的地址,&a是對象(數組)首地址,a+1是數組下一元素的地址,即a[1],&a+1是下一個對象的地址,即a[5].

2. 如下爲Windows NT下的32位C++程序,請計算sizeof的值



void Func ( char str[100] )  {  sizeof( str ) = ?  
}  


void *p = malloc( 100 ); 
sizeof ( p ) = ?

這題 很常見了,Func ( char str[100] )函數中數組名做爲函數形參時,在函數體內,數組名失去了自己的內涵,僅僅只是一個指針;在失去其內涵的同時,它還失去了其常量特性,能夠做自增、自減等 操做,能夠被修改。Windows NT 32位平臺下,指針的長度(佔用內存的大小)爲4字節,故sizeof( str ) 、sizeof ( p ) 都爲4。


3.仍是考指針,不過我對cocoa的代碼仍是不太熟悉

大概是這樣的

- (void)*getNSString(const NSString * inputString)

{

     inputString = @"This is a main test\n";

     return ;

}

-main(void)

{

NSString *a=@"Main";

 NSString *aString = [NSString stringWithString:@"%@",getNSString(a)];

 NSLog(@"%@\n", aString);

}

最後問輸出的字符串:NULL,output在 函數返回後,內存已經被釋放。

4.用預處理指令#define聲明一個常數,用以代表1年中有多少秒(忽略閏年問題)

#define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL  


我在這想看到幾件事情:  


?; #define 語法的基本知識(例如:不能以分號結束,括號的使用,等等)  


?; 懂得預處理器將爲你計算常數表達式的值,所以,直接寫出你是如何計算一年中有多少秒而不是計算出實際的值,是更清晰而沒有代價的。
  


?; 意識到這個表達式將使一個16位機的整型數溢出-所以要用到長整型符號L,告訴編譯器這個常數是的長整型數。  


?; 若是你在你的表達式中用到UL(表示無符號長整型),那麼你有了一個好的起點。記住,第一印象很重要。 

寫一個"
標準"MIN ,這個宏輸入兩個參數並返回較小的一個。 


#define MIN(A,B) ((A) <= (B) ? (A) : (B))  


這個測試是爲下面的目的而設的:  


?; 
標識#define在宏中應用的基本知識。這是很重要的,由於直到嵌入(inline)操做符變爲標準C的一部分,宏是方便產生嵌入代碼的惟一方
法,
對於嵌入式系統來講,爲了能達到要求的性能,嵌入代碼常常是必須的方法。  


?;三重條件操做符的知識。這個操做符存在C語言中的緣由是它使得編譯器能產生比 if-then-else 更優化的代碼,瞭解這個用法是很重要的。
 



?; 懂得在宏中當心地把參數用括號括起來  


?; 我也用這個問題開始討論宏的反作用,例如:當你寫下面的代碼時會發生什事?

least = MIN(*p++, b); 

結果是:
((*p++) <= (b) ? (*p++) : (*p++))
這個表達式會產生反作用,指針p會做三次++自增操做。

5.寫一個委託的 interface

@protocol MyDelegate;

@interface MyClass: NSObject

{

    id <MyDelegate> delegate;

}

// 委託方法

@protocol MyDelegate

- (void)didJobs:(NSArray *)args;

@end

6. 寫一個NSString類的實現

+ (id)initWithCString:(const char *)nullTerminatedCString encoding:(NSStringEncoding)encoding;

+ (id) stringWithCString: (const char*)nullTerminatedCString 
            encoding: (NSStringEncoding)encoding
{
  NSString  *obj;

  obj = [self allocWithZone: NSDefaultMallocZone()];
  obj = [obj initWithCString: nullTerminatedCString encoding: encoding];
  return AUTORELEASE(obj);
}

7.obj-c有多重繼承麼?不是的話有什麼替代方法?


cocoa 中全部的類都是NSObject 的子類 

多繼承在這裏是用protocol 委託代理 來實現的 
你不用去考慮繁瑣的多繼承 ,虛基類的概念.
ood的多態特性  在 obj-c 中經過委託來實現. 

8.obj- c有私有方法麼?私有變量呢

 objective-c - 類裏面的方法只有兩種, 靜態方法和實例方法. 這彷佛就不是完整的面向對象了,按照OO的原則就是一個對象只暴露有用的東西. 若是沒有了私有方法的話, 對於一些小範圍的代碼重用就不那麼順手了. 在類裏面聲名一個私有方法

@interface Controller : NSObject { NSString *something; }

+ (void)thisIsAStaticMethod;

- (void)thisIsAnInstanceMethod;

@end

@interface Controller (private) -

(void)thisIsAPrivateMethod;

@end

@private能夠用來修飾私有變 量

在Objective‐C中,全部實例變量默認都是私 有的,全部實例方法默認都 是公有的

9.關鍵字const有什麼含 意?修飾類呢?static的做 ,用於類呢?還有extern c的做用

const 意味着"只讀",下面的聲明都是什麼意思?  
const int a;  
int const a;  
const int *a;  
int * const a;  
int const * a const; 

前兩個的做用是同樣,a是一個常整型數。第三個意味着a是一個指向常整型數的指 針(也就是,整型數是不可修改的,但指針能夠)。第四個意思a是一個指向整型數的常指針(也就是說,指針指向的整型數是能夠修改的,但指針是不可修改 的)。最後一個意味着a是一個指向常整型數的常指針(也就是說,指針指向的整型數是不可修改的,同時指針也是不可修改的)。

結論:

?; 關鍵字const的做用是爲給讀你代碼的人傳達很是有用的信息,實際上,聲明一個參數爲常量是爲了告訴了用戶這個參數的應用目的。若是
你曾花不少 時間清理其它人留下的垃圾,你就會很快學會感謝這點多餘的信息。(固然,懂得用const的程序員不多會留下的垃圾讓別人來清
理的。)  
?; 經過給優化器一些附加的信息,使用關鍵字const也許能產生更緊湊的代碼。  
?; 合理地使用關鍵字const可使編譯器很天然地保護那些不但願被改變的參數,防止其被無心的代碼修改。簡而言之,這樣能夠減小bug的出現。  
 

(1)欲阻止一個變量被改變,可使用 const 關鍵字。在定義該 const 變量時,一般須要對它進行初
始化,由於之後就沒有機會再去改變它了; 
(2)對指針來講,能夠指定指針自己爲 const,也能夠指定指針所指的數據爲 const,或兩者同時指
定爲 const; 
(3)在一個函數聲明中,const 能夠修飾形參,代表它是一個輸入參數,在函數內部不能改變其值; 
(4)對於類的成員函數,若指定其爲 const 類型,則代表其是一個常函數,不能修改類的成員變量; 
(5)對於類的成員函數,有時候必須指定其返回值爲 const 類型,以使得其返回值不爲「左值」。

關鍵字volatile有什麼含意?並給出三個不一樣的例子。

一個定義爲 volatile的變量是說這變量可能會被意想不到地改變,這樣,編譯器就不會去假設這個變量的值了。精確地說就是,優化器在用到
這個變量時必須 每次都當心地從新讀取這個變量的值,而不是使用保存在寄存器裏的備份。下面是volatile變量的幾個例子:  

?; 並行設備的硬件寄存器(如:狀態寄存器)  
?; 一箇中斷服務子程序中會訪問到的非自動變量(Non-automatic variables)  
?; 多線程應用中被幾個任務共享的變量  ?; 一個參數既能夠是const還能夠是volatile嗎?解釋爲何。  
?; 一個指針能夠是volatile 嗎?解釋爲何。  

下 面是答案:  
?; 是的。一個例子是隻讀的狀態寄存器。它是volatile由於它可能被意想不到地改變。它是const由於程序不該該試圖去修改它。  
?; 是的。儘管這並不很常見。一個例子是當一箇中服務子程序修該一個指向一個buffer的指針時。  

static 關鍵字的做用:

(1)函數體內 static 變量的做用範圍爲該函數體,不一樣於 auto 變量,該變量的內存只被分配一次,
所以其值在下次調用時仍維持上次的值; 
(2)在模塊內的 static 全局變量能夠被模塊內所用函數訪問,但不能被模塊外其它函數訪問; 
(3)在模塊內的 static 函數只可被這一模塊內的其它函數調用,這個函數的使用範圍被限制在聲明
它的模塊內; 
(4)在類中的 static 成員變量屬於整個類所擁有,對類的全部對象只有一份拷貝; 
(5)在類中的 static 成員函數屬於整個類所擁有,這個函數不接收 this 指針,於是只能訪問類的static 成員變量。 

extern "C" 的做用

(1)被 extern "C"限定的函數或變量是 extern 類型的;

       extern 是 C/C++語言中代表函數和全局變量做用範圍(可見性)的關鍵字,該關鍵字告訴編譯器,
其聲明的函數和變量能夠在本模塊或 其它模塊中使用。

(2)被 extern "C"修飾的變量和函數是按照 C 語言方式編譯和鏈接的; 

extern "C"的慣用法 

(1)在 C++中引用 C 語言中的函數和變量,在包含 C 語言頭文件(假設爲 cExample.h)時,需進
行下列處理: 
extern "C"  
{  
#include "cExample.h"  
}  
而在 C 語言的頭文件中,對其外部函數只能指定爲 extern 類型,C 語言中不支持 extern "C"聲明,
在.c 文件中包含了 extern "C"時會出現編譯語法錯誤。

(2)在 C 中引用 C++語言中的函數和變量時,C++的頭文件需添加 extern "C",可是在 C 語言中不
能直接引用聲明瞭 extern "C"的該頭文件,應該僅將 C 文件中將 C++中定義的 extern "C"函數聲明爲
extern 類型。

10.爲何標準頭文件都有相似如下的結構?  
   #ifndef __INCvxWorksh  
   #define __INCvxWorksh  
   #ifdef __cplusplus  
   extern "C" {  
   #endif  
   /*...*/  
   #ifdef __cplusplus  
   }  
   #endif  
   #endif /* __INCvxWorksh */ 

顯然,頭文件中的編譯宏 「#ifndef __INCvxWorksh、#define __INCvxWorksh、#endif」 的做用
是防止該頭文件被重複引用。

11.#import #include的區別,@class?

 @class通常用於頭文件中須要聲明該類的某個實例變量的時候用到,在m文 件中仍是須要使用#import

而#import比 起#include的好處就是不會引發交叉編譯

12.MVC 模式的理解

MVC設計模式考慮三種對 象:模型對象、視圖對象、和控制器對象。模型對象表明 特別的知識和專業技能,它們負責保有應用程序的數據和定義操做數據的邏輯。視圖對象知道如何顯示應用程序的模型數據,並且可能容許用戶對其進行編輯。控制 器對象是應用程序的視圖對象和模型對象之間的協調者。

13. 線程與進程的區別和聯繫?

進程和線程都是由操做系統所體會的程序運行的基本 單元,系統利用該基本單元實現系統對應用的併發性。

程和線程的主要差異在於它們是不一樣的操做系統資源 管理方式。進程有獨立的地址空間,一個進程崩潰後,在保護模式下不會對其它進程產生影響,而線程只是一個進程中的不一樣執行路徑。線程有本身的堆棧和局部變量,但線程之間沒有單獨的地址空間,一個線程死掉就等於整個進程死掉,因此多進程的程序要比多線程的程序健壯,但在進程切換時,耗費資源較大,效率要差一些。但對於一些要求同時進行而且又要共享某些變量的併發操做,只能用線程,不能用進程。

14.列舉幾種進程的同步機制,並比較其優缺點。

答案:  原子操做 信號量機制    自旋鎖    管程,會合,分佈式系統 
進程之間通訊的途徑

答案:共享存儲系統消息傳遞系統管道:以文件系統爲基礎 
進 程死鎖的緣由

答案:資源競爭及進程推 進順序非法 
死鎖的4個必要條

答案:互斥、請求保持、不可剝奪、 環路 
死鎖的處理

答案:鴕鳥策略、預防策略、避免策略、檢測與解除死鎖

15.堆和棧 的區別

管 理方式:對於棧來說,是由編譯器自動管理,無需咱們手工控制;對於堆來講,釋放工做由程序員控制,容易產生memory leak。

申請大小:棧:在Windows下,棧是向低地址擴展的數據結構,是一塊連續的內存的區域。這句話的意思是棧頂的地址和 棧的最大容量是系統 預先規定好的,在WINDOWS下,棧的大小是2M(也有的說是1M,總之是一個編譯時就肯定的常數),若是申請的空間超過棧的剩餘空間時,將提示 overflow。所以,能從棧得到的空間較小。


堆:堆是向高地址擴展的數據結構,是不連續的內存區域。這是因爲系統是用鏈表來存儲的空閒內存地 址的,天然是不連續的,而鏈表的遍歷方向是由低地址向高地址。堆的大小受限於計算機系統中有效的虛擬內存。因而可知,堆得到的空間比較靈活,也比較大。

碎片問題:對於堆來說,頻繁的new/delete勢必會形成內存空間的不連續,從而形成大量的碎片,使程序效率下降。對於棧來說,則不會存在這個 問題,由於棧是先進後出的隊列,他們是如此的一一對應,以致於永遠都不可能有一個內存塊從棧中間彈出

分配方式:堆都是動態分配的,沒有靜態 分配的堆。棧有2種分配方式:靜態分配和動態分配。靜態分配是編譯器完成的,好比局部變量的分配。動態分配由 alloca函數進行分配,可是棧的動態分配和堆是不一樣的,他的動態分配是由編譯器進行釋放,無需咱們手工實現。

分配效率:棧是機器系統提 供的數據結構,計算機會在底層對棧提供支持:分配專門的寄存器存放棧的地址,壓棧出棧都有專門的指令執行,這就決定了棧的 效率比較高。堆則是C/C++函數庫提供的,它的機制是很複雜的。

16.什麼是鍵-,鍵路徑是什麼

模型的性質是經過一個簡單的鍵(一般是個字符串)來指定的。視圖和控制器經過鍵 來查找相應的屬性值。在一個給定的實體中,同一個屬性的全部值具備相同的數據類型。鍵-值編碼技術用於進行這樣的查找—它是一種間接訪問對象屬性的機制。

鍵路徑是一個由用點做分隔符的鍵組成的字符串,用於指定一個鏈接在一塊兒的對象性 質序列。第一個鍵的
性質是由先前的性質決定的,接下來每一個鍵的值也是相對於其前面的性質。鍵路徑使您能夠以獨立於模型
實現的方式指定相關 對象的性質。經過鍵路徑,您能夠指定對象圖中的一個任意深度的路徑,使其指向相
關對象的特定屬性。

For example, the key path address.streetwould get the value of the address property from the receiving

object, and then determine the street property relative to the address object.

17.cobj-c 如何混用

1)obj-c的編譯器處理 後綴爲m的文件時,能夠識別obj-c和c的代碼, 處理mm文件能夠識別obj-c,c,c++代碼,但cpp文件必須只能用c/c++代碼,並且cpp文件include的頭文件中,也不能出現obj- c的代碼,由於cpp只是cpp
2) 在mm文件中混用cpp直接使用便可,因此obj-c混cpp不是問題
3)在cpp中混用obj- c其實就是使用obj-c編寫的模塊是咱們想要的。
若是模塊以類實現,那麼要按照cpp class的標準寫類的定義,頭文件中不能出現obj-c的東西,包括#import cocoa的。實現文件中,即類的實現代碼中可使用obj-c的東西,能夠import,只是後綴是mm。
若是模塊以函數實現,那麼頭文件要按 c的格式聲明函數,實現文件中,c++函數內部能夠用obj-c,但後綴仍是mm或m。

總結:只要cpp文件和cpp include的文件中不包含obj-c的東西就能夠用了,cpp混用obj-c的關鍵是使用接口,而不能直接使用實現代碼,實際上cpp混用的是 obj-c編譯後的o文件,這個東西實際上是無差異的,因此能夠用。obj-c的編譯器支持cpp.

18.目標-動做機制

目標是動做消息的接收者。一個控件,或者更爲常見的是它的單元,以插座變量(參 見"插座變量"部分)
的形式保有其動做消息的目標。

動做是控件發送給目標的消息,或者從目標的角度看,它是目標爲了響應動做而實現 的方法。

程序須要某些機制來進行事件和指令的翻譯。這個 機制就是目標-動做機制。

19.cocoa touch框架

iPhone OS 應用程序的基礎 Cocoa Touch 框架重用了許多 Mac 系統的成熟模式,可是它更多地專一於觸摸的接口和優化。UIKit 爲您提供了在 iPhone OS 上實現圖形,事件驅動程序的基本工具,其創建在和 Mac OS X 中同樣的 Foundation 框架上,包括文件處理,網絡,字符串操做等。

Cocoa Touch 具備和 iPhone 用戶接口一致的特殊設計。有了 UIKit,您可使用 iPhone OS 上的獨特的圖形接口控件,按鈕,以及全屏視圖的功能,您還可使用加速儀和多點觸摸手勢來控制您的應用。

各色俱全的框架 除了 UIKit 外,Cocoa Touch 包含了建立世界一流 iPhone 應用程序須要的全部框架,從三維圖形,到專業音效,甚至提供設備訪問 API 以控制攝像頭,或經過 GPS 獲知當前位置。Cocoa Touch 既包含只須要幾行代碼就能夠完成所有任務的強大的 Objective-C 框架,也在須要時提供基礎的 C 語言 API 來直接訪問系統。這些框架包括:

Core Animation

經過 Core Animation,您就能夠經過一個基於組合獨立圖層的簡單的編程模型來建立豐富的用戶體驗。

Core Audio

Core Audio 是播放,處理和錄製音頻的專業技術,可以輕鬆爲您的應用程序添增強大的音頻功能。

Core Data

提供了一個面向對象的數據管理解決方案,它易於使用和理解,甚至可處理任何應用 或大或小的數據模型。

功能列表:框架分類

下面是 Cocoa Touch 中一小部分可用的框架:

音頻和 視頻Core AudioOpenALMedia LibraryAV Foundation數據管理Core DataSQLite

圖 形和動畫Core AnimationOpenGL ESQuartz 2D網絡/li>BonjourWebKitBSD Sockets

用 戶應用Address BookCore LocationMap KitStore Kit

20.objc的內存管理

? 若是您經過分配和初始化(好比[[MyClass alloc] init])的方式來建立對象,您就擁有這個對象,須要負責該對象的釋放。這個規則在使用NSObject的便利方法new 時也一樣適用。 ? 若是您拷貝一個對象,您也擁有拷貝獲得的對象,須要負責該對象的釋放。? 若是您保持一個對象,您就部分擁有這個對象,須要在再也不使用時釋放該對象。 反過來  ? 若是您從其它對象那裏接收到一個對象,則您不擁有該對象,也不該該釋放它(這個規則有少數
的例外,在參考文檔中有顯式的說明)。

內存管理理解

(1)程序A裏有一段內存被成功申請完成以後,內存計數器就從0變成1(這個過程是alloc)

(2)而後程序B裏也要使用這個內存,那麼內存計數器從1變成2(這個過程是retain)

(3)緊接着程序A不須要這個內存了,那麼程序A就把這個內存計數器減1(這個過程是release)

(4)當系統發現這個內存計數器變爲0,那麼就調用內存回收程序把這段內存回收(這個過程是dealloc)

21.自動釋放池是什麼,如何工做

 當您向一個對象發送一個autorelease消息時,Cocoa就會將該對 象的一個引用放入到最新的自動釋放池。它仍然是個正當的對象,所以自動釋放池定義的做用域內的其它對象能夠向它發送消息。當程序執行到做用域結束的位置 時,自動釋放池就會被釋放,池中的全部對象也就被釋放。

1.  ojc-c 是經過一種"referring counting"(引用計數)的方式來管理內存的, 對象在開始分配內存(alloc)的時候引用計數爲一,之後每當碰到有copy,retain的時候引用計數都會加一, 每當碰到release和autorelease的時候引用計數就會減一,若是此對象的計數變爲了0, 就會被系統銷燬.
2. NSAutoreleasePool 就是用來作引用計數的管理工做的,這個東西通常不用你管的.
3. autorelease和release沒什麼區別,只是引用計數減一的時機不一樣而已,autorelease會在對象的使用真正結束的時候才作引用計數 減一.

22.類工廠方法是什麼

 類工廠方法的實現是爲了向客戶提供方便,它們將分配和初始化合在一個步驟中, 返回被建立的對象,並
進行自動釋放處理。這些方法的形式是+ (type)className...(其中 className不包括任何前綴)。

工廠方法可能不 僅僅爲了方便使用。它們不但能夠將分配和初始化合在一塊兒,還能夠 爲初始化過程提供對
象的分配信息。

類工廠方法的 另外一個目的是使類(好比NSWorkspace)提供單件實例。雖 然init...方法能夠確認一
個類在每次程序運行過程只存在一個實例,但它須要首先分配一個「生的」實例,而後還必須釋放該實例。
工廠 方法則能夠避免爲可能沒有用的對象盲目分配內存。

23.單件實例是什麼

Foundation 和 Application Kit 框架中的一些類只容許建立單件對象,即這些類在當前進程中的惟一實例。舉例來講,NSFileManager 和NSWorkspace 類在使用時都是基於進程進行單件對象的實例化。當向這些類請求實例的時候,它們會向您傳遞單一實例的一個引用,若是該實例還不存在,則首先進行實例的分配 和初始化。 單件對象充當控制中心的角色,負責指引或協調類的各類服務。若是類在概念上只有一個實例(好比
NSWorkspace),就應該產生 一個單件實例,而不是多個實例;若是未來某一天可能有多個實例,您可
以使用單件實例機制,而不是工廠方法或函數。

24.動態綁定

—在運行時肯定要調用的方法

動態綁定將調用方法的肯定也推遲到運行時。在編譯時,方法的調用並不和代碼綁定 在一塊兒,只有在消實發送出來以後,才肯定被調用的代碼。經過動態類型和動態綁定技術,您的代碼每次執行均可以獲得不一樣的結果。運行時因子負責肯定消息的接 收者和被調用的方法。 運行時的消息分發機制爲動態綁定提供支持。當您向一個動態類型肯定了的對象發送消息時,運行環境系統會經過接收者的isa指針定位對象的類,並以此爲起點 肯定被調用的方法,方法和消息是動態綁定的。並且,您沒必要在Objective-C 代碼中作任何工做,就能夠自動獲取動態綁定的好處。您在每次發送消息時,


特別是當消息的接收者是動態類型已經肯定的對象時,動態綁定就會例行而 透明地發生。

25.obj-c的優缺

objc優勢:1) Cateogies 
  2) Posing 
  3) 動態識別
  4) 指標計算 
  5)彈性訊息傳遞
  6) 不是一個過分複雜的 C 衍生語言
  7) Objective-C 與 C++ 可混合編程


缺點:  1) 不支援命名空間  2)  不支持運算符重載  3) 不支持多重繼承

  4) 使用動態運行時類型,全部的方法都是函數調用,因此不少編譯時優化方法都用不到。(如內聯函數等),性能低劣。

26.sprintf,strcpy,memcpy使用上有什 麼要注意的地方

strcpy是一個字符串拷貝的函數,它的函數原型爲strcpy(char *dst, const char *src);

將 src開始的一段字符串拷貝到dst開始的內存中去,結束的標誌符號爲 '\0',因爲拷貝的長度不是由咱們本身控制的,因此這個字符串拷貝很容易出錯。具有字符串拷貝功能的函數有memcpy,這是一個內存拷貝函數,它的函 數原型爲memcpy(char *dst, const char* src, unsigned int len);

將長度爲len的一段內存,從src拷貝到dst中去,這個函數的長度可控。但 是會有內存疊加的問題。

sprintf是格式化函數。將 一段數據經過特定的格式,格式化到一個字符串緩 衝區中去。sprintf格式化的函數的長度不可控,有可能格式化後的字符串會超出緩衝區的大小,形成溢出。

27. 用變量a給出下面的定義  

a) 一個整型數(An integer  


b) 個指向整型數的指針( A pointer to an integer  


c)一個指向指針的的指針,它指向的指針是指向一個整型數( A pointer to a pointer to an integer  


d)一個有10個整型數的數組( An array of 10 integers  


e) 一個有10個指針的數組,該指針是指向一個整型數的。(An array of 10 pointers to integers  


f) 一個指向有10個整型數數組的指針( A pointer to an array of 10 integers  
g)一個指向函數的指針,該函數有一個整型參數並返回一個整型數(A pointer to a function that takes an integer as an argument
 and returns an integer  
h)一個有10個指針的數組,該指針指向一個函數,該函數有一個整型參數並返回一個整型數( An array of ten pointers to functions t
hat take an integer argument and return an integer  
 


答案是:

a) int a; // An integer  


b) int *a; // A pointer to an integer  


c) int **a; // A pointer to a pointer to an integer  


d) int a[10]; // An array of 10 integers  


e) int *a[10]; // An array of 10 pointers to integers  


f) int (*a)[10]; // A pointer to an array of 10 integers  


g) int (*a)(int); // A pointer to a function a that  takes an integer argument and returns an integer  


h) int (*a[10])(int); // An array of 10 pointers to functions  that take an integer argument and return an integer

28.readwritereadonlyassignretaincopynonatomic屬性的做用

@property是 一個屬性訪問聲明,擴號內支持如下幾個屬性:
1,getter=getterName,setter=setterName,設置setter與 getter的方法名
2,readwrite,readonly,設置可供訪問級別
2,assign,setter方法直接賦值,不進行 任何retain操做,爲了解決原類型與環循引用問題
3,retain,setter方法對參數進行release舊值再retain新值,全部 實現都是這個順序(CC上有相關資料)
4,copy,setter方法進行Copy操做,與retain處理流程同樣,先舊值release,再 Copy出新的對象,retainCount爲1。這是爲了減小對上下文的依賴而引入的機制。
5,nonatomic,非原子性訪問,不加同步, 多線程併發訪問會提升性能。注意,若是不加此屬性,則默認是兩個訪問方法都爲原子型事務訪問。鎖被加到所屬對象實例級(我是這麼理解的...)。

@synthesize xxx;  來實現實際代碼

相關文章
相關標籤/搜索