StackOverflow异常

时间:2011-04-27 09:38:16

标签: exception stack-overflow dde

我正在使用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();
    }

1 个答案:

答案 0 :(得分:0)

StackOverflowException是由于通常由意外递归引起的许多方法调用引起的。基于对您发布的代码的粗略检查,我不相信它是罪魁祸首。问题可能在其他地方。