abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
dnes 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
včera 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 4
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 9
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
20.1. 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 360 hlasů
 Komentářů: 25, poslední včera 13:34
Rozcestník
Reklama

Dotaz: C++ test na existenci dynamicky alokovane promenne

menphis avatar 19.8.2008 23:51 menphis | skóre: 22 | blog: menphis_blog
C++ test na existenci dynamicky alokovane promenne
Přečteno: 362×
dneska jsem resil zhruba nasledujici problem:

mam tridu
class Trida
{
public:

double* data

Trida(int);
~Trida();
Test(i);

};
 
v metode test dynamicky alokuji pole:
data = new double[i];
jak lze pote v destruktoru tridy (ale i jinde) zjistit, zda se pole skutecne alokovalo ? obvykla metoda
if (data) 
selze, protoze promena data existuje a navic ukazuje i na konkretni misto v pameti.

vim, ze by se napriklad pomoci bloku try dalo testovat, zda se vytvoreni pole povedlo primo v metode Test(i) a pripadne nastavit nejakou vlajku, ale takove reseni mi prijde docela kostrbate. neexistuje nejaky lepsi zpusob ?

Odpovědi

Luboš Doležel (Doli) avatar 20.8.2008 00:12 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
Inicializovat data v konstruktoru na 0
menphis avatar 20.8.2008 00:31 menphis | skóre: 22 | blog: menphis_blog
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
dik, ale tohle prave nechci, protoze promenou data budou pouzivat jen nektere instance tridy, takze ji nechci vytvaret v konstruktoru tridy, ale az ve chvili kdy bude potreba.
Luboš Doležel (Doli) avatar 20.8.2008 00:42 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
Co je to za blbost? Jaké vytváření proměnné? :-)
menphis avatar 20.8.2008 01:10 menphis | skóre: 22 | blog: menphis_blog
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
sorry ze tu pisu hlouposti , ale s cpp teprve zacinam. myslel jsi to teda cca takhle ? :

v konstruktoru tridy:
double u=-1;  
*data=&u;
a pak v destruktoru tridy
if ( *data < 0 ) 
delete [] data;
20.8.2008 01:27 Jirka P.
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
Ne. data je ukazatel, dá se použít jako hodnota. Když je 0, je prázdný. Takže v konstruktoru

data=0;

v destruktoru

delete [] data;

alokace (pozn. není exception-safe)

delete[] data; data=new double[2];

použití

if(data) use_data;

Pokud alokace selže, vyhodí výjimku.
Luboš Doležel (Doli) avatar 20.8.2008 01:35 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
Pokud alokace selže, vyhodí výjimku.
Což se dá změnit použitím new (nothrow) nebo použitím set_new_handler().
menphis avatar 20.8.2008 02:09 menphis | skóre: 22 | blog: menphis_blog
Rozbalit Rozbalit vše Re: C++ test na existenci dynamicky alokovane promenne
dik...

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267   www.czech-server.cz
© 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.