#import和#include区别 #import和@class的区别 #import<>和#import""的区别

本文详细解析了Objective-C中的预处理指令#import、#include及@class的区别,对比了它们在不同场景下的应用,并介绍了#import的不同形式。
#import和#include的区别
(1)使用场合不同
  #import是导入Objective-C头文件的关键词,#include是导入C/C++头文件的关键词
(2)重复引用

  使用#include需要处理重复引用,#import能防止同一个文件被多次包含,则不需要处理重复引用


#import和@class的区别:

(1)包不包含
      #import会包含这个类的所有信息(包括实体变量和方法),而@class只是告诉编译器,其后面声明的名称是类的名称,至于这些类是如何定义的,你现在不需要关心
(2)用与不用
   在头文件中,一般只需要知道被引用的类的名称就可以了,不需要关心类内部细节,所有用@class
   在实现文件中,会用到被引用类的内部的实体变量和方法,所以用#import来包含被引用类的头文件

(3)编译效率
    假如你有100个头文件都#import了同一个头文件A,或者这些文件存在依赖关系:A–>B, B–>C, C–>D...。当头文件A发生改变的时候,后面所有引用它的类都需要重新编译,这是非常耗性能的。而用@class则不会。
(4)是否会产生循环依赖

     假如有循环依赖关系:A–>B,B–>A,如果使用#import来相互包含,那么就会出现编译错误,如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。

      所以,一般来说,@class是放在interface中的,只是为了在interface中声明这个类。如果在@implementation中需要引用这个类的实体变量或者方法之类的,还是需要import在@class中声明的类进来.

#import<>和#import的区别

这两者区别很简单,#import用来包含系统自带的文件,#import""用来包含自定义的文件

这段代码是一个基于 FreeMarker 模板引擎的网页代码,用于实现 **添加展示群组成员** 的功能,主要用于 Web 应用的后台管理系统中。下面逐段解析其功能: --- ### 1. 引入标签库宏定义 ```ftl <#assign ww = JspTaglibs["/WEB-INF/webwork.tld"] /> <#import "/decorators/includes/macros.ftl" as m> <#include "/template/includes/actionerrors.ftl"> ``` - `<#assign ww = ...>`:引入 WebWork 自定义标签库(`ww` 是标签前缀)。 - `<#import ...>`:导入宏文件,宏用于复用代码片段(如 `@m.employeeSelector` `@m.directoryLink`)。 - `<#include ...>`:包含错误信息显示模板,用于显示表单提交时的错误。 --- ### 2. 添加群组成员的表单 ```ftl <h3>Add Group Member</h3> <@ww.form name="'createGroupFieldForm'" action="'addGroupFields'" namespace="'/admin'" validate="'true'" method="'post'"> <@ww.select label="'Group Name'" name="'groupField.fieldsName'" list="groupFieldsNamesList"/> <tr class="b"> <td>Employee No:</td> <td><@m.employeeSelector fieldName="groupField.employeeNo"/></td> </tr> <tr> <td colspan="2"> <input type="submit" class="btn" value="Add"/> <input type="reset" class="btn" value="Reset"/> </td> </tr> </@ww.form> ``` - `<@ww.form>`:创建一个表单,提交到 `/admin/addGroupFields`,使用 POST 方法,支持表单验证。 - `<@ww.select>`:创建一个下拉框,用于选择组名(`groupField.fieldsName`),数据来源是 `groupFieldsNamesList`。 - `<@m.employeeSelector>`:调用宏来选择员工编号(自动补全或搜索员工)。 - 提交按钮重置按钮。 --- ### 3. 显示群组成员列表 ```ftl <h3>Group Member List</h3> <table> <tr> <th>Group Name</th> <th>Employee</th> <th>Created Time</th> <th>Created By</th> <th>Delete</th> </tr> <#list groupFields as g> <tr class="b"> <td>${g.fieldsName?if_exists}</td> <td><@m.directoryLink g.employeeNo/></td> <td>${g.createDate?if_exists}</td> <td>${g.createdBy?if_exists}</td> <td><a href="deleteGroupFields.action?groupId=${g.id}">Delete</a></td> </tr> </#list> </table> ``` - `<#list groupFields as g>`:遍历 `groupFields` 列表,每个 `g` 表示一个群组成员记录。 - `${g.fieldsName?if_exists}`:显示组名,如果为空则不显示。 - `<@m.directoryLink>`:调用宏生成员工链接(可能是员工详情链接)。 - 显示创建时间、创建者信息。 - 删除链接,指向 `deleteGroupFields.action`,传入 `groupId` 删除记录。 --- ### 总结 这段代码的功能是: 1. 提供一个表单,让用户选择群组名员工编号,添加群组成员。 2. 展示当前所有群组成员列表,并提供删除操作。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值