`
icrwen
  • 浏览: 262033 次
  • 性别: Icon_minigender_2
  • 来自: 济南
社区版块
存档分类
最新评论

object-C

 
阅读更多

1.@class用在循环嵌入#import时很有用,当A类引用了B类,而B类也引用了A类时用#import会报错,这时用@class,

   @class相当于告诉编译器肯定会有一个这样的类。

 

 

 

3.Foundation包里有基础类:NSString ,NSMutableString,NSArray,NSMutableArray,NSEnumerator(数组枚举可以遍历访问数组元素),NSDictionary(字典用来保存大量数据并且可以快速找到),NSMutableDictionary,NSNumber

   其中数组是以nil来结尾的,所以NSArray可以存储除了nil以外的任意类型对象。

遍历目录下的后缀.jpg的文件名

 

NSFileManager * manager;

manager = [ NSFileManger defaultManager];

NSString * home;

home = [@"~" stringByExpandintTiledInPath];

 

NSDirectoryEnumerator * direnum;

direnum = [manager enumeratorAtPath:home];

 

NSMultableArray * files;

files = [NSMutableArray arryWithCapacity:47];

 

NSString * fileName;

while(fileName = [direnum nextObject]{

   if([[fileName pathExtension] isEqualTo:@"jpg"])

   {

       [files addObject:fileName];

   }

}

 

NSEnumerator * fileenum;

fileenum = [fils objectEnumerator];

while(fileName = [filenum nextObject])

{

NSLog(@"%@",fileName);

}

 

4.内存管理 --- 引用计数对象调用retain方法则计数加一,调用release方法则计数减一。

         关键是什么时候释放,什么时候加一,记住在把新对象赋值,在释放旧对象前先给新对象retain加一比较保险.

       原则是谁创建,谁释放。

 

objective-C内存管理

1)当使用new,alloc,或cop创建对象时,对象的count retain到1,则一定要负责把这个对象release或autorelease掉,这样当它的生命周期结束时,才能清空。

2)当你调用方法获得一个对象时, 你可以认为已经retain了一个count,并且autolease掉,你不用考虑和它相关的清理问题,但是如果你想保留着个对象,就需要retian

,并且确保之后你release了这个对象。

3)如果你retain一个对象,则最终是需要releas或者autolease它。

4)需要销毁对象的时候,不直接调用dealloc,而是调用release,

5) 新生成的对象,只要调用autorelease就行了,无需再调用release!

6)除了alloc,new 或copy之外的方法创建的对象都被声明了autolease.

7)内存标准使用:

      * 创建对象:

        ClassA * obj1 = [[ClassA  alloc]init];

      *创建一个autoRelease对象

        ClassA * obj1 = [[[ClassA alloc]inin]autoRelease];

       *Release一个对象后,必须立即把指针清空

         [obj1 release];

obj1 = nil;

        *指针赋值给另一个指针。

  ClassA * obj2 = obj1;

  [obj2 retain];

  //do sometin

  [obj2 releas];

  obj2 = nil;

*在一个函数中创建并返回对象,需要把这个对象设置为iautorelease

              ClassA *Func1()

{

 ClassA *obj = [[[ClassA alloc]init]autorelease];

 return obj;

}

 

2012-8-5 object-c语法再整理

1)classes基本定义

 

@interface

  • 繼承(inheritance)以 Class: Parent 表示,就像上面的 Fraction: NSObject。
  • 夾在 @interface Class: Parent { .... } 中的稱為 instance variables。
  • 沒有設定存取權限(protected, public, private)時,預設的存取權限為 protected。設定權限的方式將在稍後說明。
  • Instance methods 跟在成員變數(即 instance variables)後。格式為:scope (returnType) methodName: (parameter1Type) parameter1Name;
    • scope 有class 或 instance 兩種。instance methods 以 - 開頭,class level methods 以 + 開頭。
  • Interface 以一個 @end 作為結束。

@implementation

  • Implementation 以 @implementation ClassName 開始,以 @end 結束
    • Fraction *frac = [[Fraction alloc] init];
      • 在 Objective-C 中调用methods 的方法是 [object method],就像 C++ 的 object->method()。
      • Objective-C 沒有 value 型別。所以沒有像 C++ 的 Fraction frac; frac.print(); 這類的東西。在 Objective-C 中完全使用指针來處理对象。
      • 這行程式碼實際上做了兩件事: [Fraction alloc] 呼叫了 Fraction class 的 alloc method。這就像 malloc 記憶體,這個動作也做了一樣的事情。
      • [object init] 是一個构造(constructor)方法,負責初始化物件中的所有变量。它调用[Fraction alloc] 傳回的 instance 上的 init method。這個動作非常普遍,所以通常以一行程式完成:Object *var = [[Object alloc] init];
    • [frac setNumerator: 1] 非常簡單。它呼叫了 frac 上的 setNumerator method 並傳入 1 為參數。
    • 如同每個 C 的变量,Objective-C 也有一個用以釋放内存的方式: release。它繼承自 NSObject,這個 method 在之後會有詳盡的解說。

2)多重参数

   声明和定义 -(void)setNumertor:(int)numertor  andDenominator:(int)denomintao

  调用  [frac setNumertor:1 andDenominator:2];

  • 這個 method 實際上叫做 setNumerator:andDenominator:
  • 加入其他參數的方法就跟加入第二個時一樣,即 method:label1:label2:label3: ,而呼叫的方法是 [obj method: param1 label1: param2 label2: param3 label3: param4]
  • Labels 是非必要的,所以可以有一個像這樣的 method:method:::,簡單的省略 label 名稱,但以 : 區隔參數。並不建議這樣使用。

3)构造函数-(id)init

   Objective-C 中的建構子就是一個 "init" method,

 

4)異常情況(Exceptions)

 

  • 异常派生与NSException 例如:@interface CupWaring:NSException
  • 函数定义时,自定义异常对象生成并抛出 NSException * e = [CupWaring exceptionWithName:@""  reason:@"" userInfo:nil]; @ throw e;
  • 函数调用时捕获异常 @try{ [obj fun]} @catch(CupWaring *e){}

5)id 型別  Objective-C 有種叫做 id 的类型,它的運作有時候像是 void*,不過它卻嚴格規定只能用在对象。

 

6)类型识别

7)Objective-C 裡的 Protocol 與 Java 的 interface 或是 C++ 的 purely virtual class 相同。

 

 

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics