0

我的服务从 com 端口读取并将信息保存在数据库中。它可以正常工作一段时间,但有时会出现错误窗口以获取异常,如果我不单击“no”按钮,它不会读取来自 com 端口。当我签入事件查看器时,我在我的服务上看到一些异常编号 7034,7031。我在代码中记录每个位置并使用 try,catch。我的日志文件中没有 ant catch,所以我不明白有什么问题?

public partial class Service1 : ServiceBase
{
    string _fileName = @"c:\logSensor\log.ini";
    internal delegate void StringDelegate(string data);
    ArrayList lines = new ArrayList();
    BL.EnterDatas eData = new BL.EnterDatas();
    private class Line
    {
        public string Str;

        public Line(string str)
        {
            Str = str;
        }
    }

    public Service1()
    {
        InitializeComponent();
CommPort com = CommPort.Instance;
        com.Open();
        com.StatusChanged += OnStatusChanged;
        com.DataReceived += OnDataReceived;
        timer1.Enabled = true;
        using (System.IO.StreamWriter writer = new System.IO.StreamWriter(_fileName, true))
        {
            writer.WriteLine(PublicVariable.DateShamsi() + "  " + PublicVariable.Nowtime() +
            " . " + "Step1:Load ");
            writer.Flush();
        }
    }

    protected override void OnStart(string[] args)
    {

    }

    protected override void OnStop()
    {
    }

    private void timer1_Elapsed(object sender, System.Timers.ElapsedEventArgs e)
    {
        try
        {
            timer1.Stop();
            using (System.IO.StreamWriter writer = new System.IO.StreamWriter(_fileName, true))
            {
                writer.WriteLine(PublicVariable.DateShamsi() + "  " + PublicVariable.Nowtime() + "timer1_Elapsed:Stop Timer ");
                writer.Flush();
            }
            ReadLog();
            StreamReader sr = new StreamReader(Path.GetDirectoryName(System.Reflection.Assembly.GetEntryAssembly().Location) + "\\path.txt");
            string _logPath = sr.ReadLine();
            FileStream fs = new FileStream(_logPath, FileMode.Open);
            fs.SetLength(0);
            fs.Close();
        }
        catch (Exception ex)
        {
            using (System.IO.StreamWriter writer = new System.IO.StreamWriter(_fileName, true))
            {
                writer.WriteLine(PublicVariable.DateShamsi() + "  " + PublicVariable.Nowtime() + "Catch:timer1_Elapsed " + ex.Message);
                writer.Flush();
            }
        }

        using (System.IO.StreamWriter writer = new System.IO.StreamWriter(_fileName, true))
        {
            writer.WriteLine(PublicVariable.DateShamsi() + "  " + PublicVariable.Nowtime() + "final:timer1_Elapsed ");
            writer.Flush();
        }

        timer1.Start();
    }

    #region Functions...

... }

4

0 回答 0