Segmentation fault in gdb

Y

yinglcs

Hi,

i get this segmentation fault in my c++ program:

My question is 'it shows inMethodStr is not null, how come this can
have *inMethodStr.Ptr segmentation fault?

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread -1229927536 (LWP 16203)]
0x0806a1ee in RTSPProtocol::GetMethod (inMethodStr=@0xb6b0b6b0)
at Protocol.cpp:58
58 switch(*inMethodStr.Ptr)

Thank you for any help.
 
N

Neelesh Bodas

Hi,

i get this segmentation fault in my c++ program:

My question is 'it shows inMethodStr is not null, how come this can
have *inMethodStr.Ptr segmentation fault?

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread -1229927536 (LWP 16203)]
0x0806a1ee in RTSPProtocol::GetMethod (inMethodStr=@0xb6b0b6b0)
at Protocol.cpp:58
58 switch(*inMethodStr.Ptr)

Thank you for any help.

inMethodStr is not null doesnot mean it points to the properly
initialized object or object containing valid data.


Posting relevant piece of code might help.
 
R

Ron Natalie

Hi,

i get this segmentation fault in my c++ program:

My question is 'it shows inMethodStr is not null, how come this can
have *inMethodStr.Ptr segmentation fault?

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread -1229927536 (LWP 16203)]
0x0806a1ee in RTSPProtocol::GetMethod (inMethodStr=@0xb6b0b6b0)
at Protocol.cpp:58
58 switch(*inMethodStr.Ptr)

Thank you for any help.

In inMethodStr is something that can have . applied to it
(that is a class). It won't be null. Chances are
inMethodStr.Ptr is either a null pointer or points to
something other than a valid object.
 
A

Andre Kostur

Hi,

i get this segmentation fault in my c++ program:

My question is 'it shows inMethodStr is not null, how come this can
have *inMethodStr.Ptr segmentation fault?

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread -1229927536 (LWP 16203)]
0x0806a1ee in RTSPProtocol::GetMethod (inMethodStr=@0xb6b0b6b0)
at Protocol.cpp:58
58 switch(*inMethodStr.Ptr)

Thank you for any help.

How would we know? We can't see the rest of the code. Please post a
minimal, compilable example that shows the problem.

Offhand the address of inMethodStr is suspicious because it has a repeating
pattern (0xb6b0b6b0). This may suggest that you are using and/or passing
an uninitialized variable into GetMethod. Then you use the . operator on
that object, and Undefined Behaviour occurs (effectively dereferencing a
pointer to who-knows-where).
 
M

Martijn van Buul

* Ron Natalie:
In inMethodStr is something that can have . applied to it
(that is a class). It won't be null.

It *shouldn't* be NULL, but if I would do something like

struct SomeStruct
{
int foo;
int bar;
};

void SomeFunction (SomeStruct &pInStruct)
{
switch (pInStruct.foo)
{
[...]
}
};

int main(void)
{
SomeStruct *SueMe = 0;
SomeFunction(*SueMe);
}

Then 'pInStruct' *WILL* be NULL. And yes, I know, undefined behaviour, which
most definately *includes* being caught in a debugger.
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
473,995
Messages
2,570,236
Members
46,822
Latest member
israfaceZa

Latest Threads

Top