Forum |  HardWare.fr | News | Articles | PC | S'identifier | S'inscrire | Shop Recherche
2251 connectés 

  FORUM HardWare.fr
  Programmation
  C++

  URGENT : implementations de new, new[], delete, delete[] en C++ embarq

 


 Mot :   Pseudo :  
 
Bas de page
Auteur Sujet :

URGENT : implementations de new, new[], delete, delete[] en C++ embarq

n°212424
botman
Cubeur
Posté le 11-09-2002 à 19:15:55  profilanswer
 

bonjour,
 
je travaille sur un projet en C++ embarqué. J'ai pas droit par defaut aux allocateurs new, delete et leurs versions tableaux.
pour new et new[], j'ai fait 2 surcharges a la con a base de malloc/calloc (oui tres con je sais :D)
et j'aurais besoin tres vite d'une implémentation correcte de delete et delete[]
(m'etais jamais penché sur ces deux operateurs en details :D :D :D)

mood
Publicité
Posté le 11-09-2002 à 19:15:55  profilanswer
 

n°212427
chrisbk
-
Posté le 11-09-2002 à 19:17:52  profilanswer
 

ben free, non ?
 
edit : vois pas trop ce que tu nous a magouillé avec tes "surcharges a la con" :D


Message édité par chrisbk le 11-09-2002 à 19:23:35
n°212429
botman
Cubeur
Posté le 11-09-2002 à 19:23:45  profilanswer
 

chrisbk a écrit a écrit :

ben free, non ?



ben ...ca marche po des masses ....
 
pour delete simple oui, ca peut passer si je vais :
 
1)appel du destructeur
2)Free
3)pointeur mis a nul
 
mais ca plante pour les tableaux d'objets alloues avec calloc ...:/


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212431
botman
Cubeur
Posté le 11-09-2002 à 19:25:08  profilanswer
 

chrisbk a écrit a écrit :

ben free, non ?
 
edit : vois pas trop ce que tu nous a magouillé avec tes "surcharges a la con" :D



j'y ai pas droit a new et delete, c'est la premiere fois qu'ils font du C++ pour leur projet embarque donc je bosse sur un noyau Linux, gcc 296, adapte en cross compiler power pc :D
et generation de code pour un OS qui n'a pas le support de ces fonctions.


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212433
chrisbk
-
Posté le 11-09-2002 à 19:34:23  profilanswer
 

BotMan a écrit a écrit :

ben ...ca marche po des masses ....
 
pour delete simple oui, ca peut passer si je vais :
 
1)appel du destructeur
2)Free
3)pointeur mis a nul
 
mais ca plante pour les tableaux d'objets alloues avec calloc ...:/




 
hum y'a des chances, si je me rapelle bien, calloc = malloc + memset(..,0,...), ce qui pue pas mal pour un tableau d'objet car en faisant un memset bourrin sur des objets, tu efface la vtable dedits obj
 
Donc si ton constructeur est en virtuel, ca plantera a la desallocation (ou bien si tu essaye d'appeler des fonctions virtuelles)
 


Message édité par chrisbk le 11-09-2002 à 19:34:46
n°212434
Carbon_14
Posté le 11-09-2002 à 19:34:54  profilanswer
 

Y aurait moyen de visualiser la déclaration originale new, revue calloc ou malloc, et l'ancien delete / nouveau free du truc qui coïnce ???
Y a peut-être "astuce" basique.

n°212435
chrisbk
-
Posté le 11-09-2002 à 19:36:53  profilanswer
 

ca plante que sur les tableau alloué au calloc ou aussi sur ceux alloué au malloc ?

n°212437
botman
Cubeur
Posté le 11-09-2002 à 19:40:56  profilanswer
 

chrisbk a écrit a écrit :

ca plante que sur les tableau alloué au calloc ou aussi sur ceux alloué au malloc ?



le new ca va, le new[] aussi, mais le free :/
je trouve pas de code source sur le web :(


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212440
chrisbk
-
Posté le 11-09-2002 à 19:44:20  profilanswer
 

BotMan a écrit a écrit :

le new ca va, le new[] aussi, mais le free :/
je trouve pas de code source sur le web :(
 




 
 
et tout mon delire sur la vtable ? :D
t'avais des destructeurs virtuels ?

n°212442
youdontcar​e
Posté le 11-09-2002 à 19:45:28  profilanswer
 

BotMan a écrit a écrit :

le new ca va, le new[] aussi, mais le free :/


je pige pas du tout le problème ... si tu surcharges le new [], tu dois appeler calloc, boucler pour mettre les vtables (s'il y en a), appeler les constructeurs . donc pareil mais à l'envers pour le delete[] ...
 

mood
Publicité
Posté le 11-09-2002 à 19:45:28  profilanswer
 

n°212443
botman
Cubeur
Posté le 11-09-2002 à 19:47:40  profilanswer
 

youdontcare a écrit a écrit :

je pige pas du tout le problème ... si tu surcharges le new [], tu dois appeler calloc, boucler pour mettre les vtables (s'il y en a), appeler les constructeurs . donc pareil mais à l'envers pour le delete[] ...
 
 



ckoi un vtable :D


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212444
chrisbk
-
Posté le 11-09-2002 à 19:49:49  profilanswer
 

BotMan a écrit a écrit :

ckoi un vtable :D
 




 
les fonctions virtuelles c juste des pointeurs de fonctions
ces pointeurs sont stocké dans chaque objet, et la ou c stocké c'est la vtable :D

n°212446
youdontcar​e
Posté le 11-09-2002 à 19:50:21  profilanswer
 

BotMan a écrit a écrit :

ckoi un vtable :D


hou :D
 
c'est la virtual table, un pointeur qui contient les pointeurs vers les fonctions de l'objet. ce pointeur est généralement situé au tout début de l'objet alloué. il est présent seulement si l'objet a des méthodes virtuelles.
 
tu espères surcharger des opérateurs d'alloc c++ sans savoir ça ? :D

n°212448
botman
Cubeur
Posté le 11-09-2002 à 19:50:53  profilanswer
 

chrisbk a écrit a écrit :

 
 
les fonctions virtuelles c juste des pointeurs de fonctions
ces pointeurs sont stocké dans chaque objet, et la ou c stocké c'est la vtable :D



j'appelle ca une classe abstraite moi ca :D
mais bon, personne n'a des sources pour delete[] :??:


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212450
chrisbk
-
Posté le 11-09-2002 à 19:51:17  profilanswer
 

BotMan a écrit a écrit :

j'appelle ca une classe abstraite moi ca :D
mais bon, personne n'a des sources pour delete[] :??:




 
 
nan, spa la meme chose, c l'emplacement physique ou sont stocké ces ptr :O

n°212451
botman
Cubeur
Posté le 11-09-2002 à 19:51:22  profilanswer
 

youdontcare a écrit a écrit :

hou :D
 
c'est la virtual table, un pointeur qui contient les pointeurs vers les fonctions de l'objet. ce pointeur est généralement situé au tout début de l'objet alloué. il est présent seulement si l'objet a des méthodes virtuelles.
 
tu espères surcharger des opérateurs d'alloc c++ sans savoir ça ? :D
 



bah je fais mon calloc moi :D


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212453
botman
Cubeur
Posté le 11-09-2002 à 19:52:25  profilanswer
 

chrisbk a écrit a écrit :

 
 
 
nan, spa la meme chose, c l'emplacement physique ou sont stocké ces ptr :O



d'accord mais j'en aurai pas besoin par la suite je pense :D
 
allez juste le principe du delete[] alors :D


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212456
youdontcar​e
Posté le 11-09-2002 à 19:54:38  profilanswer
 

va falloir être plus précis.
 
si tu fais ton calloc et que ça marche, ça veut dire que ton compilo rajoute du code pour initialiser la vtable & appeller le constructeur. la seule chose que tu dois faire est alors allouer un bloc mémoire (donc ton malloc()).
 
ça marche pareil dans le sens inverse : le compilo appelle le destructeur, il te demande alors de détruire le bloc mémoire (free()).

n°212457
botman
Cubeur
Posté le 11-09-2002 à 19:57:01  profilanswer
 

youdontcare a écrit a écrit :

va falloir être plus précis.
 
si tu fais ton calloc et que ça marche, ça veut dire que ton compilo rajoute du code pour initialiser la vtable & appeller le constructeur. la seule chose que tu dois faire est alors allouer un bloc mémoire (donc ton malloc()).
 
ça marche pareil dans le sens inverse : le compilo appelle le destructeur, il te demande alors de détruire le bloc mémoire (free()).
 



mais je dois l'appeller a la main non le destructeur, avant le free :??:
je vois pas comment deviner que le truc passe en parametre a delete est un objet et pas un flottant par exemple :??:


---------------
"OCPLB : On Casse Pas Le Binôme, 'moiselle Jade, Carlson & Peters, page 823 !"
n°212463
Carbon_14
Posté le 11-09-2002 à 20:13:09  profilanswer
 

Vaut mieux un dessin que 1000 lignes de blabla disait Napoléon.
 
Le principe vaut peut-être mieux que le code générique de delete[] ??
Habituellement, il y a une "logique" à la désallocation de la mémoire, un principe de "base", ..
Les opérateurs génériques doivent rendre service en généralisant leur service, mais en C, je suis obligé de savoir ce que je fais et à quoi j'applique les fonctions (chaîne, tableaux de structures multidimentionnels, ... ).
Le C++, ça me semble plutôt le "côté obscur de la force".
 
M'enfin, vais faire un peu de VB3 pour changer. :lol:

n°212465
youdontcar​e
Posté le 11-09-2002 à 20:18:35  profilanswer
 

je viens de vérifier qq trucs avec vc++ :
 
* l'opérateur new surchargé avec les mfc ne fait que l'allocation (en entrée, une taille à allouer, en sortie, un pointeur vers une zone mémoire avec cette taille dispo)
 
* les constructeurs / destructeurs sont directement appelés dans le code. eg :
 
myClass* mc = new myClass;
 
est assemblé en :
* appel vers l'opérateur new, la taille étant déterminée à la compil ou en runtime (sizeof(myClass) * nombre d'éléments)
* appel du constructeur (qui met la vtable à jour). si plusieurs éléments, appel d'une routine qui fait la boucle d'appel des constructeurs.
 
DONC si gcc marche de la même façon (a priori pas de raison, tu peux toujours debugger pour être sûr) tu n'as qu'à te soucier de deux choses : allouer un bloc mémoire d'une taille donnée, le désallouer lorsqu'on te le repasse pour la destruction. c'est tout.
 
DONC (bis) je ne pige toujours pas ton problème ! :D

n°212468
botman
Cubeur
Posté le 11-09-2002 à 20:20:28  profilanswer
 

youdontcare a écrit a écrit :

je viens de vérifier qq trucs avec vc++ :
 
* l'opérateur new surchargé avec les mfc ne fait que l'allocation (en entrée, une taille à allouer, en sortie, un pointeur vers une zone mémoire avec cette taille dispo)
 
* les constructeurs / destructeurs sont directement appelés dans le code. eg :
 
myClass* mc = new myClass;
 
est assemblé en :
* appel vers l'opérateur new, la taille étant déterminée à la compil ou en runtime (sizeof(myClass) * nombre d'éléments)
* appel du constructeur (qui met la vtable à jour). si plusieurs éléments, appel d'une routine qui fait la boucle d'appel des constructeurs.
 
DONC si gcc marche de la même façon (a priori pas de raison, tu peux toujours debugger pour être sûr) tu n'as qu'à te soucier de deux choses : allouer un bloc mémoire d'une taille donnée, le désallouer lorsqu'on te le repasse pour la destruction. c'est tout.
 
DONC (bis) je ne pige toujours pas ton problème ! :D



ben c'est bien ce que j'ai fais, sauf que je vois pas la difference entre delete et delete[], c'est tjs un free pour liberer la zone memoire nan :??:
 
en tout cas merci bcp :)

n°212470
youdontcar​e
Posté le 11-09-2002 à 20:22:24  profilanswer
 

carbon_14 a écrit a écrit :

Le C++, ça me semble plutôt le "côté obscur de la force".


:??:

n°212472
youdontcar​e
Posté le 11-09-2002 à 20:27:09  profilanswer
 

BotMan a écrit a écrit :

je vois pas la difference entre delete et delete[], c'est tjs un free pour liberer la zone memoire nan :??:


vi.  
 
la différence c'est que certains types d'allocations stockent des données : pour allouer un bloc de 30 octets, ils allouent 40 et stockent leurs infos au début, puis passent un pointeur sur la mem allouée + 10 (donc 30 octets dispo, plus 10 de headers). apparemment c'est juste pour les opérateurs natifs, pas de distinction quand tu surcharges (toujours un delete() chez vc++).

n°212475
youdontcar​e
Posté le 11-09-2002 à 20:34:26  profilanswer
 

toujours pour delete / delete [], tu peux apparemment choisir d'overloader les deux, et donc en faire deux cas particuliers (application dans mon message précédents : stockage d'infos, debug & co).
 
si tu ne surcharges que delete, cette surcharge sera utilisée pour delete et delete [].

n°213460
Musaran
Cerveaulté
Posté le 13-09-2002 à 01:52:58  profilanswer
 

BotMan a écrit a écrit :

generation de code pour un OS qui n'a pas le support de ces fonctions.


Kwa ? new/delete sont des fonctions du langage, pas de l'OS...
 
new doit mémoriser le type de l'objet associé à une adresse.
new[] doit mémoriser en plus le nombre d'objets.
Y'a que comme ça que delete et delete[] peuvent faire leur boulot.
 
Mais si tu es sur un système limite en mémoire/puissance, il vaut peut-être mieux abandonner l'aspect polymorphique de 'allocation, et utiliser une version bridée de delete([]) à laquelle il faut spécifier le type/nombre exact d'objets à détruire.


---------------
Bricocheap: Montage de ventilo sur paté de mastic silicone
mood
Publicité
Posté le   profilanswer
 


Aller à :
Ajouter une réponse
  FORUM HardWare.fr
  Programmation
  C++

  URGENT : implementations de new, new[], delete, delete[] en C++ embarq

 

Sujets relatifs
[mysql] aide avec mysqldump !!!!! urgent ![Très Urgent] Php / MySQL, vérifier la présence d'une variable.
[urgent] comment faire ca en adaimplémentations de FileSystem
[URGENT] -PHP- déplacement de fichiers (suite...)ACCESS 2000 : VERY URGENT
Base de donnée Access et sécurité? HELP.. URGENT (merci)URGENT recherche Web service en télechargement
[VBA] Urgent - Comment modifier le menu contextuel de Word? [résolu]Impossible d'installer Visual c++ 4 sous windows NT - URGENT
Plus de sujets relatifs à : URGENT : implementations de new, new[], delete, delete[] en C++ embarq


Copyright © 1997-2022 Hardware.fr SARL (Signaler un contenu illicite / Données personnelles) / Groupe LDLC / Shop HFR