Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza
Motorola edge 70 porta il concetto di smartphone ultrasottile su un terreno più concreto e accessibile: abbina uno spessore sotto i 6 mm a una batteria di capacità relativamente elevata, un display pOLED da 6,7 pollici e un comparto fotografico triplo da 50 MP. Non punta ai record di potenza, ma si configura come alternativa più pragmatica rispetto ai modelli sottili più costosi di Samsung e Apple
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026
Sono molte le novità che ASUS ha scelto di presentare al CES 2026 di Las Vegas, partendo da una gamma di soluzioni NUC con varie opzioni di processore passando sino agli schermi gaming con tecnologia OLED. Il tutto senza dimenticare le periferiche di input della gamma ROG e le soluzioni legate alla connettività domestica
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-01-2014, 19:15   #1
darth_19
Member
 
L'Avatar di darth_19
 
Iscritto dal: Mar 2008
Messaggi: 264
[C] Heap, errore "deferencing pointer to incomplete type"

salve, svolgendo un esercizio di programmazione sulle code a priorità implementate mediante heap ho incontrato questo errore, non riesco a capire come risolverlo dato che a livello logico mi sembra sia tutto apposto, l'algoritmo dovrebbe andare senza problemi, pensavo fosse qualche problema di allocazione ma anche implementando la memoria dinamica non sono riuscito a risolvere il problema, qui c'è il codice:

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

#include "job.h"
#include "pqueue.h"

#define MAXJOB 100
#define LEFT(i)   	( (i*2) + 1 )
#define RIGHT(i)	( (i*2) + 2 )
#define PARENT(i)	( (i-1) / 2 )

struct PQUEUEtype
{
   job* heap; /*puntatore a job*/
   int heapsize;
};

.
.
.

void PQUEUEinsert ( pqueue x, job item ) /*item è l'elemento da inserire in pqueue*/
{
    int i;

    i =++(x->heapsize); /*aggiungo un elemento vuoto e parto dall'ultimo elemento dell'heap*/

    while ( i>1 && ( x->heap[PARENT(i)]->priority ) < item->priority ) /*finchè: 1)non esco fuori dall'heap e
                                                                                 2)il padre dell'elemento corrente dell'heap è minore dell'elemento da inserire (confronto le priorità!) */
    {
        x->heap[i] = x->heap[PARENT(i)]; /*faccio scendere il padre (puntatore job!) */
        i = PARENT(i);
    }

    x->heap[i]=item;
}

.
.
.

void PQUEUEheapify ( pqueue x, int i )
{
   int l, r, largest;

   l = LEFT(i);
   r = RIGHT(i);

   if ( l < x->heapsize && x->heap[l]->priority > x->heap[i]->priority )
     largest=l;
   else largest = i;

   if ( r < x->heapsize && x->heap[r]->priority > x->heap[largest]->priority)
     largest=r;
   if ( largest != i )
   {
     SWAP( x, i, largest );
     PQUEUEheapify( x, largest );
   }
}
l'errore lo riscontro in queste due funzioni, nell'header legato al .c ho la dichiarazione del tipo "pqueue" che è un puntatore a struct PQUEUEtype, riuscireste ad aiutarmi a capire perchè continua a darmi questo problema???

Vi ringrazio!
darth_19 è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2014, 19:30   #2
vbextreme
Member
 
L'Avatar di vbextreme
 
Iscritto dal: Dec 2013
Messaggi: 90
non ho capito ne l'errore ne cosa vuoi fare...
__________________
Easy framework per il linguaggio C.
vbextreme hack your life
vbextreme è offline   Rispondi citando il messaggio o parte di esso
Old 02-01-2014, 20:00   #3
darth_19
Member
 
L'Avatar di darth_19
 
Iscritto dal: Mar 2008
Messaggi: 264
Posto il codice completo per chiarezza:

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

#include "job.h"
#include "pqueue.h"

#define MAXJOB 100
#define LEFT(i)   	( (i*2) + 1 )
#define RIGHT(i)	( (i*2) + 2 )
#define PARENT(i)	( (i-1) / 2 )

struct PQUEUEtype
{
   job* heap; /*puntatore a job*/
   int heapsize;
};


pqueue PQUEUEcreate ( )
{
    pqueue x;

    printf("-> Creazione di una Coda a Priorità...\n");
    x = malloc( sizeof(*x) );

    x->heap= malloc( sizeof(job)*MAXJOB );
    x->heapsize = 0 ;
    printf("-> Coda inizializzata.\n");

    return x;
}

void PQUEUEdelete ( pqueue x )
{
    printf("-> eliminazione di una Coda a Priorità...");
    free(x);
    printf(" ...Coda eliminata.\n");
}

void PQUEUEshow ( pqueue x )
{
    int i;

    printf("---> Visualizzazione di una Coda a Priorità: \n");

    for(i=0; i< x->heapsize; i++)
    {
        JOBdisplay( x->heap[i] );
    }

    printf("---> Coda Visualizzata. \n");

}

void PQUEUEinsert ( pqueue x, job item ) /*item è l'elemento da inserire in pqueue*/
{
    int i;

    i =++(x->heapsize); /*aggiungo un elemento vuoto e parto dall'ultimo elemento dell'heap*/

    while ( i>1 && ( x->heap[PARENT(i)]->priority ) < item->priority ) /*finchè: 1)non esco fuori dall'heap e
                                                                                 2)il padre dell'elemento corrente dell'heap è minore dell'elemento da inserire (confronto le priorità!) */
    {
        x->heap[i] = x->heap[PARENT(i)]; /*faccio scendere il padre (puntatore job!) */
        i = PARENT(i);
    }

    x->heap[i]=item;
}

void SWAP ( pqueue x, int index1, int index2)
{
    job temp;

    temp = x->heap[index1];
    x->heap[index1] = x->heap[index2];
    x->heap[index2] = temp;
}

void PQUEUEheapify ( pqueue x, int i )
{
   int l, r, largest;

   l = LEFT(i);
   r = RIGHT(i);

   if ( l < x->heapsize && x->heap[l]->priority > x->heap[i]->priority )
     largest=l;
   else largest = i;

   if ( r < x->heapsize && x->heap[r]->priority > x->heap[largest]->priority)
     largest=r;
   if ( largest != i )
   {
     SWAP( x, i, largest );
     PQUEUEheapify( x, largest );
   }
}

void PQUEUEbuildheap ( pqueue x)
{
	int i;
	for ( i = (x->heapsize)/2-1 ; i >= 0; i--)
     {
		PQUEUEheapify(x, i);
	 }
}
praticamente è un modulo per l'implementazione delle code a priorità mediante Heap, l'esercizio fondamentalmente consiste nello gestire una coda a priorità

l'errore mi viene dato nelle righe in cui c'è il passaggio di puntatori "coda a priorità"->"vettore di job"->"singolo job", ovvero nel while della funzione PQUEUEinsert e nelle if della funzione PQUEUEheapify

il "tipojob" è un puntatore ad una struct jobtype che contiene un intero, la priorità del "job", ed una stringa. C'è tutto questo passaggio di puntatori perchè viene richiesto di implementare sia il "tipo coda a priorità" che il "tipo job" come ADT di prima categoria...

spero di aver dato abbastanza informazioni, è la prima volta che scrivo in questa sezione del forum mi scuso se non sono stato chiaro, o se continuo a non esserlo...

Ultima modifica di darth_19 : 02-01-2014 alle 20:04.
darth_19 è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 09:11   #4
vbextreme
Member
 
L'Avatar di vbextreme
 
Iscritto dal: Dec 2013
Messaggi: 90
che errore ti da?
__________________
Easy framework per il linguaggio C.
vbextreme hack your life
vbextreme è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 09:29   #5
darth_19
Member
 
L'Avatar di darth_19
 
Iscritto dal: Mar 2008
Messaggi: 264
l'ho scritto nel titolo!

"deferencing pointer to incomplete type"
darth_19 è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 09:33   #6
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
"a naso", il problema e' che o pqueue o job non sono state dichiarate correttamente per cui quando cerchi di andare a dereferenziare i puntatori non sa cosa c'e' dentro (incompete type solitamente vuol dire che proprio non sa come e' definita la struttura dati), ma senza sapere cos ahai scritto in job.h e pqueue.h e' difficile dare una risposta precisa.
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 09:49   #7
darth_19
Member
 
L'Avatar di darth_19
 
Iscritto dal: Mar 2008
Messaggi: 264
allora non avendo problemi di diritti d'autore vi posto anche i file header

job.h:
Codice:
/*--- MODULO PER LA GESTIONE DEI SINGOLI JOB ---*/

/*
ogni job è caratterizzato da:
- livello di priorità (intero positivo)
- informazioni sul processo (stringa di massimo 30 caratteri)
*/

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

typedef struct JOBtype* job; /*il singolo job è un puntatore a una struct jobtype*/

/*--- FUNZIONI DI INTERFACCIA ---*/

job JOBcreate( ); /*creazione di un job (vuoto) e sua inizilizzazione*/
void JOBdelete( job ); /*eliminazione del job passato alla funzione*/
void JOBdisplay (job); /*visualizzazione a video delle informazioni del job passato alla funzione*/

pqueue.h:
Codice:
/*--- MODULO PER LA GESTIONE DEllA PRIORITY QUEUE ---*/

/*
La priority queue è implementata mediante uno heap.
Si possono gestire al massimo 100 job.
*/

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

#include "job.h"

typedef struct PQUEUEtype* pqueue;

/*--- FUNZIONI DI INTERFACCIA ---*/

pqueue PQUEUEcreate ( ); /* alloca una coda a priorità */
void PQUEUEdelete ( pqueue ); /* elimina una coda a priorità */
void PQUEUEshow ( pqueue ); /* visualizza a video una coda*/

void PQUEUEinsert ( pqueue, job ); /* inserisce un elemento job in pqueue */
void SWAP ( pqueue, int, int ); /*scambia di posto due job all'interno della coda*/
void PQUEUEbuildheap ( pqueue ); /*costruisce uno heap a partire dal vettore di job*/
void PQUEUEheapify ( pqueue, int ); /*applica la proprietà funzionale degli heap al sotto albero: i, left(i), right(i) (con i indice dell'elemento job)*/
mi sembra sia tutto apposto, ho dichiarato il tipo di dato astratto pqueue e job come puntatore alla struct dichiarata nel .c, non è la prima volta che lavoro con gli ADT ed ho sempre fatto così, non lo so magari mi sfugge qualcosa...riuscite a scovare il problema?
darth_19 è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 11:25   #8
vendettaaaaa
Senior Member
 
L'Avatar di vendettaaaaa
 
Iscritto dal: Jan 2012
Messaggi: 1267
Non ho letto il codice, non ho voglia, ma ti posso dire che io uso il C++ e "incomplete type" significa che il tipo è stato solo dichiarato senza definirlo. O meglio, quando tenti di usare un oggetto di cui il compilatore non conosce la definizione, e quindi il layout in memoria. Puoi invece dichiarare puntatori a tipi incompleti in quanto non serve sapere quanto occupano. Esempio:
Codice:
class Foo; // Solo dichiarata e non definita

int main()
{
  Foo a; // Errore: per allocare nella stack una variabile Foo devo sapere cosa contiene e quindi quanta memoria occupa
  Foo* a; // OK
}
Quindi sarà qualcosa di simile nel tuo codice.

Ultima modifica di vendettaaaaa : 03-01-2014 alle 11:28.
vendettaaaaa è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 11:38   #9
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Codice:
typedef struct JOBtype* job;
Manca la definizione di JOBtype;
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 12:07   #10
darth_19
Member
 
L'Avatar di darth_19
 
Iscritto dal: Mar 2008
Messaggi: 264
Quote:
Originariamente inviato da vendettaaaaa Guarda i messaggi
Non ho letto il codice, non ho voglia, ma ti posso dire che io uso il C++ e "incomplete type" significa che il tipo è stato solo dichiarato senza definirlo. O meglio, quando tenti di usare un oggetto di cui il compilatore non conosce la definizione, e quindi il layout in memoria. Puoi invece dichiarare puntatori a tipi incompleti in quanto non serve sapere quanto occupano. Esempio:
Codice:
class Foo; // Solo dichiarata e non definita

int main()
{
  Foo a; // Errore: per allocare nella stack una variabile Foo devo sapere cosa contiene e quindi quanta memoria occupa
  Foo* a; // OK
}
Quindi sarà qualcosa di simile nel tuo codice.

ti ringrazio per la risposta, potresti dare un'occhiata al codice di job.h (dove dichiaro il puntatore alla struct) e job.c (dove dichiaro effettivamente la struct), io so che in c posso dichiare puntatori a struct non ancora dichiarate, e questo mi permette di implementare i cosiddetti "ADT di prima categoria", come vengono chiamati dal mio libro di riferimento (il Sedghewick), ora, io penso di aver messo tutto al posto giusto, il mio sarebbe una specie di "puntatore opaco", non capisco però perchè mi dia quell'errore...anche perchè mettendo a paragone con altri programmi che ho scritto, sempre seguendo la stessa modalità, non trovo differenze...

ecco il passaggio a cui mi riferisco:

Codice:
job.h:

typedef struct JOBtype* job; /*il singolo job è un puntatore a una struct jobtype*/

job.c:

struct JOBtype
{
    int priority;
    char process_info[MAXCHAR];
};

Ultima modifica di darth_19 : 03-01-2014 alle 12:11.
darth_19 è offline   Rispondi citando il messaggio o parte di esso
Old 03-01-2014, 16:19   #11
marco.r
Senior Member
 
Iscritto dal: Dec 2005
Città: Istanbul
Messaggi: 1817
Quote:
Originariamente inviato da darth_19 Guarda i messaggi
ti ringrazio per la risposta, potresti dare un'occhiata al codice di job.h (dove dichiaro il puntatore alla struct) e job.c (dove dichiaro effettivamente la struct), io so che in c posso dichiare puntatori a struct non ancora dichiarate, e questo mi permette di implementare i cosiddetti "ADT di prima categoria", come vengono chiamati dal mio libro di riferimento (il Sedghewick), ora, io penso di aver messo tutto al posto giusto, il mio sarebbe una specie di "puntatore opaco", non capisco però perchè mi dia quell'errore...anche perchè mettendo a paragone con altri programmi che ho scritto, sempre seguendo la stessa modalità, non trovo differenze...
Buona l'idea del puntatore opaco, ma allora devi fornire delle operazioni affinche' chi usa la tua struttura possa non sapere come e' fatta.
Ad esempio nel tuo caso potresti implementare job.h qualcosa come
Codice:
typedef struct JOBtype* job; /*il singolo job è un puntatore a una struct jobtype*/

int get_priority(job j);
void set_priority(job j,int priority);
void get_process_info(job,char process_info[MAXCHAR]);
void set_process_info(job,char process_info[MAXCHAR]);
In job.c oltre alla definizione della struttura metti anche quella delle operazioni che ci vuoi associare.
Codice:
struct JOBtype
{
    int priority;
    char process_info[MAXCHAR];
};

int get_priority(job j)
{
    return job->priority;
}

void set_priority(job j,int priority)
{
    job->priority = priority;
}

void get_process_info(job,char process_info[MAXCHAR]) { /* ... */ }
void set_process_info(job,char process_info[MAXCHAR]) { /* ... */ }
Ci sono anche alternative. Se JOBtype e' un tipo "interno" utilizzato solo da un'altra struttura, ad esempio dalla tua coda, uno potrebbe considerare eccessiva tutta questa astrazione. In questo caso JOBtype potrebbe essere noto alla coda, e opaco all'esterno, e quindi la sua definizione deve essere visibile anche dal codice che hai riportato sopra.
In questo potresti creare allora un header (job_impl.h ad esempio) che contenta la definizione della struttura e che venga incluso solo da chi di dovere
__________________
One of the conclusions that we reached was that the "object" need not be a primitive notion in a programming language; one can build objects and their behaviour from little more than assignable value cells and good old lambda expressions. —Guy Steele
marco.r è offline   Rispondi citando il messaggio o parte di esso
Old 04-01-2014, 09:50   #12
darth_19
Member
 
L'Avatar di darth_19
 
Iscritto dal: Mar 2008
Messaggi: 264
Marco infatti ho fatto così quello che ho postato era un estratto dei file .h e .c, nel file .h ci sono i prototipi e la dichiarazione del puntatore opaco, mentre nel file .c c'è la dichiarazione della struttura a cui punta il puntatore opaco e le funzioni..

..ma ancora l'errore continua a darmelo

RISOLTO!

avevi ragione marco l'errore stava in una deferenziazione dove passavo da un puntatore alla struct che avevo definito nel file pqueue.c ad una che avevo definito nel file job.c... mi mancava appunto una stupidissima funzione nel .c che dato un puntatre job mi ritornava il campo priority... che stupidaggine .-.

Codice:
int JOBpriority( job x)
{
    return x->priority;
}
grazie a tutti per l'aiuto!

Ultima modifica di darth_19 : 04-01-2014 alle 10:14.
darth_19 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
Le novità ASUS per il 2026 nel settore dei PC desktop Le novità ASUS per il 2026 nel settore de...
Le novità MSI del 2026 per i videogiocatori Le novità MSI del 2026 per i videogiocato...
Amazon aggiorna le offerte anche a metà ...
Trump elogia Microsoft: accordi con le B...
L'Unione Europea scommette sul software ...
In Cina parte la prima linea per batteri...
Un benchmark che mette in difficolt&agra...
OnePlus nella bufera a Taiwan: emesso ma...
Arriva Hyper Hosting, la nuova offerta ...
Steam non si ferma più: nuovo rec...
Venezuela, altro che petrolio: il tesoro...
EcoFlow DELTA Pro Ultra X: potenza e rap...
SK hynix: un nuovo impianto per produrre...
Facebook, cresce il furto di password co...
Tesla lancia la nuova Model Y con 7 post...
NVIDIA smentisce: nessun pagamento antic...
Il prototipo del razzo spaziale riutiliz...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 05:33.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v