Jak fungují řetězce (String) – Visual Basic – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Jak fungují řetězce (String) – Visual Basic – Fórum – Programujte.comJak fungují řetězce (String) – Visual Basic – Fórum – Programujte.com

 

Kartik
~ Anonymní uživatel
41 příspěvků
22. 5. 2016   #1
-
0
-

Chtěl bych vědět co se děje na pozadí VBA, když dojde třeba na přiřazení řetězce.

dim retezec as string
dim retezec2 as string
retezec="aaa"
retezec2="bbbbbb"
retezec = retezc2

Moje představa je, že se nejdřív uvolní paměť proměnné retezec, aby nezůstal navždy v paměti a pak se předá ukazatel na nový řetězec, nebo je to jinak? Řetězce ve VBA jsou typu BSTR, BSTR je ukazatel na data řetězce, která jsou (aspoň v mojí knihovně) uložené na hromadě přes new... Taky jestli se VBA při rušení řetězce postará a smazaní toho co bylo alokováno přes new, což jsou všechny data toho BSTR (prefix, data, terminator)?

Nahlásit jako SPAM
IP: 90.178.131.–
Kit+15
Guru
22. 5. 2016   #2
-
0
-

#1 Kartik
O dealokaci stringu a související defragmentaci paměti se postará až Garbage Collector.

Nahlásit jako SPAM
IP: 194.228.13.–
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
BDS+3
Věrný člen
22. 5. 2016   #3
-
0
-

#1 Kartik
String je immutable, takže se to chová trochu zvláštně. Tady to docela pěkně vysvětlují sice pro javu, ale princip bude stejný.

Nahlásit jako SPAM
IP: 185.69.69.–
W11 :)
Kartik
~ Anonymní uživatel
41 příspěvků
22. 5. 2016   #4
-
0
-

Jde mě o to VBAčko, kde se uvolňování děje aniž to mohu ovlivnit... Ať už to tedy funguje jak chce, tak hlavní je teď pro mě, jestli to správně uvolní i řetězec, který pochází z mojí dll knihovny, nebo jestli se o jeho zrušení musím postarat taky já. Jestli v tom VBAčko nevidí rozdíl odkud řetězec pochází, nebo jestli musí být nějak speciálně alokovaný...

Nevim jak přesně funguje Garbage Collector, ale tedy nejspíš sníží počet referencí a pokud je počet 0, tak to tu paměť až se mu zachce uvolní?

Nahlásit jako SPAM
IP: 90.178.131.–
Kit+15
Guru
22. 5. 2016   #5
-
0
-

#4 Kartik
Je to navržreno tak, aby ses o dealokaci vůbec nemusel starat. Stačí opustit scope, string se stane nedostupným a časem je zlikvidován.

Jen si dávej pozor, abys v cyklu nepřidával na konec stringu znak po znaku, protože při každé takové operaci se vytváří nový string a ten původní se zahodí. U delších stringů je to pak dost neefektivní.

Nahlásit jako SPAM
IP: 194.228.13.–
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
Kartik
~ Anonymní uživatel
41 příspěvků
23. 5. 2016   #6
-
0
-

#5 Kit
Takže ještě pro jistotu, ať už tedy vytvořim ten řetězec kdekoliv mimo VBA, tak se o něj VBA postará?

Jo tohle jsem před časem řešil.. udělat na začátku dostatečně dlouhý řetězec a pak tam vepisovat ty kratší je o dost rychlejší. Teď právě kvůli operacím s řetězci dělam knihovnu v C++.

Nahlásit jako SPAM
IP: 90.178.131.–
Kit+15
Guru
23. 5. 2016   #7
-
0
-

#6 Kartik
A proč děláš takové vylomeniny?

Nahlásit jako SPAM
IP: 194.228.13.–
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
BDS+3
Věrný člen
23. 5. 2016   #8
-
0
-

#6 Kartik
a co zkusit StringBuilder?

Nahlásit jako SPAM
IP: 94.113.253.–
W11 :)
Kartik
~ Anonymní uživatel
41 příspěvků
23. 5. 2016   #9
-
0
-

#7 Kit
Tak jednak se snažím přejít na C++, navíc ten kód je použitelnej jak ve VBA tak v C a mělo by to i běhat rychlejš než kdyby to bylo čistě ve VBA, alespoň ty místa kde to nejvíc drhne přepisuju do C. Další věc co mě na VBAčku štve, je že nejde kompilovat a zdrojový kód nejde zabezpečit, heslo je tam spíš jen tak na okrasu.

Nahlásit jako SPAM
IP: 90.178.131.–
Kartik
~ Anonymní uživatel
41 příspěvků
23. 5. 2016   #10
-
0
-

#8 BDS
Neznám a jak mi to pomůže?

Nahlásit jako SPAM
IP: 90.178.131.–
Kit+15
Guru
23. 5. 2016   #11
-
0
-

#9 Kartik
Předčasná optimalizace je kořenem všeho zla.

Nahlásit jako SPAM
IP: 194.228.13.–
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
Kit+15
Guru
23. 5. 2016   #12
-
0
-

#10 Kartik
Dělá totéž, co se snažíš pytlíkovat v C++, ale nemusíš přitom opouštět VBA.

Nahlásit jako SPAM
IP: 194.228.13.–
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
BDS+3
Věrný člen
24. 5. 2016   #13
-
+1
-
Zajímavé
Kit +

#10 Kartik
V podstatě to funguje jako pole znaků, takže je to ideální pro modifikaci textových řetězců. Na rozdíl od stringu se při editaci nezakládá vždy nový objekt (dokud nepřekročíš jeho kapacitu). Více..

Nahlásit jako SPAM
IP: 185.69.69.–
W11 :)
Kartik
~ Anonymní uživatel
41 příspěvků
24. 5. 2016   #14
-
0
-

#13 BDS
Ale já potřebuju ten BSTR dostat do VBA, ve kterém je to jediný typ pro řetězce. Problém není s operacemi s řetězcem. Třeba nevim proč, nebo jaký je rozdíl mezi řetězcem vytvořeným přes SysAllocString nebo pokud ho vytvořím binárně... následně SysFreeString funguje jen ty vytvořené přes funkci, otázka je tedy jak ten řetězec uvolňuje VBA.

Nahlásit jako SPAM
IP: 90.182.189.–
Kit+15
Guru
24. 5. 2016   #15
-
0
-

#14 Kartik
Proč se tímto vůbec zabýváš? Pokud tu aplikaci napíšeš správně v tom VBA, tak nemůžeš mít žádné potíže s výkonem na stringových operacích.

Nahlásit jako SPAM
IP: 194.228.13.–
Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
Kartik
~ Anonymní uživatel
41 příspěvků
24. 5. 2016   #16
-
0
-

Hlavně proto, že když napíšu nějaké základní funkce, které nadále používám skoro ve všem co dělám, tak je mohu použít jak ve VBA tak v C, místo toho abych se pak se vším do C přepisoval a psal tedy vše 2x. O dalších výhodách jsem psal už výše.

Ano s řetězci až tak zásadní problém s výkonem není, ten je spíš až při práci s geometrií, jen jsem chtěl začít s něčím snadným.

Nahlásit jako SPAM
IP: 90.182.189.–
BDS+3
Věrný člen
24. 5. 2016   #17
-
0
-

Já v tom případě stále nechápu, co Ti nefunguje.

Zatím, jsem to pochopil tak, že máš nějakou aplikaci, kterou píšeš ve VBA a do ní importuješ funkci, vracející pointer na řetězec BSTR z dll knihovny, kterou píšeš v C++. Chápu to správně?

Pokud ano, tak se  podle mě, o uvolnění řetězce, který si v dll alokoval, se musíš postarat v dll. Případně můžeš zavolat funkci v dll, která se postará o uvolnění paměti. Každopádně aplikace, nemůže vědět co funkce v dll alokují, pokud jí to nezdělíš. Obvykle se dll předává v parametrech funkce pointer na již alokovaný prostor a jeho velikost a dll do tohoto prostoru zapíše výsledek (u řetězců v .NET to bývá většinou zmíněný StringBuilder, nebo pole).

ps, tím jak pracuje GC bych se nezabýval, protože se domnívám, že to nebude jen o tom, že něco co již program nepotřebuje, to ihned smaže. Předpokládám, že tu budou hrát roli aktuální stav a vytíženost paměti, povaha aplikace atd.

Nahlásit jako SPAM
IP: 185.69.69.–
W11 :)
BDS+3
Věrný člen
24. 5. 2016   #18
-
0
-

Ikdyž teď mě napadá, že pomocí bstr předáš i délku, a importuješ pomocí "Marshalu" tak by se vlastně o likvidaci mohla postarat i VBA aplikace... Tohle nevím.

Nahlásit jako SPAM
IP: 185.69.69.–
W11 :)
Kartik
~ Anonymní uživatel
41 příspěvků
24. 5. 2016   #19
-
0
-

#17 BDS
Ano chápeš to správně. Jde mě o to jestli právě to VBA nějak rozliší co si alokovalo samo a to co přišlo odjinud, nebo jestli to zruší úplně stejně, nebo jak to udělat, aby se k tomu chovalo jako ke svému.

A vy co tomu rozumíte, tak jak jsem psal zrovna u těch řetězců je funkce SysAllocString, řetězec z té funkce se uvolňuje zas přes SysFreeString a podobně je spousta jiných funkcí, kde jedna vytváří a další ruší. Vrtá mě hlavou co zrovna v tomto, nebo jiných případech ta funkce udělá, že ta rušící funkce pozná, odkud jsou ta samá data, to znamená, že pokud nejsou vytvořena pomocí funkce, tak mazací funkce hlásí chybu.

Nahlásit jako SPAM
IP: 90.178.131.–
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 7 hostů

Moderátoři diskuze

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý