object c小代码——日期篇

1、判断两个日期是否是同一天,不要求小时,分钟要一样

   用法

NSCalendar *calendar = [[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];

BOOL datesAreEqual = [calendar isDate:firstDate equalToDate:secondDate toUnitGranularity:NSDayCalendarUnit];

NSCalendar+equalWithGranularity.h

#import <Foundation/Foundation.h>

@interface NSCalendar (equalWithGranularity)

- (BOOL)isDate:(NSDate *)date1 equalToDate:(NSDate *)date2 withGranularity:(NSCalendarUnit)granularity;

@end

NSCalendar+equalWithGranularity.m

#import "NSCalendar+equalWithGranularity.h"

@implementation NSCalendar (equalWithGranularity)

- (BOOL)isDate:(NSDate *)date1 equalToDate:(NSDate *)date2 withGranularity:(NSCalendarUnit)granularity {

    if ([date1 isEqualToDate:date2]) {
        return YES;
    }
    int componentFlags = [self componentFlagsWithGranularity:granularity];
    date1 = [self dateFromDate:date1 withComponentFlags:componentFlags];
    date2 = [self dateFromDate:date2 withComponentFlags:componentFlags];
    return [date1 isEqualToDate:date2];

}
- (int)componentFlagsWithGranularity:(NSCalendarUnit)granularity
{
    int componentFlags = 0;
    for (int i = 1<<1 ; i <= granularity ; i = i<<1) {

        componentFlags = componentFlags | i;
    }
    return componentFlags;

}
- (NSDate *)dateFromDate:(NSDate *)date withComponentFlags:(int)componentFlags {

    NSDateComponents *components = [self components:componentFlags fromDate:date];
    return [self dateFromComponents:components];
}
@end

2、时间若干操作

1 // 当前时间创建NSDate

NSDate *myDate = [NSDate date];

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

2 //从现在开始的24小时

NSTimeInterval secondsPerDay = 24*60*60;

NSDate *tomorrow = [NSDate dateWithTimeIntervalSinceNow:secondsPerDay];

NSLog(@"myDate = %@",tomorrow);

3//根据已有日期创建日期

NSTimeInterval secondsPerDay1 = 24*60*60;

NSDate *now = [NSDate date];

NSDate *yesterDay = [now addTimeInterval:-secondsPerDay1];

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

4//比较日期

BOOL sameDate = [now isEqualToDate:yesterDay];

NSLog(@"sameDate = %lu",sameDate);

4.1//获取较早的日期

NSDate *earlierDate = [yesterDay earlierDate:now];

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

4.2//较晚的日期

NSDate *laterDate = [yesterDay laterDate:now];

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

//两个日期之间相隔多少秒

NSTimeInterval secondsBetweenDates= [yesterDay timeIntervalSinceDate:now];

NSLog(@"secondsBetweenDates= %lf",secondsBetweenDates);

//通过NSCALENDAR类来创建日期

NSDateComponents *comp = [[NSDateComponentsalloc]init];

[comp setMonth:06];

[comp setDay:01];

[comp setYear:2001];

NSCalendar *myCal = [[NSCalendaralloc]initWithCalendarIdentifier:NSGregorianCalendar];

NSDate *myDate1 = [myCal dateFromComponents:comp];

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

//从已有日期获取日期

unsigned units = NSMonthCalendarUnit|NSDayCalendarUnit|NSYearCalendarUnit;

NSDateComponents *comp1 = [myCal components:units fromDate:now];

NSInteger month = [comp1 month];

NSInteger year = [comp1 year];

NSInteger day = [comp1 day];

//NSDateFormatter实现日期的输出

NSDateFormatter *formatter = [[NSDateFormatteralloc]init];

[formatter setDateStyle:NSDateFormatterFullStyle];//直接输出的话是机器码

//或者是手动设置样式[formatter setDateFormat:@"yyyy-mm-dd"];

NSString *string = [formatter stringFromDate:now];

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

NSLog(@"formater = %@",formatter);

 

转自 http://www.cnblogs.com/xdream86/archive/2012/12/17/2821305.html,感谢原作者的整理收集

转载于:https://www.cnblogs.com/howeho/p/3467309.html

在Kotlin中,单例模式是一种非常常见的设计模式,它确保一个类只有一个实例,并提供全局访问该实例的方式。Kotlin中的单例模式可以使用对象声明来实现,这是一种非常方便的语法。但是,对象声明也有一些局限性,例如不能在运行时动态地创建对象。为了解决这个问题,可以使用带参单例模式。 带参单例模式是指在创建单例时,传递一些参数,以便在创建单例时使用。在Java中,可以使用静态方法或者静态变量来实现带参单例模式。但是在Kotlin中,可以使用伴生对象来实现带参单例模式。伴生对象是一个类的对象,可以访问该类的私有成员,并且可以实现接口。 下面是一个使用伴生对象实现带参单例模式的例子: ```kotlin class Singleton private constructor(private val name: String) { init { println("Singleton initialized with name $name") } companion object { private var instance: Singleton? = null fun getInstance(name: String): Singleton { if (instance == null) { instance = Singleton(name) } return instance!! } } } ``` 在上面的例子中,Singleton类的构造函数是私有的,只能在类内部访问。而伴生对象中的getInstance方法是公共的,可以在任何地方调用。getInstance方法接收一个name参数,用于在创建Singleton实例时使用。如果实例不存在,则创建一个新的实例,并将其存储在instance变量中。如果实例已经存在,则直接返回该实例。 可以使用以下代码创建Singleton实例: ```kotlin val singleton1 = Singleton.getInstance("test1") val singleton2 = Singleton.getInstance("test2") ``` 在上面的代码中,将分别创建名为test1和test2的两个Singleton实例。由于使用的是带参单例模式,因此可以为每个实例传递不同的参数。 带参单例模式在某些情况下非常有用,例如创建具有不同配置参数的实例。然而,需要注意的是,带参单例模式可能会导致一些问题,例如可能会导致内存泄漏或者线程安全问题。因此,在使用带参单例模式时,需要仔细考虑其适用性和安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值