测试机:笔记本i7 8G 固态硬盘

由于采取读码写入txt方式, 读码频率挺高,文件名为日期格式,当前采用每次读码打开文件写入的方式, 为什么没用sb,因为怕断电情况的数据丢失.所以采取每条存入的方式.

今天想对代码进行优化,采取文件流一直打开,不用每次打开关闭的情况,对效率进行测试.

1:新建项目 writetxt

2:添加时钟事件,定时写txt.

3:加两个写入方式

4:分别计时.查看效率.

   static object obj = new object();
public static void WriteSvnLog(string result)
{
lock (obj)
{
Stopwatch sw1 = new Stopwatch();
sw1.Start();
string time = DateTime.Now.ToLongTimeString();
string path = Application.StartupPath + "\\upload\\";
if (!Directory.Exists(path))
Directory.CreateDirectory(path);
path = path + "\\logSvn" + DateTime.Now.ToString("yyyyMMdd") + ".txt";
if (!File.Exists(path))
File.Create(path).Close();
//FileStream fileStream = new FileStream(path, System.IO.FileMode.Append, System.IO.FileAccess.Write);
//System.IO.StreamWriter sw = new System.IO.StreamWriter(fileStream, Encoding.Default);
FileStream fs = new FileStream(path, FileMode.Append, FileAccess.Write);
StreamWriter sw = new StreamWriter(fs, Encoding.Default);
sw.WriteLine(result + " " + time);
sw.Close();
sw.Dispose();
fs.Close();
fs.Dispose();
sw1.Stop();
Debug.WriteLine(" 用时ms:" + sw1.Elapsed.TotalMilliseconds);
}
}
结果:
用时ms:2.4102
用时ms:2.8373
用时ms:2.987
用时ms:2.8673
用时ms:3.0787
用时ms:3.4216
用时ms:2.558
用时ms:2.6216
用时ms:2.5094
用时ms:2.4726

打开文件大小216k

测试2:打开30M的文件测试时间:

用时ms:11.0885
用时ms:2.5825
用时ms:2.5461
用时ms:2.6026
用时ms:6.1945
用时ms:2.5809
用时ms:3.247
用时ms:5.4372
用时ms:2.4047
用时ms:2.5754
用时ms:2.5532
用时ms:2.4252
用时ms:3.2643
用时ms:2.3798
用时ms:2.5797
用时ms:2.6018
用时ms:3.1233
用时ms:5.5288
用时ms:2.9044
用时ms:2.0491
用时ms:2.7034
用时ms:5.2598
用时ms:2.2486

中间有大值出现.此时计算机未饱和状态,总体值变化不大.

继续观察,有波动.

换20ms

用时ms:2.3521
用时ms:3.0119
用时ms:2.5323
用时ms:3.2632
用时ms:2.5801
用时ms:2.4971
用时ms:2.7784
用时ms:3.0281
用时ms:2.351
用时ms:2.6322
用时ms:3.0763
用时ms:2.1234
用时ms:2.569
用时ms:2.4023
用时ms:2.6595

测试三,改程序,换intel双核3.0 4G内存,机械硬盘pc机测试 老机器

因为远程机没有vs环境,用时输出到txt中

1:先在本机测试

2:远程机:

哎呀,配置低机器竟然写入速度还快, 笔记本还是固态硬盘,难道win10的固态硬盘写的慢? 问群里大牛说法.具体也不去看究竟了主要在于测试

测试四:同时写20个txt.测试

这里边碰到局部变量回收的问题

定于局部变量的时钟,运行一次就结束了.定义在外边就可以一直运行. 上边的循环中每次循环执行一次timer 执行完之后,重新赋值,原先的失效.也矫正了以前理解上的误区
在以前list<类>,list.add()之后尽管对象名一样.list内还是跟分开,导致产生了误区,
在此我写了student类作为测试
第一次

student 对象在button 外定义.全局变量

结果stulist 的值列表 是十个

放在button里边

.

结果每次循环,表里边还是一个值,说明每次new 分配了一个新的列表对象,原先的被释放掉了

如下图,

那继续 list 对象放在外边,不new  对象,结果 也是如此 ,充分说明,每次new 之后产生新的地址,分配新的堆存储空间

C#做一个写txt文件流的测试,为什么配置低的机器写入的还快的更多相关文章

  1. C++文件处理(一):读/写txt文件

    C++文件处理与C语言不同,C++文件处理使用的是:流(stream) C++头文件fstream定义了三个类型来支持文件IO

  2. 【学习总结】GirlsInAI ML-diary day-15-读/写txt文件

    [学习总结]GirlsInAI ML-diary 总 原博github链接-day15 认识读/写txt文件 路径: 绝对路径:文件在电脑中的位置 相对路径:下面会用到 1-准备 新建一个 pytho ...

  3. 使用 jquery 的 上传文件插件 uploadify 3.1 配合 java 来做一个简单的文件上次功能。并且在界面上有radio 的选择内容也要上传

    使用 jquery 的 上传文件插件 uploadify 3.1 配合 java 来做一个简单的文件上次功能.并且在界面上有radio 的选择内容也要上传 uploadify 插件的 下载和文档地址  ...

  4. 小白也能看懂的Redis教学基础篇——做一个时间窗限流就是这么简单

    不知道ZSet(有序集合)的看官们,可以翻阅我的上一篇文章: 小白也能看懂的REDIS教学基础篇--朋友面试被SKIPLIST跳跃表拦住了 书接上回,话说我朋友小A童鞋,终于面世通过加入了一家公司.这 ...

  5. .Net写txt文件-简单的记录执行日志信息代码

    在执行一些批量操作时,想记录一些执行日志信息,越简单方便越好啊.提供一个常用的简单方法,将信息记录在txt文件里: public static void log(string content, str ...

  6. matlab写txt文件

    fd=fopen('C:\Users\Qin\Desktop\1112.txt','w');for i=16:19 for j=1:5 fprintf(fd,'%f,%f\r\n',[cluster( ...

  7. C# 文件流FileStream 实现多媒体文件复制 StreamReader StreamWriter 读取写入文本

    #region 实现多媒体文件的复制 string source = @"F:\123\source.avi";//源文件路径 string target = @"F:\ ...

  8. 写TXT文件

    #region 写日志 private static void writelog(string strwrite) { string strPath = "d:/log.txt"; ...

  9. python写txt文件

    with open('data.txt','w') as f: #设置文件对象 w是重新写,原来的会被抹掉,a+是在原来的基础上写 str0=u"写文件\n" #写中文要在字符串签 ...

随机推荐

  1. RxJava2.0学习笔记1 2018年3月23日 星期五

    参考博文:给初学者的RxJava2.0教程-简书     源码 :https://github.com/ssseasonnn/RxJava2Demo 1 若是发送多个onError, 则收到第二个on ...

  2. 19.JDBC和数据库访问.md

    1.基本功能: Java通过JDBC完成: 2.基本类型,通常用最后一种 3.JDBC简介 Java连接SQL例子: 参考:http://blog.chinaunix.net/uid-20726500 ...

  3. 解决运行wamp提示“MSVCR110.dll”丢失的问题!

    我在Windows系统上安装wampserver2.5 64位,安装到最后,总是提示丢失msvcr110.dll 解决办法: 到这个网站下载一个Visual C++ Redistributable f ...

  4. KJMusic完整音乐项目

    KJMusic完整音乐项目 KJMusic是一个完整音乐项目,这个项目从欢迎页面到首页以及音乐播放页面都做得非常不错.并且本音乐支持本地音乐,和音乐电台,支持切换上下首个.本项目还支持侧滑出现menu ...

  5. Generative Adversarial Networks,gan论文的畅想

    前天看完Generative Adversarial Networks的论文,不知道有什么用处,总想着机器生成的数据会有机器的局限性,所以百度看了一些别人 的看法和观点,可能我是机器学习小白吧,看完之 ...

  6. 初识C语言中的函数(男神翁凯老师MOOC)

    什么是函数? 函数是一块代码,接收零个或多个参数,做一件事情,并返回零个或一个值. 可以先想象成数学中的函数: y=f(x) 例如 求begin到end和的函数定义 void sum(int begi ...

  7. polyfill

    [polyfill] 在JavaScript的世界里,有两个词经常被提到,shim和polyfill.它们指的都是什么,又有什么区别? 一个shim是一个库,它将一个新的API引入到一个旧的环境中,而 ...

  8. STL:unordered_set/unordered_multiset(c++11)

    unordered_set:容器内的元素无序排列,基于值进行获取单个元素速度非常快.内部根据它们的 hash value 被组织成 buckets(slot). unordered_multiset: ...

  9. 一:怎样运行python程序

    运行python程序有三种方法: 1,在命令行运行python代码:C:/python27>python hello.py   [注:如果没有把PATH环境变量设置为包含这一路径,要确保输入到了 ...

  10. 关于CDh5.13.1 HDFS启用HA(High Availability)注意事情--(JournalNode 只有一个编辑路径)

    原因为:主机名不能为域名.更换成hadoop64 这种解决.