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等。链路层还负责错误检测和纠正,以确保数据的可靠传输。