LogClass.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Diagnostics;
  4. using System.IO;
  5. using System.Linq;
  6. using System.Runtime.InteropServices;
  7. using System.Text;
  8. using System.Threading.Tasks;
  9. namespace LogClass
  10. {
  11. public class LOG
  12. {
  13. static public StringBuilder _log = new StringBuilder();
  14. static FileIO fio;
  15. static public int min = 0;
  16. static public int max = 10;
  17. //
  18. static LOG()
  19. {
  20. fio = new FileIO();
  21. fio.OpenWriteFile("log.txt");
  22. }
  23. static public void error(object str)
  24. {
  25. log("Erorr:" + str, 10);
  26. }
  27. //static object syn = new object();
  28. /// <summary>
  29. /// log写入
  30. /// </summary>
  31. /// <param name="str"></param>
  32. static public void log(object str)
  33. {
  34. log(str, 0);
  35. }
  36. static public void log(string str)
  37. {
  38. log(str, 0);
  39. }
  40. /// <summary>
  41. /// log等级定制
  42. /// </summary>
  43. /// <param name="p"></param>
  44. /// <param name="level"></param>
  45. public static void log(object p, int level)
  46. {
  47. log(p.ToString(), level);
  48. }
  49. static public void log(string str, int level)
  50. {
  51. if(level < fio.LogLevel)
  52. {
  53. return;
  54. }
  55. if (str == null)
  56. {
  57. str = "null";
  58. }
  59. fio.WriteLine(DateTime.Now.ToLocalTime() + "->" + str + "\r\n");
  60. }
  61. /// <summary>
  62. /// 修改Log的限制等级0日志最多,10最少
  63. /// </summary>
  64. /// <param name="Loglevel"></param>
  65. public static void ChangeLogLevel(int Loglevel)
  66. {
  67. fio.LogLevel = Loglevel;
  68. }
  69. public static void LogSurPlusMemory()
  70. {
  71. PerformanceCounter ramCounter = new PerformanceCounter("Memory", "Available MBytes");
  72. var ramAvailable = ramCounter.NextValue();
  73. string ramAvaiableStr = string.Format("{0} MB", ramAvailable);
  74. log($"剩余物理内存:{ramAvaiableStr}");
  75. }
  76. }
  77. public class FileIO
  78. {
  79. private FileStream fsr;
  80. private FileStream fsw;
  81. private StreamWriter sw;
  82. private StreamReader sr;
  83. private string LogFloderPath = AppDomain.CurrentDomain.SetupInformation.ApplicationBase + "Log\\";
  84. private double LogFileSize =128 * Math.Pow(1024, 3);
  85. public int LogLevel = 0;
  86. // 创建用于读取文件行的文件流和StreamWriter对象
  87. public void OpenReadFile(string file)
  88. {
  89. if (!File.Exists(file))
  90. File.Create(file).Close();
  91. fsr = new FileStream(file, FileMode.OpenOrCreate, FileAccess.Read, FileShare.ReadWrite);
  92. sr = new StreamReader(fsr);
  93. }
  94. public void Clear()
  95. {
  96. CloseWriteFile();
  97. }
  98. // 关闭读文件流
  99. public void CloseReadFile()
  100. {
  101. if (fsr != null)
  102. fsr.Close();
  103. }
  104. // 创建用于向文件中追加行的文件流和StreamWriter对象
  105. public void OpenWriteFile(string file)
  106. {
  107. int i = 1;
  108. while(true)
  109. {
  110. if (!Directory.Exists(LogFloderPath))//如果不存在就创建file文件夹
  111. {
  112. Directory.CreateDirectory(LogFloderPath);
  113. }
  114. if (!File.Exists(LogFloderPath + file)) // 如果文件不存在,先创建这个文件
  115. File.Create(LogFloderPath + file).Close();
  116. // 以追加模式打开这个文件
  117. fsw = new FileStream(LogFloderPath + file, FileMode.Append, FileAccess.Write, FileShare.ReadWrite);
  118. if (fsw.Length > LogFileSize)
  119. {
  120. file = "log"+ i + ".txt";
  121. i++ ;
  122. continue;
  123. }
  124. break;
  125. }
  126. // 根据创建的FileStream对象来创建StreamWriter对象
  127. sw = new StreamWriter(fsw);
  128. }
  129. // 关闭写文件流
  130. public void CloseWriteFile()
  131. {
  132. if (fsw != null)
  133. fsw.Close();
  134. }
  135. // 从文件中读取一行
  136. public string ReadLine()
  137. {
  138. if (sr.EndOfStream) // 如果文件流指针已经指向文件尾部,返回null
  139. return null;
  140. return sr.ReadLine();
  141. }
  142. // 向文件中追加一行字符串
  143. public void WriteLine(string s)
  144. {
  145. if(fsw.Length > LogFileSize)
  146. {
  147. OpenWriteFile("log.txt");
  148. }
  149. lock (sw)
  150. {
  151. sw.WriteLine(s);
  152. sw.Flush(); // 刷新写入缓冲区,使这一行对于读文件流可见
  153. }
  154. }
  155. // 用于判断文件流指针是否位于文件尾部
  156. public bool IsEof()
  157. {
  158. return sr.EndOfStream;
  159. }
  160. }
  161. }