#import <Foundation/Foundation.h>

//排序算法,应用于 NSArray *arr=[arrs1 sortedArrayUsingFunction:sortByID context:nil];排序

NSInteger sortByID(id obj1, id obj2, void *context){

NSString *str1 =(NSString*) obj1;

NSString *str2 =(NSString *) obj2;

if (str1.length < str2.length) {

return NSOrderedDescending;

}

else if(str1.length == str2.length)

{

return NSOrderedSame;

}

return NSOrderedAscending;

}

int main(int argc, const char * argv[]) {

@autoreleasepool {

//数组只能存储oc对象,NSArray一旦创建不能修改

NSArray *arrs0=@[@"123",@"456",@"789"];

//初始化数组的一种奇葩

NSArray *arrs1=[NSArray arrayWithArray:arrs0];

//1.获取数组中的元素对象

id need=[arrs1 objectAtIndex:1];//取出索引位置中的对象

id nn=[arrs1 objectAtIndexedSubscript:1];

NSLog(@"need=%@",need);

//2.元素个数

int t=[arrs1 count];

//3.判断是否包含

bool isYes=[arrs1 containsObject:@"123"];

//4.取得数组中第一个和最后一个元素

need= [arrs1 firstObject];

need=[arrs1 lastObject];

//5.添加元素,返回另一个数组

arrs0=[arrs1 arrayByAddingObject:@"000"];

//6.合并两个数组

arrs0=[arrs1 arrayByAddingObjectsFromArray:arrs1];

NSLog(@"%@",arrs0);

//7.取得数组一定范围内的数据

arrs0=[arrs1 subarrayWithRange:NSMakeRange(1, 1)];

NSLog(@"%ld",[arrs0 count]);

//8.判断是否相等

isYes=[arrs0 isEqualToArray:arrs1];

//9.返回元素的位置

int tt=[arrs0 indexOfObject:@"123"];

NSLog(@"%d",tt);

tt=[arrs0 indexOfObjectIdenticalTo:@"123"];

//10.数组与字符串的转换

NSString *sss=[arrs1 componentsJoinedByString:@"-"];

//11.字符串与数组转换

NSArray *array=[sss componentsSeparatedByString:@"-"];

NSLog(@"%@",sss);

NSLog(@"%@",array);

//sortedArrayHint:不知道怎么用的

//int num=[array sortedArrayHint];

//NSLog(@"%ld",num);

//12.写入文件,写入url

[arrs1 writeToFile:@"/users/tang/desktop/array.plist" atomically:YES];

NSArray *arrfile=[NSArray arrayWithContentsOfFile:@"/users/tang/desktop/array.plist"];

NSLog(@"%@",arrfile);

//13.数组的遍历 还有两种

[arrs1 enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {

NSLog(@"%d,%@",idx,obj);

if(idx==1)

{

*stop=YES;

}

}];

//14.正向遍历

NSEnumerator *dfd=[arrs1 objectEnumerator];

for (id dd in dfd) {

NSLog(@"%@",dd);

}

//15.反向遍历

dfd=[arrs1 reverseObjectEnumerator];

for (id dd in dfd) {

NSLog(@"%@",dd);

}

//16用自己写的函数实现数组的排序

NSArray *arr=[arrs1 sortedArrayUsingFunction:sortByID context:nil];

// NSLog(@"%ld",NSNotFound);

}

return 0;

}

NSArray 所有基础点示例的更多相关文章

  1. 【IOS 开发】Objective-C Foundation 框架 -- 字符串 | 日期 | 对象复制 | NSArray | NSSet | NSDictionary | 谓词

    一. 字符串 API 1. NSString 用法简介 (1) NSString API 介绍 NSString 功能 : -- 创建字符串 : 使用 init 开头的实例方法, 也可以使用 Stri ...

  2. iOS之数据持久化方案

    概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) ...

  3. iOS的数据持久化

    所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) pr ...

  4. iOS数据持久化

    在iOS中,实现数据持久化一般分为4大种: 1.属性列表 2.对象归档 3.SQLite 4.Core Data 一.属性列表 NSUserDefaults类的使用和NSKeyedArchiver有很 ...

  5. 转载 -- iOS数据持久化存储

    作者:@翁呀伟呀 授权本站转载 概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方 ...

  6. 3D touch 的 应用 --备用

    在iPhone 6s和iPhone 6s Plus中Apple引入了3D Touch技术.3D Touch的触控技术,被苹果称为新一代多点触控技术.其实,就是此前在Apple Watch上采用的For ...

  7. 妙用valueForKeyPath

    valueForKey与valueForKeyPath在KVC中同时出现,都可以使用,难免让开发者迷惑:心里知道肯定是不一样,但具体的用法你会吗?其实valueForKeyPath的功能更强大,支持深 ...

  8. ios持久化存储

    前言 iOS中常用的持久化存储方式有好几种: 偏好设置(NSUserDefaults) plist文件存储 归档 SQLite3 Core Data 沙盒 每个iOS应用都有自己的应用沙盒(应用沙盒就 ...

  9. iOS中几种数据持久化方案

    概论 所谓的持久化,就是将数据保存到硬盘中,使得在应用程序或机器重启后可以继续访问之前保存的数据.在iOS开发中,有很多数据持久化的方案,接下来我将尝试着介绍一下5种方案: plist文件(属性列表) ...

随机推荐

  1. NGUI 滑动页(UIToggle和UIToggledObjects)

    1.NGUI->Create->Scroll View 2.给Scroll View添加一个 UIGrid,自己设置Arragement(横向竖向) 3.给Grid添加元素 4.给元素添加 ...

  2. codeforces 496B. Secret Combination 解题报告

    题目链接:http://codeforces.com/problemset/problem/496/B 题目意思:给出 n 位数你,有两种操作:1.将每一位数字加一(当某一位 > 9 时只保存个 ...

  3. dhtmlxTree介绍(转载)

    dhtmlxTree 是树菜单,允许我们快速开发界面优美,基于Ajax的javascript库. 她允许在线编辑,拖拽,三种状态(全选.不选.半选),复选框等模式.同时在加载大数据量的时候,仍然 可以 ...

  4. 【python】入门学习(十)

    #入门学习系列的内容均是在学习<Python编程入门(第3版)>时的学习笔记 统计一个文本文档的信息,并输出出现频率最高的10个单词 #text.py #保留的字符 keep = {'a' ...

  5. 甲鱼od19篇随笔

    在一个程序里会有多个对话框,这时要准确的判断要找的对话框就比较困难了所以这里就需要借助 1:Resource Hacker工具来准确的定位涉及到的对话框 2:在od中查找指令,然后在所有找到的指令上下 ...

  6. Google140道面试题

    FQ找来,可能历史比较悠久了,慢慢看. 原文连接:http://www.impactinterview.com/2009/10/140-google-interview-questions/ Goog ...

  7. 数独挑战(codevs 2924)

    2924 数独挑战  时间限制: 1 s  空间限制: 1000 KB  题目等级 : 钻石 Diamond 题解  查看运行结果     题目描述 Description “芬兰数学家因卡拉,花费3 ...

  8. CSS居中布局总结

    居中布局 <div class="parent"> <div class="child">demo</div> </d ...

  9. 最简单的Web服务器

    //读取浏览器发过来的内容Socket serverSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, Protoco ...

  10. 关于Linux环境变量

    查看全局变量:  printenv 查看单个环境变量的值可以用echo命令,必须在环境变量的名称前放一个$符号 如: