Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 7967999
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 4, 20262026-06-04T07:00:31+00:00 2026-06-04T07:00:31+00:00

I am refactoring an old code, and one of the things I’d like to

  • 0

I am refactoring an old code, and one of the things I’d like to address is the way that errors are handled. I’m well aware of exceptions and how they work, but I’m not entirely sure they’re the best solution for the situations I’m trying to handle.

In this code, if things don’t validate, there’s really no reason or advantage to unwind the stack. We’re done. There’s no point in trying to save the ship, because it’s a non-interactive code that runs in parallel through the Sun Grid Engine. The user can’t intervene. What’s more, these validation failures don’t really represent exceptional circumstances. They’re expected.

So how do I best deal with this? One thing I’m not sure I want is an exit point in every class method that can fail. That seems unmaintainable. Am I wrong? Is it acceptable practice to just call exit() or abort() at the failure point in codes like this? Or should I throw an exception all the way back to some generic catch statement in main? What’s the advantage?

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-04T07:00:32+00:00Added an answer on June 4, 2026 at 7:00 am

    Throwing an exception to be caught in main and then exiting means your RAII resource objects get cleaned up. On most systems this isn’t needed for a lot of resource types. The OS will clean up memory, file handles, etc. (though I’ve used a system where failing to free memory meant it remained allocated until system restart, so leaking on program exit wasn’t a good idea.)

    But there are other resource types that you may want to release cleanly such as network or database connections, or a mechanical device you’re driving and need to shut down safely. If an application uses a lot of such things then you may prefer to throw an exception to unwind the stack back to main, and then exit.

    So the appropriate method of exiting depends on the application. If an application knows it’s safe then calling _Exit(), abort(), exit(), or quickexit() may be perfectly reasonable. (Library code shouldn’t call these, since obviously the library has no idea whether its safe for every application that will ever use the library.) If there is some critical clean up that must be performed before an application exits but you know it’s limited, then the application can register that clean up code via atexit() or at_quick_exit().

    So basically decide what you need cleaned up, document it, implement it, and try to make sure it’s tested.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I am currently refactoring some of my old code that is pretty terrible. I
This days I'm refactoring code and one of the things I want to improve
Whilst refactoring some old code I realised that a particular header file was full
We are refactoring a legacy application. The old code did something like this in
Okay, strange question time! I'm refactoring some old C++ code that declares a bunch
In the process of refactoring some code, I encountered several build errors such as
I am currently refactoring some old code. I am looking for directions on the
I unfortunately was doing a little code archeology today (while refactoring out some old
I work in a pretty large Java-project (2500+ classes) that uses an old code
I have the old classic code like this, <td align="right"> which does what it

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.