954,480 Members — Technology Publication meets Social Media
Username:
Password:
Lost login information?
Have something to say? Contribute New Article Reply to this Article

segmentation fault

Can anyone please explain to me the following strange phenomenon?

I have a code in C, and when I compile it is Windows Platform compiler (Borland 5.5), they compiling is fine and when I execute the program, everything turns out ok.

However, when I use the same code and compile it in UNIX, the compiling is ok but when I execute the program I get a "Segmentation fault" message?

kloony
Light Poster
33 posts since Jan 2005
Reputation Points: 11
Solved Threads: 0
 

There is a bug in the code. You are fortunate that the UNIX platform at least shows you this; in Windows it is just "lucky" to be running.

Dave Sinkula
long time no c
Team Colleague
5,058 posts since Apr 2004
Reputation Points: 2,780
Solved Threads: 314
 

How is that strange? On Windows you didn't touch memory that would cause a critical error, on Unix you did. It means your code is broken. Look for uninitialized pointers and out of bound array accesses. Those are the prime culprits for a seg fault.

Narue
Bad Cop
Administrator
15,460 posts since Sep 2004
Reputation Points: 6,464
Solved Threads: 1,401
 

if there is a bug in the code, why doesn't it show when I compile?
how can i rectify the problem?
I thought segmentation fault has got to do with memory errors...
or is this a portability issue?

kloony
Light Poster
33 posts since Jan 2005
Reputation Points: 11
Solved Threads: 0
 

>if there is a bug in the code, why doesn't it show when I compile?
*stunned silence*

>how can i rectify the problem?
Take my suggestions and look for off by one errors when you index an array or places you might have an uninitialized pointer.

>I thought segmentation fault has got to do with memory errors...
Yes. If you access memory outside of your address space, you get a segmentation fault.

>or is this a portability issue?
No, it's a programmer issue. Fix your broken code.

Narue
Bad Cop
Administrator
15,460 posts since Sep 2004
Reputation Points: 6,464
Solved Threads: 1,401
 

Yes, segmentation fault has chased me long enough when i was learning pointers. Most of the time it gotta do something with the pointers or array. It occurs when...

1. U de-reference a NULL pointer.
2. U de-reference an uninitialized pointer --which results in accessing memory outside of ur memory space.
3. Indexing an array where the index is out of the arrays boundary---- which also means accessing not permitted memory space.
That are the three reasons i can rem for now.

As far as i know the program should have crashed in Windows pc if it were the first case. Since it works with windows itz perhaps either the second or the third case. Look for array bounds, especially in Loops.

Asif_NSU
Posting Whiz
353 posts since Apr 2004
Reputation Points: 113
Solved Threads: 3
 

I have been trying to find out where the bug is but so far I have no luck.
Is it possible to have segmentation fault when the system "run out of memory"?

kloony
Light Poster
33 posts since Jan 2005
Reputation Points: 11
Solved Threads: 0
 

It depends on what you mean by "run out of memory". If malloc fails then it returns a null pointer, which would cause a seg fault if you don't test for failure. However, malloc failure is extremely unlikely these days, so the problem is still probably something you did wrong. If running out of "stack" space for automatic variables caused a segmentation fault, I would still be suspicious of your code because Unix is very good about growing the "stack" if needed. So if you're actually running out of memory (meaning fast memory and virtual memory), there's a lot more wrong with your code than a little error.

Unfortunately, memory errors are very difficult to find, and without actual code to look at, we're just making educated guesses.

Narue
Bad Cop
Administrator
15,460 posts since Sep 2004
Reputation Points: 6,464
Solved Threads: 1,401
 

Hello,

Please post your code. Let's take a look at it. Please use CODE tags when you do it, so that it is nice and clean to read.

Christian

kc0arf
Posting Virtuoso
Team Colleague
1,937 posts since Mar 2004
Reputation Points: 121
Solved Threads: 57
 

Hi all,
when i run this piece of code in C it works properly, but in unix it shows segmentation fault. Help me resolve this.
#include
#include
void main()
{
char *acName="hello daniweb";
*acName='H';
printf("%s",acName);
}

gurushankar
Newbie Poster
9 posts since Sep 2010
Reputation Points: 10
Solved Threads: 0
 

Because you declare acName as acharacter pointer. That is, you cannot change individual letters. All you can do is have it point to another string. So you could write

#include<stdio.h>
#include<stdlib.h>

int main(void)
{
char *acName="hello daniweb";
*acName="H";
printf("%s\n",acName);
}

and the output would be H .

In order to capitalize the first letter, you have to declare acName as acharacter array. You do this by declaring it as an array of characters, but a null character must be included in the characters count. That is, "hello daniweb" has 13 characters. You add the null character and declare an array of 14 characters. The version below does what you want.

#include<stdio.h>
#include<stdlib.h>
void main()
{
char acName[14] = "hello daniweb";
*acName='H';
printf("%s\n",acName);
}
creeps
Junior Poster in Training
82 posts since Jul 2010
Reputation Points: 85
Solved Threads: 8
 

just to elaborate on the above reply,

char *acName="hello daniweb";

acName points to an address of a string . that string is a seperate entity
and the "hello daniweb" is stored in a Read Only Memory
So when you try to change the memory location by doing

*acName='H';


, you are trying to change a Read Only Memory which is causing Segmentation fault.

and in second case

char acName[14] = "hello daniweb";

you have a normal variabel acName which you can play around with . [Obviously you can change the value of a variable] and it wont show any errors.

One more thing , this is a very old thread. Please put any more questions you have in a new thread.

sree_ec
Junior Poster
119 posts since Jan 2010
Reputation Points: 22
Solved Threads: 14
 
One more thing , this is a very old thread. Please put any more questions you have in a new thread.


I actually think this is an awesome example of using the search feature :P

creeps
Junior Poster in Training
82 posts since Jul 2010
Reputation Points: 85
Solved Threads: 8
 

This article has been dead for over three months

Post: Markdown Syntax: Formatting Help
You