DevProTalk

DevProTalk (http://www.devprotalk.com/index.php)
-   Programiranje (http://www.devprotalk.com/forumdisplay.php?f=23)
-   -   Managed C++ (http://www.devprotalk.com/showthread.php?t=7823)

dee 31. 08. 2009. 12:06

Managed C++
 
Na jedno pitanje nikako da si u glavi poslozim odgovor pa ako tko ima kakvo smisleno objasnjenje, nek podijeli.

Dakle, zasto bi itko pozelio pisati managed C++?

Gruja 31. 08. 2009. 12:24

To je najbrži put ako imaš puno već napisanog C++ koda koji hoćeš da integrišeš u neki .Net projekat.
Drugi razlog je ako hoćeš nešto više da radiš direktno sa Win API-jem, za stvari koje nisu pokrivene framework-om. Može to i iz drugih managed jezika ali ovde već imaš gotove WINAPI strukture, samo uključiš odgovarajući header.

dee 31. 08. 2009. 14:54

Koliko sam ja shvatio Windows Interop Services omogucavaju i koristenje unmanaged koda unutar managed okoline. Zasto onda ne koristiti to (pogotovo za kod koji je vec napisan)?

DejanVesic 31. 08. 2009. 15:35

Prosto, dobijaš najbolje od oba sveta. Ako si iskusan C++ programer, onda:

- možeš iskoristiti postojeći source kao osnovu kao i tvoje znanje jezika
- dobijaš prednosti .Net sveta (garbage collection, assembly management, bolji security model, više deployment opcija, gomilu gotovih biblioteka itd)

Naravno, ovo ako treba da praviš / učestvuješ u .Net projektu koji nije heavy orijentisan na IO / device drivers - iako ti možeš da ovo radiš i u .Net-u, prelazak između granica managed / Win32 je prosto previše skup.

dee 31. 08. 2009. 18:04

Pitanje se zapravo rodilo jer pisati C++ za managed okolinu zvuci kao pucati si u nogu jer unmanaged kod moze postojati i sam za sebe, a istovremeno moze biti i koristen iz managed okoline.

Drugim rijecima, nije li pisanje C++ koda za .NET limitirano na ono sto framework moze? Samim tim i redukcija mogucnosti C++? A istovremeno, iz frameworka se moze koristiti unmanaged eksterni kod normalno pa mi je tesko zamisliti slucaj gdje bi managed C++ imao svrhu jer, ako se i radi ovo sto pricas (IO & so) onda ni sam .NET nije najbolji izbor. Ili?

(Ovo ne tvrdim vec pitam posto nemam iskustva a zvuci mi nelogicno)

DejanVesic 31. 08. 2009. 18:26

Kao što rekoh - ako se radi u okviru .Net projekta nešto u C++ (iz bilo kog razloga) a da pritom taj kod ne pristupa low-level stvarima (hardver), potpuno ima smisla raditi u managed C++. Pri tom, kada kažem "low-level" baš mislim na hardver, a ne na File IO (koji sasvim lepo radi i u .Net Frameworku).

Ako se pak radi na low-level stvarima i van .Net projekta - onda unmanaged C++

Da je jedno od dva rešenja bolje (unmanaged / managed C++), ono drugo ne bi ni postojalo :-)

Jezik / framework biraš prema problemu koji rešavaš i prema znanju onog ko problem treba da reši.

dee 31. 08. 2009. 18:36

Mozes li navesti neki konkretan primjer gdje bi bilo bolje unutar .NET projekta koristiti managed C++, a da to ne bi bilo moguce/dobro izvesti pozivanjem unmanaged koda iz .NET projekta? I, naravno, zasto ne tako?

DejanVesic 31. 08. 2009. 20:41

Hm, hajde da probam opet:

- ako imam programera koji zna C++
- ako je projekat (ostatak projekta) u .Net Frameworku
- ako se ne pristupa direktno hardveru

ONDA

- će programer raditi u managed C++

JER

- je pozivanje preko InterOp-a (WIN32) SKUPO i u datom slučaju POTPUNO NEPOTREBNO.

Pozdrav,
Dejan

Dragi Tata 01. 09. 2009. 16:02

Evo primera: Imaš 10 godina staru C++ aplikaciju (npr sa MFC-om) koja lepo vrši posao i nema nikakvog smisla da se raspiše od početka u C#u, ali treba da koristiš nove .NET komponente (bilo iz frejmvorka ili 3rd party). Možeš da koristiš recimo COM za to, a možeš i C++/CLI. Ovaj drugi pristup ume da bude daleko lakši i prijatniji, posebno ako treba da debuguješ nešto.

dee 04. 09. 2009. 13:11

Sad je jasnije.

Hvala.


Vreme je GMT +2. Trenutno vreme je 03:55.

Powered by vBulletin® Verzija 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Copyright © DevProTalk. All Rights Reserved.

Mišljenja, saveti, izjave, ponude ili druge informacije ili sadržaji nastali na Sajtu su vlasništvo onoga ko ih je kreirao, a ne DevProTalk.com, tako da ne morate da se oslanjate na njih.
Autori poruka su jedini odgovorni za ovakve sadržaje. DevProTalk.com ne garantuje tačnost, kompletnost ili upotrebnu vrednost informacija, stavova, saveta ili datih izjava. Ne postoje uslovi pod kojima bi mi bili odgovorni za štetu ili gubitak koji je posledica bilo čijeg oslanjanja na nepouzdane informacije, ili bilo kakve informacije nastale kroz komunikaciju između registrovanih članova.
Web sajt može sadržavati linkove na druge web sajtove na Internetu ili neke druge sadržaje. Ne kontrolišemo niti podržavamo te druge web sajtove, niti smo pregledali bilo kakve sadržaje na takvim sajtovima. Mi nećemo biti odgovorni za legalnost, tačnost ili prikladnost bilo kog sadržaja, oglasa, proizvoda, usluga ili informacije lociranim na ili distribuiranih kroz druge web sajtove, niti za bilo kakvu štetu nastalu kao posledica takvih informacija. DevProTalk.com drži i čuva druga prava vlasništva na web sajtu. Web sajt sadrže materijale zaštićene copyright-om, zaštitne znakove i druge informacije o pravu vlasništva ili softver. Članovi mogu poslatu informacije zaštićene pravima vlasništva njihovih nosilaca i ona ostaju zaštićena bez obzira da li su oni koji prenose te informacije to naveli ili ne. Osim informacija koje su u javnom vlasništvu ili za koje dobijete dozvolu, nemate pravo da kopirate, modifikujete ili na bilo koji način menjate, objavljujete, prenosite, distribuirate, izvršavate, prikazujete ili prodajte bilo koju informaciju zaštićenu pravima vlasništva. Slanjem informacija ili sadržaja na bilo koji deo DevProTalk.com, Vi automatski dozvoljavate i predstavljate garanciju da imate pravo da dozvolite DevProTalk.com ili članovima DevProTalk.com bespovratnu, kontinualnu, neograničenu, globalnu dozvolu da koriste, kopiraju, izvršavaju, prikazuju i distribuiraju takve informacije i sadržaje i da iz takvih sadžaja koriste bilo koji deo u bilo koje svrhe, kao i pravo i dozvolu da koriste gore navedene sadržaje. Svi zaštitni znakovi (trademarks), logotipi, oznake usluga, firme ili imena proizvoda koji se pominju na ovom web sajtu su vlasništvo kojim raspolažu njihovi vlasnici.