0

私は DDE クライアントを使用して、株式市場価格をアタッチしてリッスンしています。そのクライアントには、価格の変更を受け取ったときに何をすべきかを実装したコールバック メソッドがあります。問題は、StackOverflowException が発生することです (定期的であり、同じ時間間隔ではありません)。Thread.BeginCriticalRegion() について何かを見つけましたが、それが役立つかどうかはわかりません。テストできるのは、市場が開くまであと数時間です。誰かがこの例外をオーバーライドする方法を教えてくれたら、とてもうれしいです。

前もってありがとう、アレクサンダー

IList<SymbolObject> _symbols; //initialized when the app runs for the first time

void _ddeClient_Advise(object sender, DdeAdviseEventArgs args)
    {
        if (!IsReady)
            return;

        if (string.IsNullOrEmpty(args.Text))
        {
            _logMessages.LogMessagesAdd("advise dde symbol", string.Format("args.Text is empty or NULL for {0}", args.Item), true);
            return;
        }

        try
        {
            string[] argsArray = args.Text.Replace("\0", "").Replace('\0'.ToString(), "").Split(' '); // sometimes happens here

            var list = _symbols.Where(s => s.DDESymbol == args.Item).ToList();
            if (list.Count == 0)
                return;

            decimal? val = null;
            try
            {
                var stringParts = StringUtils.CleanProphitXUrl(argsArray[0]).Split('.');
                argsArray = null;

                if (stringParts.Length >= 2)
                    val = decimal.Parse(stringParts[0] + "." + (stringParts[1].Length > 2 ? stringParts[1].Substring(0, 2) : stringParts[1]));
                else
                    val = decimal.Parse(stringParts[0]);

                stringParts = null;
            }
            catch (Exception ex)
            {
                _logMessages.LogMessagesAdd("call Price Alerts application service", ex.Message, true);
                return;
            }

            foreach (var l in list)
            {
                if (_lastPrices[l.DDESymbol] == null)
                    continue;

                if (_lastPrices[l.DDESymbol].ToString() != val.ToString())
                {
                    try
                    {
                        _quotePublishingService.PublishQuote(l.DDESymbolId, l.Symbol, args.Item, val, WebSyncPublisherUrl,
                            PublishingChannel); // a call to wcf service
                    }
                    catch (Exception ex)
                    {
                        _logMessages.LogMessagesAdd("call the service", ex.Message, true); // save to sql db
                        return;
                    }

                    _lastPrices[l.DDESymbol] = val.ToString();
                }
            }
            list = null;
            val = null;
        }
        catch
        {
        }            
    }

 public static string CleanProphitXUrl(string value) // StringUtils.CleanProphitXUrl snippet
    {
        StringBuilder sb = new StringBuilder();
        sb.Append(value.Substring(0, value.LastIndexOf(".") + 1));

        try
        {
            value = value.Replace('\r'.ToString(), "").Replace('\t'.ToString(), "").Replace('\n'.ToString(), "");
            for (int i = sb.Length; i < value.Length; i++)
            {
                if (char.IsNumber(value[i]))
                    sb.Append(value[i]);
            }
        }
        catch
        {

        }

        return sb.ToString();
    }
4

1 に答える 1

0

AStackOverflowExceptionは、通常、意図しない再帰が原因で、多数のメソッド呼び出しを行うことによって発生します。あなたが投稿したコードの大まかなチェックに基づいて、それが原因だとは思いません。問題はおそらく別の場所にあります。

于 2011-05-05T15:43:05.137 に答える