NSDate是ios中的一个保存时间的对象,其中包含了时区。通过NSLog输出的[NSDate date]是GTM时区的时间,是0时区。而中国大陆采用的是正8区。

NSLog(@"GTM 时间:%@",[NSDate date]);

2013-07-09 15:16:38.007 demo[14267:13d03] GTM 时间:2013-07-09 07:16:38 +0000

通过NSDateFormatter将NSDate类的对象输出设置好的格式。NSDateFormatter采用ios操作系统的时区作为默认值。操作系统的时区通过[[NSTimeZone localTimeZone] name]获取到。

NSLog(@"[[NSTimeZone localTimeZone] name] is %@",[[NSTimeZone localTimeZone] name]);


NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];


[dateFormatter setDateFormat:@"YYYY-MM-d HH:mm:ss"];

将NSDateFormatter对象的时区设置"Asia/Shanghai" ,为正8区,输出结果就是我们现在看到的时间

[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Shanghai"]];

NSString *dStr = [dateFormatter stringFromDate:[NSDate date]];

NSLog(@"时区:%@ 当地时间:%@",[[dateFormatter timeZone] name], dStr);

将NSDateFormatter对象的时区设置"GMT" ,为0区,输出结果就是看到[NSDate date]的值。
[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"GMT"]];
dStr = [dateFormatter stringFromDate:[NSDate date]];

NSLog(@"时区:%@ 当地时间:%@",[[dateFormatter timeZone] name], dStr);


将NSDateFormatter对象的时区设置"Asia/Tokyo" ,为正9区,输出结果就是日本用户看到的时间
[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Tokyo"]];
dStr = [dateFormatter stringFromDate:[NSDate date]];

NSLog(@"时区:%@ 当地时间:%@",[[dateFormatter timeZone] name], dStr);


可以看到,NSDateFormatter根据时区设置,将时间进行调整。 如果加上时区的前者调整,其实是和GTM的时间是一致的。

NSDateFormatter也仅仅是将时间按照不同时区的设置进行显示,NSLog(@"GTM 时间:%@",[NSDate date]);是在GTM时区下显示时间。因此如果你看到的时间比本地时区显示的时间有差异,加了多少小时,或者减了多少小时。

这点,在所有的计算机系统中都是一样的,包括linux ,windows,solaris,aix等等。

NSDateFormatter也可以将指定格式的字符串转换为NSDate。这是其他语言中常见的时间转字符串,字符串转时间的操作方法。在ios的objective-c开发中,使用NSDateFormatter类来实现。不过,这里加了一点,时区。如果不加,就是系统默认值。

[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Shanghai"]];

NSDate *dateFormatted=[dateFormatter dateFromString:@"2013-07-09 12:00:00"];

NSLog(@"GTM 时间:%@",dateFormatted);

[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Tokyo"]];

dateFormatted=[dateFormatter dateFromString:@"2013-07-09 12:00:00" ];

NSLog(@"GTM 时间:%@",dateFormatted);

[dateFormatter setTimeZone:[NSTimeZone timeZoneWithName:@"GMT"]];

dateFormatted=[dateFormatter dateFromString:@"2013-07-09 12:00:00"];

NSLog(@"GTM 时间:%@",dateFormatted);




接着讲NSCalendar。

NSCalendar是ios中的一个保存日历数据的对象,其中也有时区设置,道理和NSDate一样的。NSCalendar可以将NSDate对象在日历中是一些属性特征显示出来。NSCalendar根据设置的时区进行计算,将NSDate对象是一年中的第几周,一个月中的第几周等等计算出来。

NSCalendar还涉及到一个类NSDateComponents,两者结合,可以将某些属性拆分出来,也可以通过它来设置NSDate,也可以实现NSDate的加减和比较运算。

NSDateComponents也可以设置时区,设置年月日时分秒。

NSCalendar *localCalendar= [NSCalendar currentCalendar];

unsigned unitFlags = NSTimeZoneCalendarUnit|NSYearCalendarUnit | NSMonthCalendarUnit |NSDayCalendarUnit|NSHourCalendarUnit|NSMinuteCalendarUnit|NSSecondCalendarUnit;

unitFlags是一个设置,表示NSDateComponents会保存那些属性,一般是时分秒天月年等等,还有星期几,哪个季度,哪个月度,这里将时区也一并保存了。
NSDateComponents *comps = [localCalendar components:unitFlags fromDate:[NSDate date]];


NSLog(@"时区:%@ hour is %d",[[comps timeZone] name] ,comps.hour);


同样,也可以通过NSDateComponents设置得到一个NSDate对象。

[comps setTimeZone:[NSTimeZone timeZoneWithName:@"Asia/Tokyo"]];

[comps setSecond:00];
[comps setMinute:00];
[comps setHour:12];

[comps setDay:9];
[comps setMonth:7];
[comps setYear:2013];

NSLog(@"时区:%@ hour is %d",[[comps timeZone] name] ,comps.hour);

NSDate *compsDate=[localCalendar dateFromComponents:comps];

NSLog(@"GTM 时间:%@",compsDate);



总之,理解透了,也就这么回事。将时区理解成日期时间的另一个属性。像大陆的下午两点和美国的下午两点,不是一个时间,因为还有时区这个前提条件存在。


测试结果如下:

2013-07-09 15:16:38.006 demo[14267:13d03] test begin.....................
2013-07-09 15:16:38.007 demo[14267:13d03] GTM 时间:2013-07-09 07:16:38 +0000
2013-07-09 15:16:38.007 demo[14267:13d03] [[NSTimeZone localTimeZone] name] is Asia/Shanghai
2013-07-09 15:16:38.008 demo[14267:13d03] 时区:Asia/Shanghai 当地时间:2013-07-9 15:16:38
2013-07-09 15:16:38.008 demo[14267:13d03] 时区:GMT 当地时间:2013-07-9 07:16:38
2013-07-09 15:16:38.009 demo[14267:13d03] GTM 时间:2012-07-09 04:00:00 +0000
2013-07-09 15:16:38.009 demo[14267:13d03] GTM 时间:2012-07-09 03:00:00 +0000
2013-07-09 15:16:38.009 demo[14267:13d03] GTM 时间:2012-07-09 12:00:00 +0000
2013-07-09 15:16:38.010 demo[14267:13d03] the end.....................
2013-07-09 15:16:38.010 demo[14267:13d03] ...............................
2013-07-09 15:16:38.010 demo[14267:13d03] test begin.....................
2013-07-09 15:16:38.010 demo[14267:13d03] 时区:Asia/Shanghai hour is 15
2013-07-09 15:16:38.011 demo[14267:13d03] 时区:Asia/Tokyo hour is 12
2013-07-09 15:16:38.011 demo[14267:13d03] GTM 时间:2013-07-09 03:00:00 +0000
2013-07-09 15:16:38.011 demo[14267:13d03] the end.....................

Linux网络编程之TCP/IP通信基础以及C/S例程分享

1. 应用层(Application Layer):应用层是最靠近用户的一层,它提供了用户与网络之间的接口。在应用层,应用程序可以通过使用各种协议(如HTTP、FTP、SMTP等)来进行通信。应用层的主要任务是处理应用程序之间的通信和数据交换。2. 传输层(Transport Layer):传输层负责在网络中的两个主机之间提供可靠的端到端数据传输。传输层使用两个主要的协议:传输控制协议(TCP)和用户数据报协议(UDP)。TCP提供可靠的、面向连接的数据传输,而UDP提供不可靠的、无连接的数据传输。3. 网络层(Network Layer):网络层负责在网络中的不同主机之间提供数据包的传输和路由。网络层使用Internet协议(IP)来标识和定位主机,并使用路由协议来选择最佳路径将数据包从源主机发送到目标主机。4. 链路层(Link Layer):链路层负责在物理网络中传输数据帧。它处理与物理介质的接口,如以太网、Wi-Fi等。链路层还负责错误检测和纠正,以确保数据的可靠传输。