C#要点补充
1字符串与时间的互转
DateTime.TryParse将空字符串、为null或格式不正确,则转换为的DateTime所代表的值为:0001/1/1 0:00:00,此为DateTime.MinValue的值。
使用public static DateTime ParseExact(string s, string format, IFormatProvider provider);实例方法转换时间,可以指定转换的格式。其中format为输入字符s的格式。若指定的格式与输入字符格式不一样,会抛异常
例如:
//dateTime ="2017-11-18 17:25:53";会抛异常,这种类型对应格式为:yyyy-MM-dd HH:mm:ss
string dateTime = "20171118172553";
IFormatProvider yyyymmddFormat = new CultureInfo(String.Empty, false);
DateTime time = DateTime.ParseExact(dateTime, "yyyyMMddHHmmss", yyyymmddFormat);
2比较时间先后
使用DateTime的public int CompareTo(DateTime value);实例方法。
示例:
string dateTime = "2017-11-28 12:57:30";
DateTime dt;
DateTime.TryParse(dateTime, out dt);
int cr = dt.CompareTo(DateTime.Now);
如果cr大于0,dt时间晚于(当前时间)DateTime.Now,即时间的整数值大于DateTime.Now的整数值。
如果cr等于0,dt时间等于(当前时间)DateTime.Now,即时间的整数值等于DateTime.Now的整数值。
如果cr小于0,dt时间早于(当前时间)DateTime.Now,即时间的整数值小于DateTime.Now的整数值。
3 StreamWriter
将文件所在的目录传给StreamWriter的构造函数,而不是传递文件的全路径,那么会抛出如下的异常,看上去似乎是对文件目录没有访问权限,其实是错将文件目录传递给了StreamWriter构造函数。

4将Sream中的数据写入文件
错误的做法一:
获取流的长度然后转型为int,容易造成数据截断,导致未能读取流的全部内容。
//读取
long length = ;
using (Stream fs = new FileStream("D:\\命令行安装MySQL.docx", FileMode.Open))
{
length = fs.Length;
}
byte[] bytes = new byte[length]; using (Stream fs = new FileStream("D:\\命令行安装MySQL.docx", FileMode.Open))
{
int countIn = fs.Read(bytes, , (int)length);
}
//写入
using (Stream fs = new FileStream("D:\\命令行安装MySQLnew.docx", FileMode.OpenOrCreate))
{
fs.Write(bytes, , (int)length);
}
错误做法二:
貌似不会发生错误类型一那样的情况,但还是会出现数据截断的现象。调用FileStream的Read实例方法:Read(byte[] buffer, int offset, int count),offset这个参数的类型是int型,这里将numBytesRead 转型为int,一旦这个偏移量超过这个值,那么读取的数据有一部分就是重复的。
/读取
using (Stream fs = new FileStream("D:\\命令行安装MySQL.docx", FileMode.Open))
{
int c = ;
long numBytesRead = ;
long numBytesToRead = fs.Length;
while (numBytesToRead>)
{
if (fs.Length - numBytesRead <= c)
{
c = (int)(fs.Length - numBytesRead);
}
int n = fs.Read(bytes, (int)numBytesRead, c);
numBytesRead += n;
numBytesToRead -= n;
}
}
//写入
using (Stream fs = new FileStream("D:\\命令行安装MySQLnew.docx", FileMode.OpenOrCreate))
{
fs.Write(bytes, , (int)length);
}
正确的做法一:
确保上述错误做法中的源数据长度不超过int32的最大值。此外也可使用下面的方法,但同样要保证源数据长度不超过int32的最大值:
//读取
using (Stream fs = new FileStream("D:\\命令行安装MySQL.docx", FileMode.Open))
{
int c = ;
long position = ;
while (true)
{
position = fs.Seek(position, SeekOrigin.Begin);
if (position == fs.Length)
{
break;
} if (position + c > fs.Length)
{
c = (int)(fs.Length - position);
}
int n = fs.Read(bytes, (int)position, c);
position += n;
}
}
//写入
using (Stream fs = new FileStream("D:\\命令行安装MySQLnew.docx", FileMode.OpenOrCreate))
{
fs.Write(bytes, , (int)length);
}
正确的做法二:
使用CopyTo(Stream destination)
CopyTo(Stream destination, int bufferSize)
使用第一个方法默认缓冲区大小为4096,现在看下源码片段:
public void CopyTo(Stream destination)
{
...... InternalCopyTo(destination, _DefaultCopyBufferSize);
}
CopyTo方法中调用了InternalCopyTo方法,来看下InternalCopyTo方法的源码片段:
private void InternalCopyTo(Stream destination, int bufferSize)
{
...... byte[] buffer = new byte[bufferSize];
int read;
while ((read = Read(buffer, , buffer.Length)) != )
destination.Write(buffer, , read);
}
InternalCopyTo方法内部调用了Read方法,下面来看一下Read方法源码片段:
然而在Stream这个类中并没有Read方法的具体实现,只有一个抽象方法:
public abstract int Read([In, Out] byte[] buffer, int offset, int count);
到这里已经可以看出CopyTo方法中的参数bufferSize的作用了,即设置内存缓冲区的大小,每次从流中读取长度为bufferSize的数据,放入缓冲区,然后写入目标流,重复这个过程直到所有的流都拷贝完成。那么在内存允许的范围内,bufferSize设置的越大效率越高。
using (Stream fs = new FileStream("D:\\命令行安装MySQL.docx", FileMode.Open))
{
using(Stream fss = new FileStream("D:\\命令行安装MySQLnew.docx", FileMode.OpenOrCreate))
{
fs.CopyTo(fss);
}
}
5文件读写效率与对象频繁开关的影响
写文件方式一:
public static void W()
{
for (int i = ; i < ;i++ )
{
string s = "sdfrgyjefgyhjdsfdfgfghgew"+i;
using (StreamWriter sw = new StreamWriter(@"D:\g.txt", true))
{
sw.Write(s);
}
}
}
方式二:
public static void WT()
{
using (StreamWriter sw = new StreamWriter(@"D:\gT.txt", true))
{
for (int i = ; i < ; i++)
{
string s = "sdfrgyjefgyhjdsfdfgfghgew" + i;
sw.Write(s);
}
}
}
分析:
方式一每写一次文件,开关一次StreamWriter对象,而方式二将所有的字符串都写入文件后才关闭StreamWriter实例。统计数据如下:
|
循环次数 |
方式一 |
方式二 |
|
100万 |
21861ms |
260ms |
|
1000 |
231ms |
13ms |
C#要点补充的更多相关文章
- [.NET] 《Effective C#》快速笔记 - C# 高效编程要点补充
<Effective C#>快速笔记 - C# 高效编程要点补充 目录 四十五.尽量减少装箱拆箱 四十六.为应用程序创建专门的异常类 四十七.使用强异常安全保证 四十八.尽量使用安全的代码 ...
- 《Effective C#》快速笔记(六)- - C# 高效编程要点补充
目录 四十五.尽量减少装箱拆箱 四十六.为应用程序创建专门的异常类 四十七.使用强异常安全保证 四十八.尽量使用安全的代码 四十九.实现与 CLS 兼容的程序集 五十.实现小尺寸.高内聚的程序集 这是 ...
- CSS几个要点补充
css的font-size属性一定要带px单位,font-weight:700[千万不要带单位哦]就等于font-weight:bold加粗 1.如何像淘宝页面一样,随着浏览器的减小而保持内容区大小不 ...
- [.NET] 《C# 高效编程》(一) - C# 语言习惯
C# 语言习惯 目录 一.使用属性而不是可访问的数据成员 二.使用运行时常量(readonly)而不是编译时常量(const) 三.推荐使用 is 或 as 操作符而不是强制类型转换 四.使用 Con ...
- [.NET] 《Effective C#》读书笔记(二)- .NET 资源托管
<Effective C#>读书笔记(二)- .NET 资源托管 简介 续 <Effective C#>读书笔记(一)- C# 语言习惯. .NET 中,GC 会帮助我们管理内 ...
- [.NET] 《Effective C#》快速笔记(四)- 使用框架
<Effective C#>快速笔记(四)- 使用框架 .NET 是一个类库,你了解的越多,自己需要编写的代码就越少. 目录 三十.使用重写而不是事件处理函数 三十一.使用 ICompar ...
- [.NET] 《Effective C#》快速笔记 - C# 中的动态编程
<Effective C#>快速笔记 - C# 中的动态编程 静态类型和动态类型各有所长,静态类型能够让编译器帮你找出更多的错误,因为编译器能够在编译时进行大部分的检查工作.C# 是一种静 ...
- 【机器学习实战】第7章 集成方法 ensemble method
第7章 集成方法 ensemble method 集成方法: ensemble method(元算法: meta algorithm) 概述 概念:是对其他算法进行组合的一种形式. 通俗来说: 当做重 ...
- 【机器学习实战】第13章 利用 PCA 来简化数据
第13章 利用 PCA 来简化数据 降维技术 场景 我们正通过电视观看体育比赛,在电视的显示器上有一个球. 显示器大概包含了100万像素点,而球则可能是由较少的像素点组成,例如说一千个像素点. 人们实 ...
随机推荐
- python字典的操作
思维导图如下 1.字典的增加 dic1={'name':'wujie','age':18,'gender':'男'} dic1['profession']='python全栈' dic1.setdef ...
- 在jQuery中使用canvas时遇到的问题
正常的情况下一般在JavaScript中使用canvas,会用到如下代码: var canvas=document.getElementById("canvas"); var co ...
- ABP .Net Core API和Angular前端APP集成部署
前言:在ABP官网(https://aspnetboilerplate.com)生成的.Net Core + Angular项目前后端是两个独立的项目,我们可以分开部署,也可以将前端和Web API一 ...
- 关于C++函数返回局部对象的详细分析
以前一直挺好奇的,C++是怎么在函数内返回一个局部对象的.因为按照我之前的想法,函数返回一个基本类型的值是通过存放到ecx实现的(关于浮点不了解),但是局部对象又是比较大的,很明显不能使用寄存器作为通 ...
- UVALive 4850 Installations
题目大意:有若干个任务,每个任务耗时si,期限为di,同一时间只能做一个任务.对于一个任务,惩罚值为max(0,完成时间-期限).问怎么安排,使(最大惩罚值+次大惩罚值)最小,O(n^2). 如果没有 ...
- Python:监控ASM剩余空间
#!/usr/bin/env python # -*- coding:utf-8 -*- __author__ = 'Jipu FANG' version = 0.1 import cx_Oracle ...
- 小白的Python之路 day4 软件目录结构规范
软件目录结构规范 为什么要设计好目录结构? "设计项目目录结构",就和"代码编码风格"一样,属于个人风格问题.对于这种风格上的规范,一直都存在两种态度: 一类同 ...
- oracle里的优化器
1.1 oracle里的优化器 RBO(Rule-Based-Optinizer):基于规则的优化器 CBO(Cost-Based-Optinizer): 基于成本的优化器 SQL语句执行过程 待执行 ...
- java inputstream to string stack overflow
https://stackoverflow.com/questions/309424/read-convert-an-inputstream-to-a-string 过千赞的答案
- 第一本的java 的小总结
1.Java常见的注释有哪些,语法是怎样的? 1)单行注释用//表示,编译器看到//会忽略该行//后的所文本 2)多行注释/* */表示,编译器看到/*时会搜索接下来的*/,忽略掉/* */之间的文 ...