Object-C学习笔记(一):类的定义

一、类的定义形式:

每当创建一个类的时候会出现2个扩展名文件,分别是.h和.m文件。

.h文件是类的声明文件(也叫接口文件),.m是类的实现文件,基本格式如下:


.h接口文件Test.h

#import <Foundation/Foundation.h>
@interface Test : NSObject   //这是一个父类继承自NSObject的类
@end


.m实现文件Test.m

#import "Static.h"
@implementation Test
@end

二、定义实例属性和实例方法:


         .h接口文件Test.h

#import <Foundation/Foundation.h>
@interface Test : NSObject
{
    //声明实例变量
        int number;
}
//声明实例方法
- (int)number;
- (void)setNumber: (int) n;
- (void)print;
@end

 

.m实现文件Test.m

#import "Static.h"
 @implementation Test
//方法实现
- (int)number
{
    return number;
}
- (void)setNumber:(int)n
{
        number = n;
}
- (void)print
{
        NSLog(@"%i",number);
}
 @end

     

       类的属性的采用了gettersetter的方式读取,体现了类的封装性。

       在实现类的头部导入了接口文件#import "Static.h"的原因:我们将接口和实现部分分成两个文件,编译器会单独编译每个文件,当编译实现文件的时候,需要知道接口部分的信息。


合成存取的方法:

OC2.0开始,可以自动生成设值方法和取值方法,通过使用@property@synthesize指令。可以将上面的类像如下定义:


.h接口文件Test.h

#import <Foundation/Foundation.h>
@interface Test : NSObject 
@property int number;
//声明实例方法
- (void)print;
@end


.m实现文件Test.m

#import "Static.h"
@implementation Test
@synthesize number;
- (void)print
{
        NSLog(@"%i",number);
}
@end

        通过@property@synthesize指令就代替了numbersetnumber取值方法,是由编译程序自动帮你完成。

三、通过点语法访问类属性

当你实例化一个类的之后可以使用简洁的点语法来访问类的属性,如下语句:

可以在mian.m文件里测试

#import <Foundation/Foundation.h>
#import "Test.h"
int main(int argc, const char * argv[])
{
    @autoreleasepool {
                                                                                                                                                                                                                                                                                                                                                                                                                                        
    Test *test = [[Test alloc] init] ;
    test.number = 10; //等价于 [test setNumber :10] 这是OC里调用实例方法的格式,也叫实例接受消息 ,传递一个参数10
   int i = test.number; //等价于int i = [test number]
}
   return 0;
}



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TR34ObjectIdentifers DEFINITIONS EXPLICIT TAGS ::= BEGIN -- Content types, from PKCS #7 -- pkcs7 OBJECT IDENTIFIER ::= { iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs7(7) } id-data OBJECT IDENTIFIER ::= { pkcs7 data(1) } id-signedData OBJECT IDENTIFIER ::= { pkcs7 signedData(2) } id-envelopedData OBJECT IDENTIFIER ::= { pkcs7 envelopedData (3) } id-digestedData OBJECT IDENTIFIER ::= { pkcs7 digestedData(5) } id-encryptedData OBJECT IDENTIFIER ::= { pkcs7 encryptedData (6) } pkcs9 OBJECT IDENTIFIER ::= { iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9) } smime OBJECT IDENTIFIER ::= { pkcs9 smime(16) } -- Signed attributes, from PKCS #9, S/MIME, and ANS X9.73 -- id-contentType OBJECT IDENTIFIER ::= { pkcs9 contentType(3) } id-messageDigest OBJECT IDENTIFIER ::= { iso(1) member-body(2) us(840) rsadsi(113549) pkcs(1) pkcs9(9) 4 } id-signingTime OBJECT IDENTIFIER ::= { pkcs9 signingTime(5) } id-contentIdentifier OBJECT IDENTIFIER ::= { smime id-aa(2) contentIdentifier(7) } id-msgSequenceNo OBJECT IDENTIFIER ::= { iso(1) member-body(2) us(840) x973(10060) attribute(1) msgSequenceNo(1) } id-signingCertificate OBJECT IDENTIFIER ::= { smime id-aa(2) signingCertificate(12) } id-otherSigningCert OBJECT IDENTIFIER ::= { itu-t(0) identified-organization(4) etsi(0) electronic-signature-standard(1733) part1(1) attributes(1) 12 } id-biometricSyntax OBJECT IDENTIFIER ::= { iso(1) member-body(2) us(840) x973(10060) attribute(1) biometricSyntax(2) } END 请理解这段代码,并使用openssl的接口,采用linux c编程完成对数据的编码和解码
最新发布
06-02

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值