delorie.com/archives/browse.cgi | search |
X-Spam-Check-By: | sourceware.org |
To: | cygwin AT cygwin DOT com |
From: | Shankar Unni <shankarunni AT netscape DOT net> |
Subject: | Re: Throwing c++ exception across threads |
Date: | Thu, 26 Apr 2007 18:31:09 -0700 |
Lines: | 47 |
Message-ID: | <f0rjou$8i4$1@sea.gmane.org> |
References: | <f0no2t$pfq$1 AT sea DOT gmane DOT org> |
Mime-Version: | 1.0 |
User-Agent: | Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.8.1.3) Gecko/20070326 Thunderbird/2.0.0.0 Mnenhy/0.7.5.666 |
In-Reply-To: | <f0no2t$pfq$1@sea.gmane.org> |
X-IsSubscribed: | yes |
Mailing-List: | contact cygwin-help AT cygwin DOT com; run by ezmlm |
List-Id: | <cygwin.cygwin.com> |
List-Unsubscribe: | <mailto:cygwin-unsubscribe-archive-cygwin=delorie DOT com AT cygwin DOT com> |
List-Subscribe: | <mailto:cygwin-subscribe AT cygwin DOT com> |
List-Archive: | <http://sourceware.org/ml/cygwin/> |
List-Post: | <mailto:cygwin AT cygwin DOT com> |
List-Help: | <mailto:cygwin-help AT cygwin DOT com>, <http://sourceware.org/ml/#faqs> |
Sender: | cygwin-owner AT cygwin DOT com |
Mail-Followup-To: | cygwin AT cygwin DOT com |
Delivered-To: | mailing list cygwin AT cygwin DOT com |
Eric Lilja wrote: > [...] Any messages are > displayed in an editbox. If a severe error occurs, an exception is > thrown. Will there be any problems if I catch these exceptions in the > main thread? [...] Just thinking about that setup makes my head spin. Yes, I suspect there'll be lots of problems if you do this. :-) The very concept of "catching the exception in main" is absurd when threads are involved: the whole point of exception catching and throwing is that it is totally synchronous, and goes from callee to caller (to its caller and so on, until your main()). All of this only makes sense in the context of one thread. Implicit in the catching of an exception is the idea that the exception was thrown from _something you called from within that try block_. Otherwise, you'd have a situation like: /* parent: */ func() { ... // spawn thread return; //!! } main() { ... func(); ... some_other_random_stuff(); } /* child: */ ... throw something; ... Err, but the point from where the thread was created is no longer on the stack, because control returned to the parent and then went on somewhere else. So even if you attempted to do something bizarre like "hop stacks to the parent thread's stack", you'd end up in some random stack frame in the parent thread, like "some_other_random_stuff()", which won't be expecting that exception and won't know what to do with it... -- Unsubscribe info: http://cygwin.com/ml/#unsubscribe-simple Problem reports: http://cygwin.com/problems.html Documentation: http://cygwin.com/docs.html FAQ: http://cygwin.com/faq/
webmaster | delorie software privacy |
Copyright © 2019 by DJ Delorie | Updated Jul 2019 |