zoukankan      html  css  js  c++  java
  • OC数组的简单使用、NSArray

      和上一篇文章一样,数组的重要性不言而喻,在OC编程的过程中我们会不断的使用到NSArray,和C语言不同的是,我们这里的数组只能存OC对象类型,不能存C语言基本数据类型,也不能存NSNull类型,但是我们这里的数组可以存多种对象类型,比如,在同一个数组里面,既可以存字符串类型,又可以存对象化了以后的整数类型,甚至是另外一个数组,也可以存其他的对象类型(将C语言的数据类型转换成OC的对象类型下面会讲到),不过在同一个数组里面尽量存同一种数据类型,这是为了方便使用。在OC数组里面以nil表示结尾,如果你在数组的中间存了一个nil的数据,那么在nil后面的数据是读取不到的。

      和NSString一样,数组可以分为可变数组(NSMutableArray)和不可变数组(NSArray),首先,我们还是从不可变数组说起,因为可变数组只是在不可变数组上加上了一些新的方法。

    一、不可变数组

    1.不可变数组的创建

    2.访问数组的对象个数可以使用count属性,回忆一下,在字符串中访问字符串的长度我们使用的是length属性。

    3.获取某个对象的索引值使用方法:indexOfObject

    4.获取某个索引值对应的对象使用方法:objectAtIndex

    5.判断数组是否包含某个对象使用方法:containsObject

    6.获取数组第一个元素:arr[0]

               [arr objectAtIndex:0]

               [arr firstObject]

    7.获取数组最后一个元素:[arr lastObject]

    二、可变数组

      可变数组相对于不可变数组和可变字符串相对于不可变字符串类似,都增加了一些方法和属性,最主要的就是增、删、改、插入。

    1.创建可变数组

    2.向可变数组里面增加一个对象使用方法:addObject

    3.在可变数组里面删除对象:

      [removeObject:@"xianggang"];

            [ar removeObject:@"bj"];

            [ar removeObjectAtIndex:1];

            [ar removeAllObjects];

    4.更换数组里面的一个对象

      [ar exchangeObjectAtIndex:0 withObjectAtIndex:1];

    5.插入一个对象

      [ar insertObject:@"bj" atIndex:1];

    三、封装(即类型转换)

    1.将C语言基本数据类型封装为OC对象类型我们使用的是NSNumber;如:

    NSNumber *number = [NSNumber numberWithInt:20];

    NSNumber *number1 = [NSNumber numberWithFloat:20.0];

    2.将C语言的结构体和枚举封装了OC对象类型需要使用NSValue;如:

    struct CGRect{

              CGPoint point;

              CGSize size;

            };

     struct CGPoint {

             CGFloat x;

             CGFloat y;

             };

             

            struct CGSize {

                CGFloat width;

                CGFloat height;

            };

             */

            CGRect rect = CGRectMake(100, 100, 200, 150);

            NSValue *rectValue = [NSValue valueWithRect:rect];

      

  • 相关阅读:
    hdu 5400 Arithmetic Sequence(模拟)
    hdu 5402 Travelling Salesman Problem(大模拟)
    hdu 5009 Paint Pearls (dp)
    poj 1236 Network of Schools(tarjan+缩点)
    hdu 3836 Equivalent Sets(tarjan+缩点)
    编程之美2015初赛第一场 hihoCoder #1156 : 彩色的树(染色问题)
    hdu 2807 The Shortest Path(矩阵+floyd)
    The Unique MST (判断是否存在多个最小生成树)
    Advanced Fruits(好题,LCS的模拟)
    Dark roads(kruskal)
  • 原文地址:https://www.cnblogs.com/laorenyuhail/p/9583570.html
Copyright © 2011-2022 走看看