ylbtech-System.IO.Stream.cs
1.返回顶部
1、
#region 程序集 mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089
// C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.5\mscorlib.dll
#endregion using System.Runtime;
using System.Runtime.InteropServices;
using System.Threading;
using System.Threading.Tasks; namespace System.IO
{
//
// 摘要:
// 提供字节序列的一般视图。 这是一个抽象类。若要浏览此类型的.NET Framework 源代码,请参阅 Reference Source。
[ComVisible(true)]
public abstract class Stream : MarshalByRefObject, IDisposable
{
//
// 摘要:
// 无后备存储区的 Stream。
public static readonly Stream Null; //
// 摘要:
// 初始化 System.IO.Stream 类的新实例。
protected Stream(); //
// 摘要:
// 当在派生类中重写时,获取或设置当前流中的位置。
//
// 返回结果:
// 流中的当前位置。
//
// 异常:
// T:System.IO.IOException:
// 出现 I/O 错误。
//
// T:System.NotSupportedException:
// 流不支持查找。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
public abstract long Position { get; set; }
//
// 摘要:
// 当在派生类中重写时,获取流长度(以字节为单位)。
//
// 返回结果:
// 表示流长度(以字节为单位)的长值。
//
// 异常:
// T:System.NotSupportedException:
// 从派生的类 Stream 不支持查找。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
public abstract long Length { get; }
//
// 摘要:
// 当在派生类中重写时,获取指示当前流是否支持写入功能的值。
//
// 返回结果:
// 如果流支持写入,则为 true;否则为 false。
public abstract bool CanWrite { get; }
//
// 摘要:
// 获取一个值,该值确定当前流是否可以超时。
//
// 返回结果:
// 一个确定当前流是否可以超时的值。
[ComVisible(false)]
public virtual bool CanTimeout { get; }
//
// 摘要:
// 当在派生类中重写时,获取指示当前流是否支持查找功能的值。
//
// 返回结果:
// 如果流支持查找,为 true;否则为 false。
public abstract bool CanSeek { get; }
//
// 摘要:
// 当在派生类中重写时,获取指示当前流是否支持读取的值。
//
// 返回结果:
// 如果流支持读取,为 true;否则为 false。
public abstract bool CanRead { get; }
//
// 摘要:
// 获取或设置一个值(以毫秒为单位),该值确定流在超时前尝试读取多长时间。
//
// 返回结果:
// 一个确定流在超时前尝试读取多长时间的值(以毫秒为单位)。
//
// 异常:
// T:System.InvalidOperationException:
// System.IO.Stream.ReadTimeout 方法始终引发 System.InvalidOperationException。
[ComVisible(false)]
public virtual int ReadTimeout { get; set; }
//
// 摘要:
// 获取或设置一个值(以毫秒为单位),该值确定流在超时前尝试写入多长时间。
//
// 返回结果:
// 一个确定流在超时前尝试写入多长时间的值(以毫秒为单位)。
//
// 异常:
// T:System.InvalidOperationException:
// System.IO.Stream.WriteTimeout 方法始终引发 System.InvalidOperationException。
[ComVisible(false)]
public virtual int WriteTimeout { get; set; } //
// 摘要:
// 在指定的 System.IO.Stream 对象周围创建线程安全(同步)包装。
//
// 参数:
// stream:
// 要同步的 System.IO.Stream 对象。
//
// 返回结果:
// 一个线程安全的 System.IO.Stream 对象。
//
// 异常:
// T:System.ArgumentNullException:
// stream 为 null。
public static Stream Synchronized(Stream stream);
//
// 摘要:
// 开始异步读操作。 (考虑使用 System.IO.Stream.ReadAsync(System.Byte[],System.Int32,System.Int32)
// 进行替换;请参见“备注”部分。)
//
// 参数:
// buffer:
// 数据读入的缓冲区。
//
// offset:
// buffer 中的字节偏移量,从该偏移量开始写入从流中读取的数据。
//
// count:
// 最多读取的字节数。
//
// callback:
// 可选的异步回调,在完成读取时调用。
//
// state:
// 一个用户提供的对象,它将该特定的异步读取请求与其他请求区别开来。
//
// 返回结果:
// 表示异步读取的 System.IAsyncResult(可能仍处于挂起状态)。
//
// 异常:
// T:System.IO.IOException:
// 尝试超出末尾的流中的异步读取或发生了磁盘错误。
//
// T:System.ArgumentException:
// 一个或多个参数无效。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
//
// T:System.NotSupportedException:
// 当前 Stream 实现不支持读取的操作。
public virtual IAsyncResult BeginRead(byte[] buffer, int offset, int count, AsyncCallback callback, object state);
//
// 摘要:
// 开始异步写操作。 (考虑使用 System.IO.Stream.WriteAsync(System.Byte[],System.Int32,System.Int32)
// 进行替换;请参见“备注”部分。)
//
// 参数:
// buffer:
// 从中写入数据的缓冲区。
//
// offset:
// buffer 中的字节偏移量,从此处开始写入。
//
// count:
// 最多写入的字节数。
//
// callback:
// 可选的异步回调,在完成写入时调用。
//
// state:
// 一个用户提供的对象,它将该特定的异步写入请求与其他请求区别开来。
//
// 返回结果:
// 表示异步写入的 IAsyncResult(可能仍处于挂起状态)。
//
// 异常:
// T:System.IO.IOException:
// 尝试异步写入该流的末尾,或者发生了磁盘错误。
//
// T:System.ArgumentException:
// 一个或多个参数无效。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
//
// T:System.NotSupportedException:
// 当前 Stream 实现不支持写入操作。
public virtual IAsyncResult BeginWrite(byte[] buffer, int offset, int count, AsyncCallback callback, object state);
//
// 摘要:
// 关闭当前流并释放与之关联的所有资源(如套接字和文件句柄)。 不直接调用此方法,而应确保流得以正确释放。
public virtual void Close();
//
// 摘要:
// 从当前流中读取字节并将其写入到另一流中。
//
// 参数:
// destination:
// 当前流的内容将复制到的流。
//
// 异常:
// T:System.ArgumentNullException:
// destination 为 null。
//
// T:System.NotSupportedException:
// 当前流不支持读取。- 或 -destination 不支持写入。
//
// T:System.ObjectDisposedException:
// 当前流或 destination 之前关闭 System.IO.Stream.CopyTo(System.IO.Stream) 方法被调用。
//
// T:System.IO.IOException:
// 出现 I/O 错误。
public void CopyTo(Stream destination);
//
// 摘要:
// 使用指定的缓冲区大小,从当前流中读取字节并将其写入到另一流中。
//
// 参数:
// destination:
// 当前流的内容将复制到的流。
//
// bufferSize:
// 缓冲区的大小。 此值必须大于零。 默认大小为 81920。
//
// 异常:
// T:System.ArgumentNullException:
// destination 为 null。
//
// T:System.ArgumentOutOfRangeException:
// bufferSize 为负数或零。
//
// T:System.NotSupportedException:
// 当前流不支持读取。- 或 -destination 不支持写入。
//
// T:System.ObjectDisposedException:
// 当前流或 destination 之前关闭 System.IO.Stream.CopyTo(System.IO.Stream) 方法被调用。
//
// T:System.IO.IOException:
// 出现 I/O 错误。
public void CopyTo(Stream destination, int bufferSize);
//
// 摘要:
// 从当前流中异步读取字节并将其写入到另一个流中。
//
// 参数:
// destination:
// 当前流的内容将复制到的流。
//
// 返回结果:
// 表示异步复制操作的任务。
//
// 异常:
// T:System.ArgumentNullException:
// destination 为 null。
//
// T:System.ObjectDisposedException:
// 已释放当前的流或目标流。
//
// T:System.NotSupportedException:
// 当前的流不支持读取,或目标流不支持写入。
[ComVisible(false)]
public Task CopyToAsync(Stream destination);
//
// 摘要:
// 使用指定的缓冲区大小,从当前流中异步读取字节并将其写入到另一流中。
//
// 参数:
// destination:
// 当前流的内容将复制到的流。
//
// bufferSize:
// 缓冲区的大小(以字节为单位)。 此值必须大于零。 默认大小为 81920。
//
// 返回结果:
// 表示异步复制操作的任务。
//
// 异常:
// T:System.ArgumentNullException:
// destination 为 null。
//
// T:System.ArgumentOutOfRangeException:
// buffersize 为负数或零。
//
// T:System.ObjectDisposedException:
// 已释放当前的流或目标流。
//
// T:System.NotSupportedException:
// 当前的流不支持读取,或目标流不支持写入。
[ComVisible(false)]
public Task CopyToAsync(Stream destination, int bufferSize);
//
// 摘要:
// 使用指定的缓冲区大小和取消令牌,从当前流中异步读取字节并将其写入到另一个流中。
//
// 参数:
// destination:
// 当前流的内容将复制到的流。
//
// bufferSize:
// 缓冲区的大小(以字节为单位)。 此值必须大于零。 默认大小为 81920。
//
// cancellationToken:
// 要监视取消请求的标记。 默认值为 System.Threading.CancellationToken.None。
//
// 返回结果:
// 表示异步复制操作的任务。
//
// 异常:
// T:System.ArgumentNullException:
// destination 为 null。
//
// T:System.ArgumentOutOfRangeException:
// buffersize 为负数或零。
//
// T:System.ObjectDisposedException:
// 已释放当前的流或目标流。
//
// T:System.NotSupportedException:
// 当前的流不支持读取,或目标流不支持写入。
[ComVisible(false)]
public virtual Task CopyToAsync(Stream destination, int bufferSize, CancellationToken cancellationToken);
//
// 摘要:
// 释放由 System.IO.Stream 使用的所有资源。
public void Dispose();
//
// 摘要:
// 等待挂起的异步读取完成。 (考虑使用 System.IO.Stream.ReadAsync(System.Byte[],System.Int32,System.Int32)
// 进行替换;请参见“备注”部分。)
//
// 参数:
// asyncResult:
// 对要完成的挂起异步请求的引用。
//
// 返回结果:
// 从流中读取的字节数,介于零 (0) 和所请求的字节数之间。 流仅在流结尾返回零 (0),否则在至少有 1 个字节可用之前应一直进行阻止。
//
// 异常:
// T:System.ArgumentNullException:
// asyncResult 为 null。
//
// T:System.ArgumentException:
// 挂起的读操作的句柄将不可用。- 或 -挂起的操作不支持读取。
//
// T:System.InvalidOperationException:
// asyncResult 不是源自 System.IO.Stream.BeginRead(System.Byte[],System.Int32,System.Int32,System.AsyncCallback,System.Object)
// 上当前流的方法。
//
// T:System.IO.IOException:
// 流已关闭或出现了内部错误。
public virtual int EndRead(IAsyncResult asyncResult);
//
// 摘要:
// 结束异步写操作。 (考虑使用 System.IO.Stream.WriteAsync(System.Byte[],System.Int32,System.Int32)
// 进行替换;请参见“备注”部分。)
//
// 参数:
// asyncResult:
// 对未完成的异步 I/O 请求的引用。
//
// 异常:
// T:System.ArgumentNullException:
// asyncResult 为 null。
//
// T:System.ArgumentException:
// 正在等待的写入操作的句柄将不可用。- 或 -挂起的操作不支持写入。
//
// T:System.InvalidOperationException:
// asyncResult 不是源自 System.IO.Stream.BeginWrite(System.Byte[],System.Int32,System.Int32,System.AsyncCallback,System.Object)
// 上当前流的方法。
//
// T:System.IO.IOException:
// 流已关闭或出现了内部错误。
public virtual void EndWrite(IAsyncResult asyncResult);
//
// 摘要:
// 当在派生类中重写时,将清除该流的所有缓冲区,并使得所有缓冲数据被写入到基础设备。
//
// 异常:
// T:System.IO.IOException:
// 出现 I/O 错误。
public abstract void Flush();
//
// 摘要:
// 异步清除此流的所有缓冲区并导致所有缓冲数据都写入基础设备中。
//
// 返回结果:
// 表示异步刷新操作的任务。
//
// 异常:
// T:System.ObjectDisposedException:
// 已释放流。
[ComVisible(false)]
public Task FlushAsync();
//
// 摘要:
// 异步清理这个流的所有缓冲区,并使所有缓冲数据写入基础设备,并且监控取消请求。
//
// 参数:
// cancellationToken:
// 要监视取消请求的标记。 默认值为 System.Threading.CancellationToken.None。
//
// 返回结果:
// 表示异步刷新操作的任务。
//
// 异常:
// T:System.ObjectDisposedException:
// 已释放流。
[ComVisible(false)]
public virtual Task FlushAsync(CancellationToken cancellationToken);
//
// 摘要:
// 当在派生类中重写时,从当前流读取字节序列,并将此流中的位置提升读取的字节数。
//
// 参数:
// buffer:
// 字节数组。 此方法返回时,该缓冲区包含指定的字符数组,该数组的 offset 和 (offset + count -1) 之间的值由从当前源中读取的字节替换。
//
// offset:
// buffer 中的从零开始的字节偏移量,从此处开始存储从当前流中读取的数据。
//
// count:
// 要从当前流中最多读取的字节数。
//
// 返回结果:
// 读入缓冲区中的总字节数。 如果很多字节当前不可用,则总字节数可能小于请求的字节数;如果已到达流结尾,则为零 (0)。
//
// 异常:
// T:System.ArgumentException:
// offset 和 count 的总和大于缓冲区长度。
//
// T:System.ArgumentNullException:
// buffer 为 null。
//
// T:System.ArgumentOutOfRangeException:
// offset 或 count 为负数。
//
// T:System.IO.IOException:
// 出现 I/O 错误。
//
// T:System.NotSupportedException:
// 流不支持读取。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
public abstract int Read(byte[] buffer, int offset, int count);
//
// 摘要:
// 从当前流异步读取字节的序列,将流中的位置提升读取的字节数,并监视取消请求。
//
// 参数:
// buffer:
// 数据写入的缓冲区。
//
// offset:
// buffer 中的字节偏移量,从该偏移量开始写入从流中读取的数据。
//
// count:
// 最多读取的字节数。
//
// cancellationToken:
// 要监视取消请求的标记。 默认值为 System.Threading.CancellationToken.None。
//
// 返回结果:
// 表示异步读取操作的任务。TResult 参数的值包含读入缓冲区的总字节数。 如果当前可用字节数少于所请求的字节数,则该结果值可小于所请求的字节数;如果已到达流结尾时,则为
// 0(零)。
//
// 异常:
// T:System.ArgumentNullException:
// buffer 为 null。
//
// T:System.ArgumentOutOfRangeException:
// offset 或 count 为负数。
//
// T:System.ArgumentException:
// offset 和 count 的总和大于缓冲区长度。
//
// T:System.NotSupportedException:
// 流不支持读取。
//
// T:System.ObjectDisposedException:
// 已释放流。
//
// T:System.InvalidOperationException:
// 之前的读取操作当前正在使用流。
[ComVisible(false)]
public virtual Task<int> ReadAsync(byte[] buffer, int offset, int count, CancellationToken cancellationToken);
//
// 摘要:
// 从当前流异步读取字节序列,并将流中的位置提升读取的字节数。
//
// 参数:
// buffer:
// 数据写入的缓冲区。
//
// offset:
// buffer 中的字节偏移量,从该偏移量开始写入从流中读取的数据。
//
// count:
// 最多读取的字节数。
//
// 返回结果:
// 表示异步读取操作的任务。TResult 参数的值包含读入缓冲区的总字节数。 如果当前可用字节数少于所请求的字节数,则该结果值可小于所请求的字节数;如果已到达流结尾时,则为
// 0(零)。
//
// 异常:
// T:System.ArgumentNullException:
// buffer 为 null。
//
// T:System.ArgumentOutOfRangeException:
// offset 或 count 为负数。
//
// T:System.ArgumentException:
// offset 和 count 的总和大于缓冲区长度。
//
// T:System.NotSupportedException:
// 流不支持读取。
//
// T:System.ObjectDisposedException:
// 已释放流。
//
// T:System.InvalidOperationException:
// 之前的读取操作当前正在使用流。
[ComVisible(false)]
public Task<int> ReadAsync(byte[] buffer, int offset, int count);
//
// 摘要:
// 从流中读取一个字节,并将流内的位置向前提升一个字节,或者如果已到达流结尾,则返回 -1。
//
// 返回结果:
// 强制转换为 Int32 的无符号字节,如果到达流的末尾,则为 -1。
//
// 异常:
// T:System.NotSupportedException:
// 流不支持读取。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
[TargetedPatchingOptOut("Performance critical to inline across NGen image boundaries")]
public virtual int ReadByte();
//
// 摘要:
// 当在派生类中重写时,设置当前流中的位置。
//
// 参数:
// offset:
// 相对于 origin 参数的字节偏移量。
//
// origin:
// System.IO.SeekOrigin 类型的值,指示用于获取新位置的参考点。
//
// 返回结果:
// 当前流中的新位置。
//
// 异常:
// T:System.IO.IOException:
// 出现 I/O 错误。
//
// T:System.NotSupportedException:
// 流不支持查找,例如在流构造从管道或控制台输出的情况下即为如此。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
public abstract long Seek(long offset, SeekOrigin origin);
//
// 摘要:
// 当在派生类中重写时,设置当前流的长度。
//
// 参数:
// value:
// 所需的当前流的长度(以字节表示)。
//
// 异常:
// T:System.IO.IOException:
// 出现 I/O 错误。
//
// T:System.NotSupportedException:
// 流不支持写入和查找,例如在流构造从管道或控制台输出的情况下即为如此。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
public abstract void SetLength(long value);
//
// 摘要:
// 当在派生类中重写时,向当前流中写入字节序列,并将此流中的当前位置提升写入的字节数。
//
// 参数:
// buffer:
// 字节数组。 此方法将 count 个字节从 buffer 复制到当前流。
//
// offset:
// buffer 中的从零开始的字节偏移量,从此处开始将字节复制到当前流。
//
// count:
// 要写入当前流的字节数。
//
// 异常:
// T:System.ArgumentException:
// 总和 offset 和 count 大于缓冲区长度。
//
// T:System.ArgumentNullException:
// buffer 是 null。
//
// T:System.ArgumentOutOfRangeException:
// offset 或 count 为负。
//
// T:System.IO.IOException:
// 将出现 I/O 错误,如找不到指定的文件。
//
// T:System.NotSupportedException:
// 流不支持写入。
//
// T:System.ObjectDisposedException:
// System.IO.Stream.Write(System.Byte[],System.Int32,System.Int32) 是关闭了流之后调用。
public abstract void Write(byte[] buffer, int offset, int count);
//
// 摘要:
// 将字节的序列异步写入当前流,将该流中的当前位置向前移动写入的字节数,并监视取消请求。
//
// 参数:
// buffer:
// 从中写入数据的缓冲区。
//
// offset:
// buffer 中的从零开始的字节偏移量,从此处开始将字节复制到该流。
//
// count:
// 最多写入的字节数。
//
// cancellationToken:
// 要监视取消请求的标记。 默认值为 System.Threading.CancellationToken.None。
//
// 返回结果:
// 表示异步写入操作的任务。
//
// 异常:
// T:System.ArgumentNullException:
// buffer 为 null。
//
// T:System.ArgumentOutOfRangeException:
// offset 或 count 为负数。
//
// T:System.ArgumentException:
// offset 和 count 的总和大于缓冲区长度。
//
// T:System.NotSupportedException:
// 流不支持写入。
//
// T:System.ObjectDisposedException:
// 已释放流。
//
// T:System.InvalidOperationException:
// 流正在由前一次写操作使用。
[ComVisible(false)]
public virtual Task WriteAsync(byte[] buffer, int offset, int count, CancellationToken cancellationToken);
//
// 摘要:
// 将字节序列异步写入当前流,并将流的当前位置提升写入的字节数。
//
// 参数:
// buffer:
// 从中写入数据的缓冲区。
//
// offset:
// buffer 中的从零开始的字节偏移量,从此处开始将字节复制到该流。
//
// count:
// 最多写入的字节数。
//
// 返回结果:
// 表示异步写入操作的任务。
//
// 异常:
// T:System.ArgumentNullException:
// buffer 为 null。
//
// T:System.ArgumentOutOfRangeException:
// offset 或 count 为负数。
//
// T:System.ArgumentException:
// offset 和 count 的总和大于缓冲区长度。
//
// T:System.NotSupportedException:
// 流不支持写入。
//
// T:System.ObjectDisposedException:
// 已释放流。
//
// T:System.InvalidOperationException:
// 流正在由前一次写操作使用。
[ComVisible(false)]
public Task WriteAsync(byte[] buffer, int offset, int count);
//
// 摘要:
// 将一个字节写入流内的当前位置,并将流内的位置向前提升一个字节。
//
// 参数:
// value:
// 要写入流中的字节。
//
// 异常:
// T:System.IO.IOException:
// 出现 I/O 错误。
//
// T:System.NotSupportedException:
// 流不支持写入,或该流已关闭。
//
// T:System.ObjectDisposedException:
// 在流关闭后调用方法。
public virtual void WriteByte(byte value);
//
// 摘要:
// 分配 System.Threading.WaitHandle 对象。
//
// 返回结果:
// 对已分配的 WaitHandle 的引用。
[Obsolete("CreateWaitHandle will be removed eventually. Please use \"new ManualResetEvent(false)\" instead.")]
protected virtual WaitHandle CreateWaitHandle();
//
// 摘要:
// 释放由 System.IO.Stream 占用的非托管资源,还可以另外再释放托管资源。
//
// 参数:
// disposing:
// 若要释放托管资源和非托管资源,则为 true;若仅释放非托管资源,则为 false。
protected virtual void Dispose(bool disposing);
//
// 摘要:
// 提供对 System.Diagnostics.Contracts.Contract 的支持。
[Obsolete("Do not call or override this method.")]
protected virtual void ObjectInvariant();
}
}
2、
2.返回顶部
 
3.返回顶部
 
4.返回顶部
 
5.返回顶部
 
 
6.返回顶部
 
作者:ylbtech
出处:http://ylbtech.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

.NETFramework:Stream的更多相关文章

  1. Java 8 vs. Scala(二):Stream vs. Collection

    [编者按]在之前文章中,我们介绍了 Java 8和Scala的Lambda表达式对比.在本文,将进行 Hussachai Puripunpinyo Java 和 Scala 对比三部曲的第二部分,主要 ...

  2. C# 温故而知新:Stream篇(—)

    C# 温故而知新:Stream篇(—) 目录: 什么是Stream? 什么是字节序列? Stream的构造函数 Stream的重要属性及方法 Stream的示例 Stream异步读写 Stream 和 ...

  3. Akka(25): Stream:对接外部系统-Integration

    在现实应用中akka-stream往往需要集成其它的外部系统形成完整的应用.这些外部系统可能是akka系列系统或者其它类型的系统.所以,akka-stream必须提供一些函数和方法来实现与各种不同类型 ...

  4. FunDA(4)- 数据流内容控制:Stream data element control

    上节我们探讨了通过scalaz-stream-fs2来驱动一套数据处理流程,用fs2的Pipe类型来实现对数据流的逐行操作.本篇讨论准备在上节讨论的基础上对数据流的流动和元素操作进行优化完善.如数据流 ...

  5. Java8初体验(2):Stream语法详解

    原文出处: 一冰_天锦 上篇文章Java8初体验(1):lambda表达式语法比较详细的介绍了lambda表达式的方方面面,细心的读者会发现那篇文章的例子中有很多Stream的例子.这些Stream的 ...

  6. Java提升四:Stream流

    1.Stream流的定义 Stream是Java中的一个接口.它的作用类似于迭代器,但其功能比迭代器强大,主要用于对数组和集合的操作. Stream中的流式思想:每一步只操作,不存储. 2.Strea ...

  7. 恕我直言你可能真的不会java第6篇:Stream性能差?不要人云亦云

    一.粉丝的反馈 问:stream比for循环慢5倍,用这个是为了啥? 答:互联网是一个新闻泛滥的时代,三人成虎,以假乱真的事情时候发生.作为一个技术开发者,要自己去动手去做,不要人云亦云. 的确,这位 ...

  8. Java 8新特性(二):Stream API

    本篇文章继续介绍Java 8的另一个新特性--Stream API.新增的Stream API与InputStream和OutputStream是完全不同的概念,Stream API是对Java中集合 ...

  9. .NETFramework:WebClient

    ylbtech-.NETFramework:WebClient 1.程序集 System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5 ...

随机推荐

  1. 果皇的矩阵[matrix]

    #1101. 果皇的矩阵[matrix] 题目描述 输入格式 一行两个数,表示 N,M. 输出格式 一行一个数,表示答案对 10^9+7 取模后的结果 样例 样例输入 3 3 样例输出 38 数据范围 ...

  2. AbstractQueuedSynchronizer 队列同步器源码分析

    AbstractQueuedSynchronizer 队列同步器(AQS) 队列同步器 (AQS), 是用来构建锁或其他同步组件的基础框架,它通过使用 int 变量表示同步状态,通过内置的 FIFO ...

  3. C#代码调用页面javascript函数

    C#代码调用javascript函数   前台<%@ Page Language="C#" AutoEventWireup="true" CodeFile ...

  4. 怎样高速地安装Ubuntu SDK

    我在先前的文章"Ubuntu SDK 安装"中已经具体地介绍了怎样安装Ubuntu SDK.可是非常多的开发人员可能在最后安装SDK所须要的chroots时候会失败.这里面的原因是SDK在安装chro ...

  5. [转]gzip,bzip2,tar,zip命令使用方法详解

    原文:http://blog.chinaunix.net/uid-20779720-id-2547669.html 1 gzipgzip(1) 是GNU的压缩程序.它只对单个文件进行压缩.基本用法如下 ...

  6. 第04章-VTK基础(3)

    [译者:这个系列教程是以Kitware公司出版的<VTK User's Guide -11th edition>一书作的中文翻译(出版时间2010年,ISBN: 978-1-930934- ...

  7. yii使用CUploadedFile上传文件

    一.前端代码 Html代码   <form action="<?php echo $this->createUrl('/upload/default/upload/');? ...

  8. MongoDB:分片(简介 & 自动分片 & 片键)

    分片(增加服务器,水平扩展)是MongoDB的扩展方式,通过分片能过增加更多的机器来应对不断增加的负载和数据,还不影响应用. [简介] 分片(sharding)是指将数据拆分,将其分散存在不同的机器上 ...

  9. JAVA 保留两位小数

    package com.oracle.pojo; import java.math.BigDecimal; import java.text.DecimalFormat; import java.te ...

  10. 下载Google官方/CM Android源码自己主动又一次開始的Shell脚本

    国内因为某种原因,下载CM或Google官方的Android源码总easy中断.总看着机器.一中断就又一次运行repo sync还太麻烦,所以我特意编写了一段shell脚本(download.sh). ...