黄学彪
2019-10-10 2ed75b8b337048e5d75e6d9ec8307633134f02fd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
using System;
using System.Collections.Generic;
using System.Text;
 
namespace Shared.Phone.UserCenter
{
    /// <summary>
    /// 线程逻辑(创建这个东西,是为了Log出力)
    /// </summary>
    public class HdlThreadLogic
    {
        #region ■ 变量声明___________________________
 
        /// <summary>
        /// 线程逻辑(创建这个东西,是为了Log出力)
        /// </summary>
        private static HdlThreadLogic m_Current = null;
        /// <summary>
        /// 线程逻辑(创建这个东西,是为了Log出力)
        /// </summary>
        public static HdlThreadLogic Current
        {
            get
            {
                if (m_Current == null)
                {
                    m_Current = new HdlThreadLogic();
                }
                return m_Current;
            }
        }
        #endregion
 
        #region ■ 线程执行___________________________
 
        /// <summary>
        /// 子线程执行(创建这个东西,是为了Log出力)
        /// </summary>
        public void RunThread(Action action)
        {
            new System.Threading.Thread(() =>
            {
                //记录起当前界面,虽然似乎没啥用
                string nowFormId = UserCenterResourse.NowActionFormID;
                try
                {
                    action.Invoke();
                    action = null;
                }
                catch (Exception ex)
                {
                    Application.RunOnMainThread(() =>
                    {
                        //出现未知错误,数据丢失
                        var alert = new ShowMsgControl(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uUnknownErrorAndDataLost));
                        alert.Show();
                    });
                    //Log出力
                    string msg = "当前激活的界面[" + nowFormId + "]\r\n";
                    msg += ex.Message + "\r\n";
                    msg += ex.TargetSite.ToString();
                    HdlLogLogic.Current.WriteLog(-1, msg);
                }
            })
            { IsBackground = true }.Start();
        }
 
        /// <summary>
        /// 执行运行子线程里面的主线程(创建这个东西,是为了Log出力)
        /// </summary>
        public void RunMainInThread(Action action)
        {
            new System.Threading.Thread(() =>
            {
                Application.RunOnMainThread(() =>
                {
                    //记录起当前界面,虽然似乎没啥用
                    string nowFormId = UserCenterResourse.NowActionFormID;
                    try
                    {
                        action.Invoke();
                        action = null;
                    }
                    catch (Exception ex)
                    {
                        //出现未知错误,数据丢失
                        var alert = new ShowMsgControl(ShowMsgType.Error, Language.StringByID(R.MyInternationalizationString.uUnknownErrorAndDataLost));
                        alert.Show();
                        //Log出力
                        string msg = "当前激活的界面[" + nowFormId + "]\r\n";
                        msg += ex.Message + "\r\n";
                        msg += ex.TargetSite.ToString();
                        HdlLogLogic.Current.WriteLog(-1, msg);
                    }
                });
                
            })
            { IsBackground = true }.Start();
        }
 
        #endregion
    }
}