La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

Bonnes pratiques C++11 avec Visual C++

Présentations similaires


Présentation au sujet: "Bonnes pratiques C++11 avec Visual C++"— Transcription de la présentation:

1

2 Bonnes pratiques C++11 avec Visual C++
Loïc Joly - CAST Christophe Pichaud - Sogeti

3 Donnez votre avis ! Depuis votre smartphone sur : De nombreux lots à gagner toute les heures !!! Claviers, souris et jeux Microsoft… Merci de nous aider à améliorer les Techdays ! Slide obligatoire. Ne pas effacer.

4 performance compatibility portability

5 Plan Visual C++ 2013 November 2013 CTP Guide de survie en C++11
Interop WinRT

6 Visual C++ 2013 C++11 : C11 : Meilleur support
Le contenu du November 2012 CTP (voir Développer en natif avec C++11 =default, =delete, NSDI, greater<>, make_unique… C11 : Meilleur support _Bool, déclaration au milieu de bloc, designated initializer… Des retouches d’IHM (formatage du code…)

7 November 2013 CTP CTP = version beta. Installable sans danger. C++ 11
Génération des fonctions spéciales de déplacement, & and && for *this Initialisation thread safe des variables statiques Inheriting constructors alignof/alignas, __func__, Extended sizeof constexpr (partiel : Pas les fonctions membre) noexcept (partiel : Pas la version conditionelle) C++14 decltype(auto), auto function return type deduction generic lambdas (partiel : Liste de capture explicite uniquement) Autre Resumable functions and await

8 Guide de survie EN C++11 Autour de la sémantique de déplacement

9 Intérêt de déplacer Copie Déplacement
La destination vaut la valeur qu’avait la source initialement La source est inchangée On peut continuer à utiliser la source Fournit la strong exception guarantee Plus lent La destination vaut la valeur qu’avait la source initialement On se moque de l’état de la source, tant qu’il est viable On va éviter d’utiliser la source par la suite Ne fournit que la basic exception guarantee …mais peut souvent être noexcept Plus rapide

10 Comment ça marche ? Lvalue (ça possède un nom, on peut en prendre l’adresse) et Rvalue (le reste) On peut surcharger une fonction là-dessus int f(maClasses const &c); // Version pour les Lvalues int f(maClasses &&c); // Version pour les Rvalues Dans la seconde version, comme on sait qu’on est les seuls à accéder à l’objet, on a le droit d’être destructif

11 Comment rendre nos classes déplaçables
Constructeur et affectation par déplacement MaClasse(MaClasse &&c); MaClasse &operator=(MaClasse &&c); Pas générés automatiquement si un destructeur ou constructeur de copie est défini Empêche la génération automatique d’un constructeur de copie Règle des 5 (ou règle des 0 !)

12 Quelques conseils sur les classes déplaçables
Si possible, rendre les opérations de déplacement noexcept, et le déclarer Utiliser une macro en attendant un meilleur support de VC++ Réfléchir à l’état d’un objet depuis lequel il y a eu déplacement Préférez la règle des 0 à la règle des 5 Utiliser des classes RAII pour gérer vos données, comme [shared/unique]_ptr Éviter new et delete !

13 Utiliser dans l’ordre de préférence
Un type à sémantique de valeur (string, vector, map, optional…) Des pointeurs à propriété unique (unique_ptr / T* observant (observer_ptr ?) Des pointeurs à propriété partagée (shared_ptr/weak_ptr)

14 Universal references Notion pédagogique inventée pas Scott Meyers
T&& dans un contexte où T est déduit  Universal reference Selon la manière dont on instanciera, une universal reference deviendra : Une Lvalue reference si T est une Lvalue Une Rvalue reference si T est une Rvalue Idéal pour transmettre des arguments à l’aide de std::forward On n’a pas forcément le droit de toucher à la source ! Fonctionne souvent assez mal avec la surcharge (car peut déjà tout prendre en charge)

15 Transmettre des arguments
La fonction va : On utilise : Et pour transmettre: Utiliser la donnée Ex: ofstream::open void f(T const &t); ou void f(T &t); g(t) Dupliquer la donnée Ex: vector::push_back void f(T t); g(std::move(t)) void f(T&& t); Transmettre une donnée dont on ne sait rien Ex: make_shared template <class T> void f(T &&t); g(std::forward<T>(t))

16 Et avec des pointeurs intelligents ?
Pour Utiliser Une fonction manipulant uniquement l’objet pointé void f(T& t); void f(T *t); // Si l’objet peut ne pas exister void f(observer_ptr<T> t); // au lieu de T* ? Une fonction prenant propriété d’un objet géré par shared_ptr void f(shared_ptr<T> t); Une fonction prenant la propriété unique d’un objet géré par pointeur void f(unique_ptr<T> t); Le reste Plus rare…

17 Interop WinRT

18 Conception de composants WinRT
C# / VB C++/CX C++ avec WRL

19 Pourquoi faire des composants WinRT en C++
Performance Gestion batterie Protection contre la décompilation Accès à Win32 Code existant

20 Scénarios d’applications C++ hybrides
Interface HTML/JS Interface C#/VB Interface C++ Composants WinRT C++ Composants WinRT C++ Composants WinRT C#/VB

21 Le nouveau modèle de composants WinRT
Windows 8 utilise des composants COM il existe l’interface IUnknown mais aussi IInspectable Ces composants COM sont nommés WinRT Il existe deux manières de coder C++/CX qui sont des extensions du compilateur C++ Standard avec WRL : Windows Runtime Library WRL est inspirée de la librairie ATL

22 Un composant WinRT C’est un composant COM
Il expose des metadata (.winmd) Il utilise les types Windows spécifiques Link avec RuntimeObject.lib Ne tourne que sous Windows 8.x *En mode Desktop En mode Store App

23 La librairie WRL Les entêtes sont définies dans
C:\Program Files (x86)\Windows Kits\8.1\Include\winrt\wrl async.h client.h def.h event.h ftm.h implements.h internal.h module.h wrappers\corewrappers.h

24 Un composant WRL Simple
import "inspectable.idl"; import "Windows.Foundation.idl"; #define COMPONENT_VERSION 1.0 namespace Library1 { interface ILogger; runtimeclass Logger; [uuid(3EC4B4D6-14A6-4D0D-BB96-31DA25224A15), version(COMPONENT_VERSION)] interface ILogger : Iinspectable { [propget] HRESULT Name([out, retval] HSTRING* value); [propput] HRESULT Name([in] HSTRING value); HRESULT LogInfo([in] HSTRING value); HRESULT GetInt32([out] int * pValue); } [version(COMPONENT_VERSION), activatable(COMPONENT_VERSION)] runtimeclass Logger [default] interface ILogger; #include "Library1_h.h" namespace ABI { namespace Library1 { class Logger : public RuntimeClass<ILogger> { InspectableClass(L"Library1.Logger", BaseTrust) public: STDMETHOD(get_Name)(HSTRING* value); STDMETHOD(put_Name)(HSTRING value); STDMETHOD(LogInfo)(HSTRING value); STDMETHOD(GetInt32)(int * pValue); private: std::wstring name; }; ActivatableClass(Logger); }

25 Un composant COM WRL import "ocidl.idl"; #define COMPONENT_VERSION 1.0 [uuid(3AAF07AA-A699-4E7C-8F01-BFF237D22B1B), version(COMPONENT_VERSION)] interface ILogger : IUnknown { HRESULT LogInfo([in] BSTR bstrMessage); } [uuid(F15D3912-E8B8-40C8-8CF3-354F0B8B93CC), version(COMPONENT_VERSION)] library WRLCOMLibrary1 [uuid(75DB8F5A-F13F-4E16-A487-9CD26A874654), version(COMPONENT_VERSION)] coclass Logger [default] interface ILogger; #include "Library1_h.h" class Logger : public RuntimeClass<RuntimeClassFlags<ClassicCom>, ILogger> { public: STDMETHOD(LogInfo)(BSTR value); };

26 WRL et COM Attention WRL ne fournit pas de support pour
IDispatch et les interfaces dual, les connections points L’enregistrement automatique du module Il faut le faire manuellement avec un .reg Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\Wow6432Node\CLSID\{75DB8F5A-F13F-4E16-A487-9CD26A874654}] @="Logger Class" [HKEY_CLASSES_ROOT\Wow6432Node\CLSID\{75DB8F5A-F13F-4E16-A487-9CD26A874654}\InprocServer32] @="C:\\dev\\Store\\App1\\Debug\\WRLCOMLibrary1Dll.dll" "ThreadingModel"="Apartment" [HKEY_CLASSES_ROOT\Wow6432Node\CLSID\{75DB8F5A-F13F-4E16-A487-9CD26A874654}\Programmable] [HKEY_CLASSES_ROOT\Wow6432Node\CLSID\{75DB8F5A-F13F-4E16-A487-9CD26A874654}\TypeLib] @="{F15D3912-E8B8-40C8-8CF3-354F0B8B93CC}" [HKEY_CLASSES_ROOT\Wow6432Node\CLSID\{75DB8F5A-F13F-4E16-A487-9CD26A874654}\Version] @="1.0“

27 WRL et les méthodes Async
Exemple de méthode dans la classe Root: Windows.Foundation.IAsyncOperation<ILogger> GetLoggerAsync(); Exemple de client XAML C#: private async void Button_Click(object sender, RoutedEventArgs e) { Library1.Root root = new Root(); Library1.ILogger ilogger = await root.GetLoggerAsync(); ilogger.LogInfo("log me !"); }

28 Un composant WRL et les méthodes Async
interface IRoot; runtimeclass Root; [uuid(3EC4B4D6-14A6-4D0D-BB96-31DA25224A16), version(COMPONENT_VERSION)] interface IRoot : IInspectable { HRESULT GetLoggerAsync([out][retval] Windows.Foundation.IAsyncOperation<ILogger*>** value); } [version(COMPONENT_VERSION), activatable(COMPONENT_VERSION)] runtimeclass Root [default] interface IRoot;

29 Le composant WRL avec une méthode Async
#include "Library1_h.h" namespace ABI { namespace Library1 { class Root : public RuntimeClass<IRoot> { InspectableClass(L"Library1.Root", BaseTrust) public: STDMETHOD(GetLoggerAsync)(Windows::Foundation::IAsyncOperation<ILogger*>** value); }; ActivatableClass(Logger); } Il faut maintenant implémenter cette interface C:\Program Files (x86)\Windows Kits\8.1\Include\winrt windows.foundation.collections.h

30 La routine GetLoggerAsync()
namespace ABI { namespace Library1 { STDMETHODIMP Root::GetLoggerAsync(Windows::Foundation::IAsyncOperation<ILogger*>** value) { ComPtr<task_based_async_operation<ILogger>> pObject = Make<task_based_async_operation<ILogger>>( std::async([&]() -> ILogger* ComPtr<Logger> p = Make<Logger>(); return p.Detach(); })); *value = pObject.Detach(); return S_OK; } La magie est contenue dans la classe task_based_async_operation via PPL Tasks.

31 WRL et les Collections Exemple de méthode dans la classe Root:
Windows.Foundation.Collections::IVector<HSTRING> Getvector(); Exemple de client XAML C#: private async void Button_Click(object sender, RoutedEventArgs e) { Library1.Root root = new Root(); IList<string> list = root.GetVector(); foreach (string s in list) { … } }

32 Un composant WRL et les collections
interface IRoot; runtimeclass Root; [uuid(3EC4B4D6-14A6-4D0D-BB96-31DA25224A16), version(COMPONENT_VERSION)] interface IRoot : IInspectable { HRESULT GetVector([out][retval] Windows.Foundation.Collections.IVector<HSTRING>** value); } [version(COMPONENT_VERSION), activatable(COMPONENT_VERSION)] runtimeclass Root [default] interface IRoot;

33 Le composant WRL avec les collections
#include "Library1_h.h" namespace ABI { namespace Library1 { class Root : public RuntimeClass<IRoot> { InspectableClass(L"Library1.Root", BaseTrust) public: STDMETHOD(GetVector)(Windows::Foundation::Collections::IVector<HSTRING>** value); }; ActivatableClass(Logger); } Il faut maintenant implémenter cette interface C:\Program Files (x86)\Windows Kits\8.1\Include\winrt windows.foundation.collections.h

34 La routine GetVector()
namespace ABI { namespace Library1 { STDMETHODIMP Root::GetVector(Windows::Foundation::Collections::IVector<HSTRING>** value) { ComPtr<Vector<HSTRING>> v = Make<Vector<HSTRING>>(); HString str; str.Set(L"String1"); v->Append(str.Detach()); str.Set(L"String2"); str.Set(L"String3"); *value = v.Detach(); return S_OK; } La magie est contenue dans la classe Vector via std::vector<T>.

35 WRL et les opérations asynchrones
Support en C++/CX via les ‘PPL Taks’ IAsyncOperation<int>^ CalculateAnswer() { return concurrency::create_async([]() -> int { // faire une opération longue ici… return 42; }); } IAsyncOperation<String^>^ CalculateQuestion() { return create_async([]() -> String^ { return ref new String(L“Hello IAsyncOperation<T>…"); }); }

36 Conclusion

37 Juin 2013

38 C/C++ French user group : cpp-frug@googlegroups.com

39

40 Grosse partie Sous titre

41 Titre et contenu Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

42 Titre seul

43 Exemple de graphs

44 Titre et 2 colonnes Colonne 1 Colonne 2

45 Titre comparaison Elément 1 Elément 2 Paramètre 1 Paramètre 2

46 Slide avec code Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.

47 NOM démo Sous titre démo

48 Titre vidéo Sous titre

49


Télécharger ppt "Bonnes pratiques C++11 avec Visual C++"

Présentations similaires


Annonces Google