.NET Framework各个版本(4.5)

增加了两个新关键字async和await它们可用于基于任务的异步模式(TAP)

什么是基于任务的异步模式呢?

这就要说到.NET 4.0新增加的Task类型,它可以让我们更加方便的进行多线程开发。它提供了很多方法像开启任务(Start,Run方法等),延续任务(ContinueWith),等待任务(Wait,WaitAll,WaitAny),取消任务(CancellationToken),延迟执行(Delay),条件执行(WhenAll,WhenAny)等。

通常能够使用async和await的方法总是返回Task<T>类型,下面的例子是Redis命令中一个判断key是否存在的异步方法:

Task<bool> KeyExistsAsync(RedisKey key, CommandFlags flags = CommandFlags.None);

该方法返回的是一个Task<bool>类型,我是这样封装它的:

        /// <summary>
        /// 判断Key是否存在
        /// </summary>
        /// <param name="key"></param>
        /// <param name="db"></param>
        /// <returns></returns>
        public async Task<bool> KeyExistsAsync(string key,int db)
        {
            return await RedisManager.ReadDataBase(db).KeyExistsAsync(key);
        }

最终调用的例子如下:

            RedisCommand command = new RedisCommand();
            var flag = command.KeyExistsAsync("city", 1).Result;

.NET 4.5 的另一个新特性是 Zip 压缩改进,可减少压缩文件的大小,进而可以减轻网络带宽的压力,例子如下:

        /// <summary>
        /// 压缩字节数组
        /// </summary>
        /// <param name="str"></param>
        public static byte[] Compress(byte[] inputBytes)
        {
            using (MemoryStream outStream = new MemoryStream())
            {
                using (GZipStream zipStream = new GZipStream(outStream, CompressionMode.Compress, true))
                {
                    zipStream.Write(inputBytes, 0, inputBytes.Length);
                    zipStream.Close(); //很重要,必须关闭,否则无法正确解压
                    return outStream.ToArray();
                }
            }
        }

        /// <summary>
        /// 解压缩字节数组
        /// </summary>
        /// <param name="str"></param>
        public static byte[] Decompress(byte[] inputBytes)
        {

            using (MemoryStream inputStream = new MemoryStream(inputBytes))
            {
                using (MemoryStream outStream = new MemoryStream())
                {
                    using (GZipStream zipStream = new GZipStream(inputStream, CompressionMode.Decompress))
                    {
                        zipStream.CopyTo(outStream);
                        zipStream.Close();
                        return outStream.ToArray();
                    }
                }

            }
        }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在.NET Framework 4.5中,时间戳是指将日期和时间表示为一串数字或字符串的方法。时间戳经常用于跟踪和记录事件的顺序和时间。在.NET Framework 4.5中,可以使用DateTime结构来表示日期和时间。DateTime结构具有一些有用的成员和方法,用于在应用程序中处理和操作日期和时间。 在.NET Framework 4.5中,可以使用DateTime.Now属性来获取当前的日期和时间。这个属性返回一个DateTime对象,其中包含了当前的日期和时间。可以使用DateTime.Now.ToString()方法将DateTime对象转换为字符串,以方便在控制台或文件中显示。 如果需要将日期和时间保存为时间戳格式,可以使用DateTime.Now.Ticks属性。Ticks属性返回从0001年1月1日午夜以来经过的以100纳秒为单位的时间间隔数。可以使用ToString("yyyyMMddHHmmssffff")方法将Ticks值转换为字符串,其中参数指定了输出字符串的格式。这样可以得到一个精确到毫秒的时间戳字符串,用于表示某个特定时刻的时间。 除了在本地计算机上获取当前的日期和时间之外,.NET Framework 4.5还提供了一些其他方法来处理和操作日期和时间。例如,可以使用DateTime.Parse()方法将字符串转换为DateTime对象,以便进行日期和时间的计算和比较。还可以使用DateTime.AddDays()、DateTime.AddMinutes()等方法对日期和时间进行加减操作。 总而言之,.NET Framework 4.5为处理和操作日期和时间提供了一系列强大的工具和方法。通过使用DateTime结构和相关方法,可以轻松地获取当前的日期和时间,将其保存为时间戳格式,并进行各种日期和时间的计算和操作。 ### 回答2: 在.NET Framework 4.5中,时间戳(Timestamp)是一个64位的整数值,用于表示自某个固定时间点(通常是1970年1月1日午夜以来的毫秒数)至当前时间的经过时间。 .NET Framework 4.5引入了一个名为DateTimeOffset的新的日期和时间结构,它比以前的DateTime结构提供了更多的功能和灵活性,其中包括支持时间戳的特性。DateTimeOffset结构可以通过ToUnixTimeMilliseconds方法将日期和时间转换为时间戳。 时间戳在很多应用场景中都很有用,例如跟踪和记录事件发生的时间,或者在分布式系统中用于确定操作的先后顺序。使用时间戳可以确保不同计算机或设备上的事件具有相对一致的时间参考。 在.NET Framework 4.5中,使用时间戳可以通过以下步骤完成:首先,获取当前的日期和时间,可以使用DateTime.Now属性获取当前的本地时间。然后,可以使用DateTimeOffset结构的ToUnixTimeMilliseconds方法将日期和时间转换为时间戳的毫秒数。 值得注意的是,时间戳通常是以数字形式表示的,可能会很难阅读和理解。为了方便人类阅读,可以使用ToString方法将时间戳转换为格式化的日期和时间字符串。 总而言之,时间戳在.NET Framework 4.5中具有很多实用的用途,并且可以通过DateTimeOffset结构和ToUnixTimeMilliseconds方法轻松地实现和使用。 ### 回答3: .NET Framework 4.5中的时间戳指的是一种用于表示特定时间的数值。它通常用于记录或标记事件发生的时间,以便后续的分析或数据处理。 在.NET Framework 4.5中,可以使用DateTimeOffset结构来获取时间戳。这个结构包含了日期和时间信息,同时也包含了与协调世界时(Coordinated Universal Time,UTC)之间的偏移量。 在获取时间戳之前,可以使用DateTimeOffset.UtcNow属性获取当前时间。这个时间是基于协调世界时的。 接下来,可以使用DateTimeOffset.ToUnixTimeSeconds()方法将时间戳转换为从协调世界时的1970年1月1日午夜开始计算的秒数。这个方法返回的是一个长整数值。 另外,还可以使用DateTimeOffset.ToUnixTimeMilliseconds()方法来获取时间戳的毫秒数。这个方法返回的也是一个长整数值,表示从协调世界时的1970年1月1日午夜开始计算的毫秒数。 需要注意的是,以上方法返回的时间戳值,不受本地时区的影响。这意味着无论程序在哪个时区运行,获取到的时间戳都是一致的。 在.NET Framework 4.5中,时间戳的使用非常方便,可以用于各种需要记录或处理时间信息的场景,例如日志记录、数据同步等。同时,使用协调世界时作为参考时间,确保了时间戳的一致性和准确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值