stack overflow - StackOverflow exception



我正在使用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("", "").Replace(''.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();
    }

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

最新更新