PDA

Visualizza la versione completa : [C] Segmentation fault su array di stringhe globale


Kamui
07-09-2011, 13:23
Ciao :zizi:

Ho questo problema: quando creo un array di stringhe - o meglio, di char* - se questo globale non riesco a scrivere dentro i suoi elementi, n con strdup n facendo a mano la malloc.
Lo stesso codice usando lo stesso array ma locale, invece, funziona.

Ad esempio:



incluso.h:

#define MAX 10


file1.c:

int n=0;
char* array[MAX];


file2.c:

extern int n;
extern char* array[MAX];

void fun(){
array[0]=strdup(mia_stringa);
}

-> segfault :mem:




incluso.h:

#define MAX 10


file2.c:

void fun(){
char* array[MAX];
array[0]=strdup(mia_stringa);
}


-> non segfaulta ma duplica la stringa nell'elemento 0 del mio array.

Vi ringrazio in anticipo per i suggerimenti :bh:

oregon
07-09-2011, 13:39
Non vedo problemi ... forse la causa da qualche altra parte del codice ... mostralo tutto ...

Kamui
07-09-2011, 15:17
e' un po' lungo :afraid:

quella variabile la uso l per la prima volta, mi serve globale perch dev'essere recuperata altrove e volevo evitarmi i passaggi di parametri :stordita:

se mi dici cosa cercare lo posto.

non possono essere problemi hardware? Il codice non gira su PC ma su una scheda con la RAM al limite, ho gi avuto qualche magagna abbastanza inspiegabile con gli spazi di memoria.

oregon
07-09-2011, 15:21
Beh ... s, potrebbe essere un problema di risorse ... non facile dirlo senza avere altre info.

Kamui
07-09-2011, 15:51
Che tipo di info possono servire?

La RAM sempre quasi satura ma c' una partizione di swap, incollo anche i valori di ulimit.



# cat /proc/2338/limits
Limit Soft Limit Hard Limit Units
Max cpu time unlimited unlimited seconds
Max file size unlimited unlimited bytes
Max data size unlimited unlimited bytes
Max stack size 8388608 unlimited bytes
Max core file size 0 unlimited bytes
Max resident set unlimited unlimited bytes
Max processes unlimited unlimited processes
Max open files 1024 1024 files
Max locked memory 65536 65536 bytes
Max address space unlimited unlimited bytes
Max file locks unlimited unlimited locks
Max pending signals 16382 16382 signals
Max msgqueue size 819200 819200 bytes
Max nice priority 0 0
Max realtime priority 0 0
Max realtime timeout unlimited unlimited us

# free -m
total used free shared buffers cached
Mem: 59 58 1 0 4 27
-/+ buffers/cache: 26 33
Swap: 89 1 88


E' un programma C sotto Linux su architettura ARMEL, compilato con gcc via crosscompilazione.

Il problema semplice come l'ho descritto, gli array di stringhe globali mi segfaultano nonostante lo stesso codice su array locali nella stessa posizione nel flusso del programma funzioni :ecco:

Un modo per girare attorno al problema usare una struct globale anzich un array, ma non capisco perch.


incluso.h:

#define MAX 10
#ifndef STRUCT_UPDATES
#define STRUCT_UPDATES
struct updates{
char* name;
};
#endif

file1.c:

struct updates array[MAX];


file2.c:

extern int n;
extern struct updates array[MAX];

void fun(){
array[0].name=strdup(mia_stringa);
}

Loading