• Xcode界面简介


    创建 Object-C 程序

    进入主界面方式 : 打开 Xcode 之后, 可以使用 Xcode 菜单, 但是必须创建一个 Object-C 工程 或者 导入 一个 Object-C 工程才可以进入主界面;

    -- 打开现有工程 : 点击右边的历史记录, 就可以打开现有的工程;

    -- 创建工程 : 点击第一个 Create a new Xcode Project 即可创建一个新工程;

    -- 导入工程 : 点击 Check out an existing project 可以导入一个已经创建的工程;

    创建一个命令行程序 : 选择 创建工程界面的 OS X --> Command Line Tool 程序, 即创建了一个命令行程序, Cocoa Application 是创建有界面的程序;

    -- ios 项目 : ios项目是为手机和平板开发的应用;

    -- OS X 项目 : OS X 是为 OS 操作系统创建的应用;

    创建工程 : 注明 工程名, 公司名称, 类型;

    -- Product Name : 工程名称;

    -- Organization Name : 组织名称;

    -- Type : 这里选 Foundation, 这是 Object-C 工程;



     创建 IOS 项目

    打开 Xcode 并选择创建新工程 : 弹出菜单中选择 IOS --> Single View Application 工程;

    填写项目信息 : 

    -- Product Name : 项目名称;

    -- Organization Name : 公司标识;

    -- Class Prefix : 为了避免用户定义类与 Object-C 类命名冲突问题, 在每个类之前都加上这个前缀;

    -- Devices : 选择应用运行的设备, Universal 表示同事兼容 ipad 和 iphone;

    Xcode 界面详解

    1. Xcode 界面简介

    (1) 顶部区域 

    程序运行相关 : 

    -- 从左至右介绍 : 运行按钮, 停止按钮, 为工程选择运行平台;

    编辑器相关 : 

    -- 从左至右介绍 : 标准编辑器, 辅助编辑器, 版本编辑器;

    面板控制相关 : 

    -- 从左至右介绍 : 隐藏左侧面板, 隐藏底部面板, 隐藏右侧面板;

    (2) 左面板

    面板介绍 : 该面板是 Xcode 工程导航面板, 上方的七个按钮用于切换导航模式;

    (3) 底部面板

    面板介绍 : 用于 Xcode 显示 控制台调试输出信息;

    (4) 右面板

    检查器面板 : 根据项目的不同, 包含大量审查器;

    库面板 : 

    -- 库面板简介(从左至右) : 文件模板库, 代码片段库, 对象库, 媒体库;

    (5) 详细编辑区

    该区域是代码编写主要区域 

    2. 导航面板详解

    导航面板简介 : 

    -- 从左至右 : 项目导航, 符号导航, 搜索导航, 问题导航, 测试导航, 调试导航, 断点导航, 日志导航;

    (1) 项目导航

    项目导航组成 : 

    -- 源文件 : 在 HelloWorld 目录下的 ".h" 和 ".m" 后缀文件是源文件;

    -- 属性文件 : 在 HelloWorld 下的 Supporting Files 目录下是属性文件 图片等;

    -- 单元测试项目 : HelloWorldTest 是工程的单元测试项目;

    -- 目标应用 : Products 目录下的 HelloWorld.app 是目标应用;

    (2) 符号导航

    符号导航简介 : 用符号显示工程中的 类, 项目 和 属性;

    -- 表示方式 : C 表示类, M 表示方法, P 表示属性;

    -- 快速定位 : 点击对应的方法或者属性, 能快速定位到这个类中;

    (3) 搜索导航

    搜索导航简介 : 在搜索框中输入要搜索的字符串, 按回车就可以搜索出包含该字符串的类;

    (4) 问题导航面板

    问题导航面板简介 : 显示项目中存在的警告或者错误;

    (5) 测试导航

    测试导航简介 : 点击 testExample 后面的执行按钮, 就会运行该单元测试;

    (6) 调试导航

    调试导航简介 : 调试导航面板中显示了各线程的详细信息;

    添加断点 : 在 OCTViewController.m 中添加一个断点;

    开始调试(自动判断) : 点击顶部面板中的调试按钮, 如果代码中有断点, 就会自动进入调试状态, 执行到断点时会自动停止, 详细调试信息显示在底部的调试输出面板;

    调试面板介绍 :  下面从左至右介绍;

    -- Continue program execution : 继续执行下面的代码;

    -- Step over : 单步调试, 点击一次该按钮, 执行一行代码, 如果有方法调用, 不会进入方法中;

    -- Strp in : 步入调试, 点击该按钮, 会进入方法中;

    -- Step out : 步出调试, 在方法中, 点击该按钮, 会退出方法, 执行方法外的单步调试;

    (7) 断点导航

    断点导航简介 : 列出所有的断点, 方便管理断点;

    (8) 日志导航

    日志导航简介 : 列出项目开发过程中 构建, 生成, 运行过程, 每次该过程都可以通过日志面板查看;

    3. 检查器面板

    检查面板分类 : 

    -- 普通源文件 : 包含 文件检查器 和 快速帮助器;

    -- 故事版 : 界面文件, 除了文件检查器 和 快速帮助器之外, 还有 身份检查器, 属性检查器, 大小检查器, 连接检查器;

    文件检查器 : 

    -- Identity and Type : File Name(文件名), File Type(文件类型), Full Path(路径);

    -- Text Settings : Text Encoding(文件编码使用字符集), Indent Using(缩进), Wrap lines(自动换行);

    快速帮助器 : 将光标停留在系统类的时候, 该面板会显示该类的 参考手册, 使用指南 和 示例代码;

    界面设计相关检查器 : 用户选中 ".storyboard" 或者 ".xib" 后缀的文件时, 会多出另外四个检查器;

    -- 身份检查器 : 管理界面组件类 实现类, 恢复ID 等标识性的属性;

    -- 属性检查器 : 管理界面组件 拉伸方式, 背景色 等属性;

    -- 大小检查器 : 管理界面组件 宽高 xy轴坐标 等属性;

    -- 连接检查器 : 管理界面组件 与程序代码之间的关联性;

    4. 库面板

    库面板简介 : 从左至右介绍;

    -- 文件库模板 : 管理文件模板, 可以快速创建指定类型文件, 可以直接拖入项目中;

    -- 代码片段库 : 管理各种代码片段, 可以直接拖入源代码中;

    -- 对象库 : 界面组件, 可以直接拖入 故事板中;

    -- 媒体库 : 管理各种 图片, 音频 等多媒体资源;

    Xcode 帮助系统详解

    帮助系统作用 : Object-C 开发中需要调用很多系统的类, 需要了解每个类的 用法, 通过 Xcode 帮助系统可以查询这些类的用法;

    1. 快速帮助面板

    右面板中的快速面板显示内容 : 该类继承的父类, 遵循的协议, 类所在框架, 点击Reference 中的链接, 可以进入类的详细介绍;

    类详细介绍页面 : 通过 快速帮助面板 中的 Reference 中的链接, 可以进入该页面;

    类方法分类界面 : 该界面与详细介绍界面是同一个, 下拉即可;

    2. 直接搜索

    搜索 : 通过任意链接进入类详细介绍界面之后, 可以在上方的输入框中输入关键字, 即可搜索相关的 类, 方法, 协议 或者 函数;

    3. 代码自动提示

    提示方式 : 代码编辑区域, 按住 option 键, 然后将光标移动到类上, 会变成问号, 点击就会出现下面的提示框;

    1. 文件扩展名介绍

    C语言源文件后缀 : ".c";

    C++语言源文件后缀 : ".cc", ".cpp";

    头文件 : ".h";

    Object-C源程序 : ".m";

    Object-C++源程序 : ".mm";

    C/C++/Object-C/Object-C++生成的中间文件 : ".o";

    C/C++/Object-C/Object-C++生成的可执行文件 : ".out";

    2. 程序源码及解析

    程序源码 

    /* 导入 Foundation 框架下的 Foundation.h 文件 */
    #include <Foundation/Foundation.h>
    
    /* 程序入口函数 */
    int main(int argc, char * argv[])
    {
    	/* 自动释放池, 该环境中执行的语句会自动回收所创建的对象 */
    	@autoreleasepool
    	{
    		/* Foundation 中的输出函数, 可输出字符串, 对象等 */
    		NSLog(@"Hello World"); /* @"Hello World", 加上 @ 是为了与 C 中的字符串区分 */
    	}
    	return 0;
    }



    (1) 导入框架头文件

    导入头文件语句 : #import <a/b.h> 是导入 a 框架 中的 b.h 头文件;

    框架简介 : 框架是 一系列类 函数的集合, Cocoa QuickTime 都被封装成了框架, Cocoa 包括了 Foundation 和 Application Kit 等组件;

    (2) 自动释放池

    内存管理 : 在早期的 Object-C 需要手动管理内存的分配和回收, Object-C 2.0 引入了 ARC(自动引用计数) 和 自动释放池, 不在进行手动内存管理;

    自动释放池 : 使用 "@autoreleasepool{}" 包裹的代码位于 Object-C 的自动释放池中, 这些语句会自动回收创建的对象, 不用进行手动的内存管理;

    (3) 字符串输出

    NSLog()函数 : 该函数是 Foundation 框架提供的一个函数, 该函数可以输出 字符串 对象等;

    -- NS 前缀说明 : Cocoa 框架中所有的 类 函数 常量 都会加上 NS 前缀;

    -- @"string" 说明 : @符号 用于区分 Object-C 与 C语言字符串, 加上 @ 符号的时 Object-C 字符串;

    3. 编译运行代码

    LLVM Clang 编译器语法 : clang -fobjc-arc -framwork 框架名称 源程序 -o 输出结果 ;

    -- -fobjc-arc 参数 : 启用 Object-C 的 ARC 自动技术功能;

    -- -o 参数 : 如果不带, 默认 输出 a.out ;

    编译执行结果 : 

    octopus-2:ios octopus$ clang -fobjc-arc -framework Foundation 01-HelloWorld.m 
    octopus-2:ios octopus$ ls
    01-HelloWorld.m	a.out
    octopus-2:ios octopus$ ./a.out 
    2014-08-10 00:22:55.670 a.out[3394:507] Hello World

     LLDB(就是Xcode下方的调试栏)中有用的一些命令
        打印帮助
        打印调用栈
        打印最基本的内容 (p)
        打印对象(po)
        打印表达式(expr)
        打印线程中的一些东西

    LLDB  常用命令

    假如你准备在模拟器里面运行这个,你可以在“(lldb)”提示的后面输入下面的:

    (lldb) po $eax

    LLDB在xcode4.3或者之后的版本里面是默认的调试器。假如你正在使用老一点版本的xcode的话,你又GDB调试器。他们有一些基本的相同的命令,因此假如你的xcode使用的是“(gdb)”提示,而不是“(lldb)”提示的话,你也能够更随一起做,而没有问题。

    “po”命令是“print object”(打印对象)的简写。“$eax”是cup的一个寄存器。在一个异常的情况下,这个寄存器将会包含一个异常对象的指针。注意:$eax只会在模拟器里面工作,假如你在设备上调试,你将需要使用”$r0″寄存器。

    例如,假如你输入:

    (lldb) po [$eax class]

    你将会看像这样的东西:

    (id) $2 = 0x01446e84 NSException

    这些数字不重要,但是很明显的是你正在处理的NSException对象在这里。

    你可以对这个对象调用任何方法。例如:

    (lldb) po [$eax name]

    这个将会输出这个异常的名字,在这里是NSInvalidArgumentException,并且:

    (lldb) po [$eax reason]

    这个将会输出错误消息:

    (unsigned int) $4 = 114784400 Receiver () has no segue with identifier 'ModalSegue'

    注意:当你仅仅使用了“po $eax”,这个命令将会对这个对象调用“description”方法和打印出来,在这个情况下,你也会得到错误的消息。

    实用LLDB命令

    命令名 用法 说明

     
    expr expr 表达式 可以在调试时动态执行指定表达式,并将结果打印出来,很有用的命令。
    po po 表达式 与expr类似,打印对象,会调用对象description方法。是print-object的简写
    print print (type) 表达式 也是打印命令,需要指定类型。
    bt bt [all] 打印调用堆栈,是thread backtrace的简写,加all可打印所有thread的堆栈。
    br l br l breakpoint list的简写
    process continue l process continue 简写:c
    thread step-in l thread step-in l 简写:s
    thread step-inst l thread step-inst l 简写:si
    thread step-over l thread step-over l 简写:n
    thread step-over-inst l thread step-over-inst l 简写:ni
    thread step-out l thread step-out l 简写:f
    thread list thread list 简写:th l

     

    内存泄漏隐患提示
    Potential Leak of an object allocated on line ……
    数据赋值隐患提示
    The left operand of …… is a garbage value;
    对象引用隐患提示
    Reference-Counted object is used after it is released;

    对retain、copy、init、release、autorelease等在计数时的使用情况的详细讲解,推荐一下:

    http://www.cnblogs.com/andyque/archive/2011/08/08/2131236.html

    调用autorelease这意味着,你可以在这个函数里面使用vari,但是,一旦下一次run loop被调用的时候,它就会被发送release对象。然后引用计数改为0,那么内存也就被释放掉了。(关于autorelease到底是怎么工作的,我的理解是:每一个线程都有一个autoreleasePool的栈,里面放了很多autoreleasePool对象。当你向一个对象发送autorelease消息之后,就会把该对象加到当前栈顶的autoreleasePool中去。当当前runLoop结束的时候,就会把这个pool销毁,同时对它里面的所有的autorelease对象发送release消息。而autoreleasePool是在当前runLoop开始的时候创建的,并压入栈顶。那么什么是一个runLoop呢?一个UI事件,Timer call, delegate call, 都会是一个新的Runloop。)

     
  • 相关阅读:
    Heartbeat实现热备
    rsync实现数据增量备份
    MySql重置密码
    media viewport
    Java操作Excel之JXL (填充EXCEL模板)转载
    字节流与字符流的区别详解
    GIT和SVN的区别
    oracle与DB2递归查询
    SQL中使用WITH AS提高性能 简化嵌套SQL(转载)
    CVS tag and branch(转)
  • 原文地址:https://www.cnblogs.com/isItOk/p/4683371.html
Copyright © 2020-2023  润新知