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 518039
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 13, 20262026-05-13T07:53:46+00:00 2026-05-13T07:53:46+00:00

ASSERT(pointer); pointer->x; In this code, the ASSERT seems to be redundant. If the pointer

  • 0
ASSERT(pointer);
pointer->x;

In this code, the ASSERT seems to be redundant. If the pointer is NULL, pointer->x will fail anyway. Is my argument correct?

  • 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-05-13T07:53:47+00:00Added an answer on May 13, 2026 at 7:53 am

    The important (if not main) purpose of assertions is to document the invariants that are supposed to hold at certain point in the code. The fact that assert can also abort the program if the invariant is broken is just icing on the cake, albeit a very useful one. I’d say that in a typical program 90% of assertions are assertions that rather obviously can’t fail and never will fail. In other words, assert is to a large degree a kind of formalized comment language. Formalized in a sense that these “comments” are written in the same language the rest of the code is written in (C/C++), as opposed to plain English.

    In your code sample the assertion is there to tell you that the pointer is not supposed to be null here. That’s why it is there. In that sense this assert is not redundant.

    As far as the execution flow is concerned, assert is always redundant, which is why assertions are typically not compiled in the release version of the code. There’s nothing to prevent you from keeping the assertions in release code as well, but normally it is done by introducing a special kind of “release assertion”. In any case, making the main functionality of the code depend in the actions taken by an assertion is not a good programming practice. Assertions are supposed to be redundant, as far as the main functionality of the code is concerned.

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

Sidebar

Related Questions

I am getting an invalid null pointer error from this section of code. I
When Debug.Assert() method calls exist in source code and I compile in release mode,
I'm stuck with this annoying segmentation fault when checking if a pointer is 0.
I've always thought that it's impossible for this to be null inside instance method
Inspired from the other topic , I wrote this code which simulates a finally
I found a bug in my code where I compared the pointer with '\0'.
I have searched and can't find the assert to this. I know it must
Running into an issue with some code I'm working on. This code is being
How to get data samples from QAudioInput I found in this examples code from
Assert.Equals() never calls Equals() operator == operator != Am I missing something? I have

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.