.NET Core - Guida rapida

.NET Core è l'ultima piattaforma di sviluppo generica gestita da Microsoft. Funziona su piattaforme diverse ed è stato riprogettato in modo da rendere .NET veloce, flessibile e moderno. Questo sembra essere uno dei principali contributi di Microsoft. Gli sviluppatori possono ora creare applicazioni Android, iOS, Linux, Mac e Windows con .NET, il tutto in Open Source.

In questo tutorial tratteremo .NET Core e alcune nuove innovazioni tra cui gli aggiornamenti di .NET Framework, .NET Standard e gli aggiornamenti della piattaforma Windows universale, ecc.

Caratteristiche di .NET Core

Di seguito sono riportate le caratteristiche principali di .NET Core:

Open source

  • .NET Core è un'implementazione open source, che utilizza licenze MIT e Apache 2.

  • .NET Core è un progetto .NET Foundation ed è disponibile su GitHub.

  • In quanto progetto open source, promuove un processo di sviluppo più trasparente e promuove una comunità attiva e impegnata.

Cross-platform

  • L'applicazione implementata in .NET Core può essere eseguita e il relativo codice può essere riutilizzato indipendentemente dalla destinazione della piattaforma.

  • Attualmente supporta tre principali sistemi operativi (OS)

    • Windows

    • Linux

    • MacOS

  • I sistemi operativi (OS) supportati, le CPU e gli scenari applicativi cresceranno nel tempo, forniti da Microsoft, altre società e individui.

Distribuzione flessibile

  • Possono esserci due tipi di distribuzioni per le applicazioni .NET Core:

    • Distribuzione dipendente dal framework

    • Distribuzione autonoma

  • Con la distribuzione dipendente dal framework, l'app dipende da una versione a livello di sistema di .NET Core in cui sono installate l'app e le dipendenze di terze parti.

  • Con la distribuzione autonoma, anche la versione .NET Core usata per creare l'applicazione viene distribuita insieme all'app e alle dipendenze di terze parti e può essere eseguita fianco a fianco con altre versioni.

Strumenti della riga di comando

  • Tutti gli scenari del prodotto possono essere utilizzati dalla riga di comando.

Compatibile

  • .NET Core è compatibile con .NET Framework, Xamarin e Mono, tramite la libreria .NET Standard

Modulare

  • .NET Core viene rilasciato tramite NuGet in pacchetti di assembly più piccoli.

  • .NET Framework è un grande assembly che contiene la maggior parte delle funzionalità principali.

  • .NET Core è disponibile come pacchetti più piccoli incentrati sulle funzionalità.

  • Questo approccio modulare consente agli sviluppatori di ottimizzare la loro app includendo solo quei pacchetti NuGet di cui hanno bisogno nella loro app.

  • I vantaggi di una superficie di app più piccola includono una maggiore sicurezza, assistenza ridotta, prestazioni migliorate e costi ridotti in un modello pay-per-what-you-use.

La piattaforma .NET Core

.NET Core Platform contiene le seguenti parti principali:

  • .NET Runtime - Fornisce un sistema di tipi, caricamento di assembly, un garbage collector, interoperabilità nativa e altri servizi di base.

  • Fundamental Libraries - Un set di librerie di framework, che forniscono tipi di dati primitivi, tipi di composizione di app e utilità fondamentali.

  • SDK & Compiler - Un set di strumenti SDK e compilatori di linguaggi che consentono l'esperienza dello sviluppatore di base, disponibile in .NET Core SDK.

  • ‘dotnet’ app host- Viene utilizzato per avviare le app .NET Core. Seleziona il runtime e ospita il runtime, fornisce un criterio di caricamento degli assembly e avvia l'app. Lo stesso host viene utilizzato anche per avviare gli strumenti SDK più o meno allo stesso modo.

In questo capitolo, discuteremo le varie dipendenze che è necessario distribuire ed eseguire. Questi includono le applicazioni .NET Core su macchine Windows sviluppate utilizzando Visual Studio.

Versioni di Windows supportate

.NET Core è supportato nelle seguenti versioni di Windows:

  • Windows 7 SP1
  • Windows 8.1
  • Windows 10
  • Windows Server 2008 R2 SP1 (server completo o Server Core)
  • Windows Server 2012 SP1 (server completo o Server Core)
  • Windows Server 2012 R2 SP1 (server completo o Server Core)
  • Windows Server 2016 (Full Server, Server Core o Nano Server)

Dipendenze

  • Se esegui la tua applicazione .NET Core su versioni di Windows precedenti a Windows 10 e Windows Server 2016, richiederà anche Visual C ++ Redistributable.

  • Questa dipendenza viene installata automaticamente se si utilizza il programma di installazione .NET Core.

  • È necessario installare manualmente Visual C ++ Redistributable per Visual Studio 2015 se si installa .NET Core tramite lo script di installazione o si distribuisce un'applicazione .NET Core autonoma.

  • Per i computer Windows 7 e Windows Server 2008, è necessario assicurarsi che l'installazione di Windows sia aggiornata e includa anche l'hotfix KB2533623 installato tramite Windows Update.

Prerequisiti con Visual Studio

  • Per sviluppare applicazioni .NET Core usando .NET Core SDK, puoi usare qualsiasi editor di tua scelta.

  • Tuttavia, se desideri sviluppare applicazioni .NET Core su Windows utilizzando Visual Studio, puoi utilizzare le due versioni seguenti:

    • Visual Studio 2015

    • Visual Studio 2017 RC

  • I progetti creati con Visual Studio 2015 saranno basati su project.json per impostazione predefinita, mentre i progetti creati con Visual Studio 2017 RC saranno sempre basati su MSBuild.

In questo capitolo, discuteremo la configurazione dell'ambiente di .NET Core. Si tratta di una riprogettazione significativa di .NET Framework. Per usare .NET Core nella tua applicazione, ci sono due versioni che puoi usare:

  • Visual Studio 2015
  • Visual Studio 2017 RC

Visual Studio 2015

Per utilizzare Visual Studio 2015, è necessario aver installato quanto segue:

  • Microsoft Visual Studio 2015 Update 3
  • Microsoft .NET Core 1.0.1 - Anteprima degli strumenti VS 2015 2

Microsoft fornisce una versione gratuita di visual studio che contiene anche SQL Server e può essere scaricata da https://www.visualstudio.com/en-us/downloads/download-visual-studio-vs.aspx e Microsoft .NET Core 1.0.1 - VS 2015 Tooling Preview 2 possono essere scaricati da https://www.visualstudio.com/downloads/

È inoltre possibile seguire le linee guida per l'installazione nel seguente URL https://www.microsoft.com/net/core/#windowsvs2017

Installazione di Visual Studio 2015

Segui questi passaggi per installare Visual Studio 2015 -

Step 1- Una volta completato il download, esegui il programma di installazione. Verrà visualizzata la seguente finestra di dialogo.

Step 2 - Fare clic su Install per avviare il processo di installazione.

Step 3 - Una volta completata l'installazione, vedrai la seguente finestra di dialogo.

Step 4 - Chiudi questa finestra di dialogo e riavvia il computer se necessario.

Step 5- Apri Visual Studio dal menu Start; riceverai la seguente finestra di dialogo. Potrebbero essere necessari alcuni minuti per caricare e finalmente essere utilizzato per la prima volta.

Step 6 - Una volta caricato, vedrai la seguente schermata.

Step 7 - Al termine dell'installazione di Visual Studio, chiudere Visual Studio e avviare Microsoft .NET Core - VS 2015 Tooling Preview 2.

Step 8 - Seleziona la casella di controllo e fai clic su Installa.

Step 9 - Una volta completata l'installazione, vedrai la seguente finestra di dialogo.

Ora sei pronto per avviare la tua applicazione usando .NET Core.

Visual Studio 2017

In questo tutorial useremo Visual Studio 2015, ma se vuoi usare Visual Studio 2017, una versione sperimentale degli strumenti .NET Core per Visual Studio è inclusa in Visual Studio 2017 RC e puoi vedere le linee guida per l'installazione qui https://www.microsoft.com/net/core/#windowsvs2017

Visual Studio 2015 fornisce un ambiente di sviluppo completo per lo sviluppo di applicazioni .NET Core. In questo capitolo creeremo un nuovo progetto all'interno di Visual Studio. Dopo aver installato gli strumenti di Visual Studio 2015, è possibile iniziare a creare una nuova applicazione .NET Core.

Nel New Project finestra di dialogo, nell'elenco Modelli, espandere il nodo Visual C # e selezionare .NET Core e dovresti vedere i seguenti tre nuovi modelli di progetto

  • Libreria di classi (.NET Core)
  • Applicazione console (.NET Core)
  • Applicazione Web ASP.NET Core (.NET Core)

Nel riquadro centrale della finestra di dialogo Nuovo progetto, selezionare Applicazione console (.NET Core) e denominarla "FirstApp", quindi fare clic su OK.

Visual Studio aprirà il progetto appena creato e vedrai nella finestra Esplora soluzioni tutti i file presenti in questo progetto.

Per verificare che l'applicazione console .NET core funzioni, aggiungiamo la seguente riga.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace FirstApp { 
   public class Program { 
      public static void Main(string[] args) { 
         Console.WriteLine("Hello guys, welcome to .NET Core world!"); 
      } 
   } 
}

Ora esegui l'applicazione. Dovresti vedere il seguente output.

.NET Core supporta l'integrale numerico standard e le primitive a virgola mobile. Supporta anche i seguenti tipi:

  • System.Numerics.BigInteger che è un tipo integrale senza limite superiore o inferiore.

  • System.Numerics.Complex è un tipo che rappresenta numeri complessi.

  • Un set di tipi di vettore abilitati SIMD (Single Instruction Multiple Data) nello spazio dei nomi System.Numerics.

Tipi integrali

.NET Core supporta interi con e senza segno di intervalli diversi da un byte a otto byte di lunghezza. Tutti i numeri interi sono tipi di valore.

La tabella seguente rappresenta i tipi integrali e la loro dimensione;

genere Firmato / Non firmato Dimensioni (byte) Valore minimo Valore massimo
Byte Non firmato 1 0 255
Int16 Firmato 2 −32.768 32.767
Int32 Firmato 4 −2.147.483.648 2.147.483.647
Int64 Firmato 8 −9.223.372.036.854.775.808 9.223.372.036.854.775.807
SByte Firmato 1 -128 127
UInt16 Non firmato 2 0 65.535
UInt32 Non firmato 4 0 4.294.967.295
UInt64 Non firmato 8 0 18.446.744.073.709.551.615

Ogni tipo integrale supporta un set standard di operatori aritmetici, di confronto, uguaglianza, conversione esplicita e conversione implicita.

È anche possibile lavorare con i singoli bit in un valore intero utilizzando la classe System.BitConverter.

Tipi in virgola mobile

.NET Core include tre tipi primitivi a virgola mobile, illustrati nella tabella seguente.

genere Dimensioni (byte) Valore minimo Valore massimo
Doppio 8 −1,79769313486232e308 1.79769313486232e308
Single 4 −3.402823e38 3.402823e38
Decimale 16 −79.228.162.514.264.337.593,5 43.950.335 79.228.162.514.264.337.593.543,9 50.335
  • Ogni tipo a virgola mobile supporta un set standard di operatori aritmetici, di confronto, di uguaglianza, di conversione esplicita e di conversione implicita.

  • È inoltre possibile lavorare con i singoli bit nei valori Double e Single utilizzando la classe BitConverter.

  • La struttura Decimal ha i propri metodi, Decimal.GetBits e Decimal.Decimal (Int32 ()), per lavorare con i singoli bit di un valore decimale, nonché il proprio set di metodi per eseguire alcune operazioni matematiche aggiuntive.

BigInteger

  • System.Numerics.BigInteger è un tipo immutabile che rappresenta un numero intero arbitrariamente grande il cui valore in teoria non ha limiti superiori o inferiori.

  • I metodi del tipo BigInteger sono strettamente paralleli a quelli degli altri tipi integrali.

Complesso

  • Il tipo System.Numerics.Complex rappresenta un numero complesso, ovvero un numero con una parte di numero reale e una parte di numero immaginario

  • Supporta un insieme standard di operatori aritmetici, di confronto, uguaglianza, conversione esplicita e conversione implicita, nonché metodi matematici, algebrici e trigonometrici.

SIMD

  • Lo spazio dei nomi Numerics include un set di tipi di vettore abilitati per SIMD per .NET Core.

  • SIMD consente di parallelizzare alcune operazioni a livello di hardware, il che si traduce in enormi miglioramenti delle prestazioni in app matematiche, scientifiche e grafiche che eseguono calcoli su vettori.

  • I tipi di vettore abilitati per SIMD in .NET Core includono quanto segue:

    • Tipi System.Numerics.Vector2, System.Numerics.Vector3 e System.Numerics.Vector4, che sono vettori a 2, 3 e 4 dimensioni di tipo Single.

    • La struttura Vector <T> che consente di creare un vettore di qualsiasi tipo numerico primitivo. I tipi numerici primitivi includono tutti i tipi numerici nello spazio dei nomi System ad eccezione di Decimal.

    • Due tipi di matrice, System.Numerics.Matrix3 × 2, che rappresenta una matrice 3 × 2; e System.Numerics.Matrix4 × 4, che rappresenta una matrice 4 × 4.

    • Il tipo System.Numerics.Plane, che rappresenta un piano tridimensionale, e il tipo System.Numerics.Quaternion, che rappresenta un vettore utilizzato per codificare rotazioni fisiche tridimensionali.

In questo capitolo tratteremo il concetto di Garbage collection, che è una delle caratteristiche più importanti della piattaforma di codice gestito .NET. Il Garbage Collector (GC) gestisce l'allocazione e il rilascio della memoria. Il garbage collector funge da gestore automatico della memoria.

  • Non è necessario sapere come allocare e rilasciare memoria o gestire la durata degli oggetti che utilizzano quella memoria

  • Viene effettuata un'allocazione ogni volta che si dichiara un oggetto con una parola chiave "nuova" o un tipo di valore è boxed. Le allocazioni sono in genere molto veloci

  • Quando la memoria non è sufficiente per allocare un oggetto, il GC deve raccogliere ed eliminare la memoria inutile per rendere disponibile la memoria per nuove allocazioni.

  • Questo processo è noto come garbage collection.

Vantaggi della raccolta dei rifiuti

Garbage Collection offre i seguenti vantaggi:

  • Non è necessario liberare memoria manualmente durante lo sviluppo dell'applicazione.

  • Alloca anche gli oggetti nell'heap gestito in modo efficiente.

  • Quando gli oggetti non vengono più utilizzati, recupererà quegli oggetti cancellandone la memoria e manterrà la memoria disponibile per allocazioni future.

  • Gli oggetti gestiti ottengono automaticamente contenuto pulito per iniziare, quindi i loro costruttori non devono inizializzare ogni campo dati.

  • Fornisce inoltre la sicurezza della memoria assicurandosi che un oggetto non possa utilizzare il contenuto di un altro oggetto.

Condizioni per la raccolta dei rifiuti

La raccolta dei dati obsoleti si verifica quando una delle seguenti condizioni è vera.

  • Il sistema ha poca memoria fisica.

  • La memoria utilizzata dagli oggetti allocati nell'heap gestito supera una soglia accettabile. Questa soglia viene regolata continuamente durante l'esecuzione del processo.

  • Il GC.Collectviene chiamato il metodo e in quasi tutti i casi non è necessario chiamare questo metodo, perché il garbage collector viene eseguito continuamente. Questo metodo viene utilizzato principalmente per situazioni e test unici.

Generazioni

.NET Garbage Collector ha 3 generazioni e ogni generazione ha il proprio heap che viene utilizzato per l'archiviazione degli oggetti allocati. C'è un principio di base secondo cui la maggior parte degli oggetti è di breve durata o di lunga durata.

Prima generazione (0)

  • Nella generazione 0, gli oggetti vengono prima allocati.

  • In questa generazione, gli oggetti spesso non vivono oltre la prima generazione, poiché non sono più in uso (fuori ambito) al momento della successiva raccolta di dati inutili.

  • La generazione 0 è veloce da raccogliere perché l'heap associato è piccolo.

Seconda generazione (1)

  • Nella prima generazione, gli oggetti hanno uno spazio della seconda possibilità.

  • Gli oggetti che hanno vita breve ma sopravvivono alla raccolta della generazione 0 (spesso basata su tempi casuali) passano alla generazione 1.

  • Anche le raccolte di prima generazione sono veloci perché anche l'heap associato è piccolo.

  • I primi due heap rimangono piccoli perché gli oggetti vengono raccolti o promossi all'heap di generazione successiva.

Terza generazione (2)

  • Nella seconda generazione, tutti gli oggetti lunghi sono vissuti e il suo mucchio può diventare molto grande.

  • Gli oggetti di questa generazione possono sopravvivere a lungo e non esiste un heap di nuova generazione per promuovere ulteriormente gli oggetti.

  • Garbage Collector ha un heap aggiuntivo per oggetti di grandi dimensioni noto come Large Object Heap (LOH).

  • È riservato per oggetti di 85.000 byte o superiori.

  • Gli oggetti di grandi dimensioni non vengono allocati ai cumuli generazionali ma vengono assegnati direttamente al LOH

  • Le raccolte di seconda generazione e LOH possono richiedere molto tempo per i programmi in esecuzione da molto tempo o che operano su grandi quantità di dati.

  • È noto che i programmi server di grandi dimensioni hanno cumuli di decine di GB.

  • Il GC utilizza una varietà di tecniche per ridurre il tempo di blocco dell'esecuzione del programma.

  • L'approccio principale consiste nell'eseguire il maggior numero possibile di operazioni di Garbage Collection su un thread in background in un modo che non interferisca con l'esecuzione del programma.

  • Il GC espone anche alcuni modi in cui gli sviluppatori possono influenzare il suo comportamento, il che può essere molto utile per migliorare le prestazioni.

In questo capitolo, comprenderemo il processo di esecuzione di .NET Core e lo confronteremo con .NET Framework. Il processo di esecuzione gestito include i seguenti passaggi.

  • Scegliere un compilatore
  • Compilazione del codice in MSIL
  • Compilazione di MSIL in codice nativo
  • Codice in esecuzione

Scegliere un compilatore

  • È un ambiente di esecuzione multilingue, il runtime supporta un'ampia varietà di tipi di dati e funzionalità del linguaggio.

  • Per ottenere i vantaggi forniti da Common Language Runtime, è necessario utilizzare uno o più compilatori di linguaggio destinati al runtime.

Compilazione del codice in MSIL

  • La compilazione traduce il codice sorgente in Microsoft Intermediate Language (MSIL) e genera i metadati richiesti.

  • I metadati descrivono i tipi nel codice, inclusa la definizione di ogni tipo, le firme dei membri di ogni tipo, i membri a cui fa riferimento il codice e altri dati che il runtime utilizza al momento dell'esecuzione.

  • Il runtime individua ed estrae i metadati dal file e dalle librerie di classi di framework (FCL) in base alle esigenze durante l'esecuzione.

Compilazione di MSIL in codice nativo

  • Al momento dell'esecuzione, un compilatore just-in-time (JIT) traduce MSIL in codice nativo.

  • Durante questa compilazione, il codice deve superare un processo di verifica che esamina MSIL e metadati per scoprire se è possibile determinare se il codice è indipendente dai tipi.

Codice in esecuzione

  • Il Common Language Runtime fornisce l'infrastruttura che consente l'esecuzione e servizi che possono essere utilizzati durante l'esecuzione.

  • Durante l'esecuzione, il codice gestito riceve servizi quali garbage collection, sicurezza, interoperabilità con codice non gestito, supporto per il debug multilingue e supporto avanzato per la distribuzione e il controllo delle versioni.

Processo di esecuzione del codice .NET Core

Ora mettiamo in relazione il modo in cui il codice viene eseguito con .NET Core rispetto a .NET Framework. In .NET Core ci sono molte sostituzioni di questi componenti che fanno parte di .NET Framework.

  • In .NET Core ora abbiamo una nuova serie di compilatori, come Roslyn per C # e VB.

  • È anche possibile usare il nuovo compilatore F # 4.1 se si vuole usare F # con .NET Core.

  • In realtà questi strumenti sono diversi e possiamo usare Roslyn anche con .NET Framework se stiamo usando C # 6 o versioni successive, perché il compilatore C # può supportare solo fino a C # 5.

  • In .NET Core, non abbiamo una libreria di classi framework (FCL), quindi viene utilizzato un set diverso di librerie e ora abbiamo CoreFx.

  • CoreFx è la reimplementazione delle librerie di classi per .NET Core.

  • Abbiamo anche un nuovo tempo di esecuzione con .NET Core noto come CoreCLR e sfrutta un compilatore JIT.

  • Ora la domanda è perché abbiamo la reimplementazione di tutti questi componenti che abbiamo già nel framework .NET.

  • Quindi la risposta è la stessa del motivo per cui Microsoft ha implementato .NET Core.

È un'altra considerazione di .NET Core per creare e implementare un'applicazione modulare. Invece di installare l'intero .NET Framework, l'applicazione può ora installare solo ciò che è necessario. Andiamo allo studio visivo e vediamo la modularità.

Ecco la nostra semplice applicazione .NET Core, in Esplora soluzioni. Espandiamo Riferimenti e vedrai il riferimento a .NETCoreApp

All'interno di .NETCoreApp, vedrai il riferimento al pacchetto NuGet; allargiamolo.

Vedrai l'intera serie di riferimenti al pacchetto NuGet. Se hai lavorato in .NET Framework, molti di questi spazi dei nomi ti sembreranno familiari, perché sei abituato a usarli in .NET Framework.

.NET Framework è suddiviso in molti pezzi diversi e reimplementato con CoreFx; questi pezzi sono ulteriormente distribuiti come pacchetti individuali.

  • Ora, se espandi NETStandard.Library, vedrai ulteriori riferimenti. Noterai anche System.Console che stiamo utilizzando in questa applicazione.

  • Ora non devi portare tutto all'interno di .NET Framework, ma solo portare ciò che ti serve per la tua applicazione.

  • Ci sono anche altri vantaggi; ad esempio, questi moduli possono essere aggiornati individualmente se lo si desidera.

La modularità porta a vantaggi in termini di prestazioni e l'applicazione può essere eseguita più velocemente, in particolare l'applicazione ASP.NET Core.

In questo capitolo, discuteremo dei file di progetto .NET Core e di come aggiungere file esistenti nel progetto.

Comprendiamo un semplice esempio in cui abbiamo alcuni file già creati; dobbiamo aggiungere questi file nel nostro progetto FirstApp.

Ecco l'implementazione di Student.cs file

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace FirstApp { 
   public class Student { 
      public int ID { get; set; } 
      public string LastName { get; set; } 
      public string FirstMidName { get; set; } 
      public DateTime EnrollmentDate { get; set; } 
   } 
}

Ecco l'implementazione di Course.cs file.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace FirstApp { 
   public class Course { 
      public int CourseID { get; set; } 
      public string Title { get; set; } 
      public int Credits { get; set; } 
   } 
}

Salviamo ora questi tre file nel disco e nella cartella di origine del progetto.

  • Ora, se hai familiarità con .NET e questa era una tradizionale applicazione console .NET framework, è importante capire come aggiungere questi file nel tuo progetto in Visual Studio.

  • È prima necessario trascinare i file in Esplora soluzioni per copiarli nella cartella del progetto, poiché il progetto deve fare riferimento a questi file.

  • Uno dei vantaggi di .NET Core è l'approccio adottato con il file di progetto (project.json); possiamo semplicemente trascinare i file nella radice del nostro progetto e quindi questi verranno automaticamente inclusi nel nostro progetto.

  • Non è necessario fare riferimento manualmente ai file come abbiamo fatto in passato per le tradizionali applicazioni .NET Framework in Visual Studio.

Apriamo ora la radice del tuo progetto.

Copiamo ora tutti e tre i file nella radice del tuo progetto.

Ora puoi vedere tutti i file copiati nella cartella principale.

Passiamo ora a Visual Studio; riceverai la seguente finestra di dialogo.

Clic Yes to All per ricaricare il tuo progetto.

Ora vedrai che i file vengono inclusi automaticamente nel tuo progetto.

In questo capitolo discuteremo come aggiungere pacchetti nell'applicazione .NET Core e come trovare un pacchetto specifico. Possiamo andare direttamente a NuGet e aggiungere il pacchetto, ma qui vedremo altri posti.

Andiamo ora al codice sorgente di .NET Core che si trova qui - https://github.com/dotnet/corefx

Nel repository CoreFx, apri il file src cartella -

E vedrai l'intero elenco di cartelle che corrispondono a diversi pacchetti. Cerchiamo ora Json -

C'è un altro modo per trovare il tuo pacchetto, probabilmente conosci vari tipi se hai familiarità con .NET Framework, ma l'assemblaggio di pacchetti in .NET Core è totalmente diverso e non saprai dove si trovano quei pacchetti.

Se conosci il tipo, puoi eseguire la ricerca per invertire la ricerca del pacchetto utilizzando https://packagesearch.azurewebsites.net/

Qui puoi inserire qualsiasi tipo di pacchetto che desideri trovare. Quindi, questo sito eseguirà la scansione di NuGet e troverà i pacchetti pertinenti per te.

Cerchiamo ora DataContractJson.

Ora vedrai che otteniamo lo stesso pacchetto; facciamo clic sul pacchetto.

Vedrai ora la pagina NuGet; è necessario confermare che è necessario questo pacchetto. Puoi aggiungerlo nella tua applicazione utilizzando alcuni metodi.

Apriamo il file project.json.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      } 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

Questo è il nuovo formato del progetto e all'interno di questo file vedrai la sezione delle dipendenze. Aggiungiamo una nuova dipendenza come mostrato di seguito.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      }, 
      "System.Runtime.Serialization.Json": "4.0.2" 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

Ora, se guardi i tuoi riferimenti, lo vedrai System.Runtime.Serialization.Json il pacchetto viene aggiunto al progetto.

Un altro modo è passare a NuGet Manager e sfogliare il pacchetto che si desidera aggiungere.

In questo capitolo verrà illustrato come creare un'applicazione UWP utilizzando .NET Core. UWP è anche noto come applicazione UWP di Windows 10. Questa applicazione non funziona su versioni precedenti di Windows, ma funzionerà solo su versioni future di Windows.

Di seguito sono riportate alcune eccezioni in cui UWP verrà eseguito senza problemi.

  • Se vuoi eseguirlo localmente devi avere Windows 10, puoi anche sviluppare su Windows 8 e quindi dovrai eseguirlo su Emulator, ma è incoraggiato usare Windows 10.

  • Per l'applicazione UWP avrai bisogno anche di Windows 10 SDK. Apriamo l'installazione di Visual Studio 2015 e quindi modifichiamo Visual Studio.

  • Nella pagina delle funzionalità selezionate, scorri verso il basso e vedrai Strumenti di sviluppo app di Windows universali, seleziona l'opzione come mostrato di seguito.

Qui puoi vedere le diverse versioni di SDK e l'ultimo aggiornamento anche su Strumenti, fai clic su Avanti.

Ora, fai clic su Install pulsante.

Al termine dell'installazione, sarà necessario riavviare il sistema.

Implementiamo ora la piattaforma UWP seguendo questi passaggi.

  • Innanzitutto, avvia Visual Studio 2015.

  • Fare clic sul menu File e selezionare Nuovo → Progetto; verrà visualizzata una finestra di dialogo Nuovo progetto. È possibile visualizzare i diversi tipi di modelli nel riquadro sinistro della finestra di dialogo.

  • Nel riquadro di sinistra, puoi vedere la visualizzazione ad albero, ora seleziona Modello universale da Modelli → Visual C # → Windows.

  • Dal riquadro centrale, seleziona il modello App vuota (Windows universale).

  • Dai un nome al progetto digitando UWPFirstApp nel campo Nome e fare clic su OK.

  • Viene visualizzata la finestra di dialogo versione di destinazione / versione minima. Le impostazioni predefinite vanno bene per questo tutorial, quindi seleziona OK per creare il progetto.

  • Qui, abbiamo un unico progetto che può indirizzare tutti i dispositivi Windows 10 e noterai che sia .NET Core che UWP sono la semplificazione del multi-targeting.

  • Quando si apre un nuovo progetto, i suoi file vengono visualizzati sul lato destro del riquadro Esplora soluzioni. Potrebbe essere necessario scegliere la scheda Esplora soluzioni invece della scheda Proprietà per visualizzare i file.

  • Sebbene l'app vuota (finestra universale) sia un modello minimo, contiene ancora molti file. Questi file sono essenziali per tutte le app UWP che usano C #. Ogni progetto creato in Visual Studio contiene i file.

  • Per vedere l'esempio in esecuzione, apriamo MainPage.XAML e aggiungiamo il codice seguente.

<Page 
   x:Class = "UWPFirstApp.MainPage" 
   xmlns = "http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
   xmlns:x = "http://schemas.microsoft.com/winfx/2006/xaml" 
   xmlns:local = "using:UWPFirstApp" 
   xmlns:d = "http://schemas.microsoft.com/expression/blend/2008" 
   xmlns:mc = "http://schemas.openxmlformats.org/markup-compatibility/2006" 
   mc:Ignorable = "d">  
   
   <Grid Background = "{ThemeResource ApplicationPageBackgroundThemeBrush}"> 
      <StackPanel HorizontalAlignment = "Center"> 
         <TextBlock Text = "Hello, world!"  
            Margin = "20" 
            Width = "200" 
            HorizontalAlignment = "Left"/> 
         <TextBlock Text = "Write your name." 
            Margin = "20" 
            Width = "200" 
            HorizontalAlignment = "Left"/> 
         <TextBox x:Name = "txtbox"  
            Width = "280" 
            Margin = "20" 
            HorizontalAlignment = "Left"/> 
         <Button x:Name = "button" Content = "Click Me" 
            Margin = "20" 
            Click = "button_Click"/> 
         <TextBlock x:Name = "txtblock"  
            HorizontalAlignment = "Left" 
            Margin = "20"/> 
      </StackPanel> 
   </Grid> 

</Page>

Di seguito è riportato l'evento clic del pulsante in C #.

using System; 
using System.Collections.Generic; 
using System.IO; 
using System.Linq; 
using System.Runtime.InteropServices.WindowsRuntime; 

using Windows.Foundation; 
using Windows.Foundation.Collections; 

using Windows.UI.Xaml; 
using Windows.UI.Xaml.Controls; 
using Windows.UI.Xaml.Controls.Primitives; 
using Windows.UI.Xaml.Data; 
using Windows.UI.Xaml.Input; 
using Windows.UI.Xaml.Media; 
using Windows.UI.Xaml.Navigation;  

// The Blank Page item template is documented at 
// http://go.microsoft.com/fwlink/?LinkId=402352&clcid=0x409  

namespace UWPHellowWorld { 
   /// <summary> 
   /// An empty page that can be used on its own or navigated to within a Frame. 
   /// </summary> 
   public sealed partial class MainPage : Page { 
      public MainPage() { 
         this.InitializeComponent(); 
      }  
      private void button_Click(object sender, RoutedEventArgs e) { 
         if (txtbox.Text != "") 
            txtblock.Text = "Hello: " + txtbox.Text; 
         else 
            txtblock.Text = "You have not write your name"; 
      } 
   } 
}

Eseguiamo ora il codice sopra sulla macchina locale e vedrai la seguente finestra. Ora digita un nome qualsiasi nella casella di testo e premi il tastoClick Me pulsante.

In questo capitolo discuteremo che cos'è MSBuild e come funziona con .NET Core. MSBuild è la piattaforma di compilazione per Microsoft e Visual Studio. Nell'applicazione UWP, se apri la cartella del progetto, vedrai entrambi i file project.json e * .csproj.

Ma se apri la nostra precedente app .NET Core Console, vedrai i file project.json e * .xproj.

  • Il sistema di compilazione .NET Core o il sistema di compilazione project.json non è sufficiente per le esigenze della piattaforma UWP; questo è il motivo per cui UWP utilizza ancora il sistema di compilazione * .csproj (MSBuild).

  • Ma project.json si sposterà per quanto riguarda il sistema di compilazione.

  • Ora, se desideri aggiungere alcuni file esistenti alla tua applicazione UWP come abbiamo aggiunto nell'app Console, devi aggiungere quei file nella cartella del progetto. Inoltre, sarà necessario includere nel progetto anche in Esplora soluzioni.

Consideriamo ora i seguenti file; copia questi file nella cartella del tuo progetto.

Torniamo a Visual Studio e apriamo Esplora soluzioni.

  • Ora puoi vedere che solo la copia dei file non è sufficiente in caso di applicazioni UWP, perché in Esplora soluzioni non possiamo vedere quei file.

  • Ora dobbiamo includere anche quei file facendo clic su Show All Files come evidenziato nello screenshot qui sopra e vedrai ora tutti i file nella cartella del progetto.

Questi due file non sono ancora inclusi nel nostro progetto. Per includere questi file, selezionali e fai clic con il pulsante destro del mouse su qualsiasi file, quindi selezionaInclude in Project.

Ora anche questi file sono inclusi. Una buona cosa che si può prevedere è l'approccio project.json di eliminare i file per * .csproj nella futura versione degli strumenti SKD e anche in Visual Studio.

In questo capitolo discuteremo i riferimenti tra la nostra app Console e la nostra app UWP. Se guardi i riferimenti in Esplora soluzioni della tua applicazione console, vedrai .NETCoreApp come mostrato di seguito.

.NETCoreApp è un nuovo framework destinato all'applicazione .NET Core. Ora, se guardi sotto i riferimenti dell'applicazione UWP, apparirà un po 'diverso come mostrato di seguito.

  • Il motivo principale è che qui in UWP abbiamo * .csproj, quindi siamo tornati al vecchio stile di riferimenti e possiamo scegliere come target un solo framework con questo tipo di progetto.

  • I riferimenti però sono simili. È ora possibile vedere che nell'applicazione UWP, il riferimento al pacchetto NuGet Miscrosoft.NETCore.UniversalWindowsPlatform è simile al riferimento NuGet Microsoft.NETCore.App nell'applicazione console.

  • Sia Miscrosoft.NETCore.UniversalWindowsPlatform che Microsoft.NETCore.App sono meta-pacchetto, il che significa che sono composti da altri pacchetti.

  • Nell'applicazione console, possiamo eseguire il drill-in e vedere altri pacchetti all'interno di Microsoft.NETCore.App, ma non possiamo fare lo stesso Miscrosoft.NETCore.UniversalWindowsPlatform in Esplora soluzioni.

  • Tuttavia, possiamo usare un altro strumento, NuGet Package Explorer per esaminarlo. Apriamo ora questo URL nel browser -https://npe.codeplex.com/downloads/get/clickOnce/NuGetPackageExplorer.application e vedrai una piccola utility in download.

  • Una volta completato il download, fai doppio clic su quel file.

  • Clic Install per avviare l'installazione in NuGet Package Explorer.

  • Al termine dell'installazione, vedrai la seguente finestra di dialogo.

  • Facciamo ora clic sul file Open a package from online feed opzione.

  • Per impostazione predefinita, cercherà il feed nuget.org. Cerchiamo ora Microsoft.NETCore.UniversalWindowsPlatform nella casella di ricerca e vedrai 1 risultato come mostrato di seguito.

  • Clicca il open link e aprirà le dipendenze di primo livello di questo metapacchetto.

  • Apriamo ora il metapacchetto .NETCore per l'applicazione .NETCore e il metapacchetto per l'applicazione UWP fianco a fianco.

  • Ora puoi vedere che ogni meta-pacchetto è composto da diversi set di pacchetti.

  • .NET Core è un sottoinsieme delle classi disponibili in .NET Framework almeno in questo momento, ma è in crescita e sarà come per le classi di base di .NET Framework.

  • La piattaforma UWP è basata su .NET Core, è un superset delle API disponibili per lo sviluppo di Windows Store.

Ora abbiamo più API disponibili per lo sviluppo grazie a .NET Core.

I componenti di Windows Runtime sono oggetti autonomi che puoi creare e usare da qualsiasi linguaggio, inclusi C #, Visual Basic, JavaScript e C ++. Oltre al meta-pacchetto .NET Core che abbiamo visto nel capitolo precedente, l'app UWP ha anche un riferimento per impostazione predefinita a un Universal Windows SDK.

Windows universale è il riferimento a Windows Runtime ed è stato preso in considerazione in una serie di contratti API.

Il set di API all'interno di una famiglia di dispositivi è suddiviso in suddivisioni note come contratti API. Puoi trovare un elenco di diversi contratti API quihttps://msdn.microsoft.com/en-us/library/windows/apps/dn706135.aspx

La maggior parte di queste API all'interno di Windows Runtime viene scomposta in un unico contratto. Cerchiamo ora la parola chiave universale nella pagina Contratti API.

Puoi vedere i collegamenti a varie API e puoi anche vedere che la famiglia Universal è così grande che ha 12 pagine di documentazione.

Puoi anche cercare il contratto API del telefono in questa pagina.

Facciamo ora clic sul file Windows.Phone.PhoneContracte scorri verso il basso; ora vedrai le informazioni sulla batteria del telefono o del dispositivo mobile.

Se vuoi aggiungere queste informazioni a quelle che hai già, dovresti aggiungere i riferimenti manualmente. Andiamo ora a Visual Studio e fai clic con il pulsante destro del mouse sui riferimenti in Esplora soluzioni.

Selezionare Add References…

È ora possibile vedere la nuova categoria di riferimento per Windows universale; in questa categoria c'è Core che si riferisce ai contratti API Windows universali principali

  • Le estensioni ci consentono di estendere la funzionalità e vedrai diversi riferimenti Mobile, Desktop e altre estensioni.

  • Esistono diverse estensioni SKD e puoi aggiungerne altre per ottenere più API.

  • Puoi anche vedere diverse versioni. Quindi, assicurati di ottenere l'ultima versione per ottenere le API aggiornate, quindi fai clic su OK.

Ora puoi vederlo Windows Mobile Extensions for the UWP viene aggiunto come riferimento.

Una libreria di classi definisce i tipi e metodi che possono essere chiamati da qualsiasi applicazione.

  • Una libreria di classi sviluppata utilizzando .NET Core supporta la libreria .NET Standard, che consente alla libreria di essere chiamata da qualsiasi piattaforma .NET che supporti quella versione della libreria .NET Standard.

  • Una volta terminata la libreria di classi, è possibile decidere se distribuirla come componente di terze parti o se includerla come componente in bundle con una o più applicazioni.

Cominciamo aggiungendo un progetto di libreria di classi nella nostra applicazione Console; fare clic con il pulsante destro del mouse sul filesrc cartella in Esplora soluzioni e selezionare Add → New Project…

Nel Add New Project finestra di dialogo, scegliere il nodo .NET Core, quindi scegliere il modello di progetto Libreria di classi (.NET Core).

Nella casella di testo Nome, immettere "UtilityLibrary" come nome del progetto, come mostra la figura seguente.

Fare clic su OK per creare il progetto della libreria di classi. Una volta creato il progetto, aggiungiamo una nuova classe. Fare clic con il tasto destro suproject in Esplora soluzioni e seleziona Add → Class...

Selezionare la classe nel riquadro centrale e immettere StringLib.cs nel nome e nel campo, quindi fare clic Add. Una volta aggiunta la classe, sostituire il codice seguente nel file StringLib.cs.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace UtilityLibrary { 
   public static class StringLib { 
      public static bool StartsWithUpper(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
         return false; 
         Char ch = str[0]; 
         return Char.IsUpper(ch); 
      } 
      public static bool StartsWithLower(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
         return false; 
         Char ch = str[0]; 
         return Char.IsLower(ch); 
      } 
      public static bool StartsWithNumber(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
         return false;  
         Char ch = str[0]; 
         return Char.IsNumber(ch); 
      } 
   } 
}
  • La libreria di classi, UtilityLibrary.StringLib, contiene alcuni metodi come, StartsWithUpper, StartsWithLower, e StartsWithNumber che restituisce un valore booleano che indica se l'istanza di stringa corrente inizia rispettivamente con lettere maiuscole, minuscole e numeri.

  • In .NET Core, il Char.IsUpper restituisce true se un carattere è in maiuscolo, il metodo Char.IsLower restituisce true se un carattere è in minuscolo e analogamente il metodo Char.IsNumber restituisce true se un carattere è un numerico.

  • Sulla barra dei menu, scegli Genera, Genera soluzione. Il progetto dovrebbe essere compilato senza errori.

  • Il nostro progetto console .NET Core non ha accesso alla nostra libreria di classi.

  • Ora per consumare questa libreria di classi dobbiamo aggiungere il riferimento a questa libreria di classi nel nostro progetto console.

Per fare ciò, espandere FirstApp e fare clic con il pulsante destro del mouse su Riferimenti e selezionare Add Reference…

Nella finestra di dialogo Gestione riferimenti, seleziona UtilityLibrary, il nostro progetto di libreria di classi, quindi fai clic su OK.

Apriamo ora il file Program.cs del progetto della console e sostituiamo tutto il codice con il codice seguente.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Threading.Tasks; 
using UtilityLibrary; 

namespace FirstApp { 
   public class Program { 
      public static void Main(string[] args) { 
         int rows = Console.WindowHeight; 
         Console.Clear(); 
         do { 
            if (Console.CursorTop >= rows || Console.CursorTop == 0) { 
               Console.Clear(); 
               Console.WriteLine("\nPress <Enter> only to exit; otherwise, enter a string and press <Enter>:\n"); 
            } 
            string input = Console.ReadLine(); 
            
            if (String.IsNullOrEmpty(input)) break; 
            Console.WriteLine("Input: {0} {1,30}: {2}\n", input, "Begins with uppercase? ", 
            input.StartsWithUpper() ? "Yes" : "No"); 
         } while (true); 
      } 
   } 
}

Eseguiamo ora la tua applicazione e vedrai il seguente output.

Per una migliore comprensione, utilizziamo gli altri metodi di estensione della libreria di classi nel progetto.

In questo capitolo discuteremo cos'è PCL (Portable Class Library) e anche perché abbiamo bisogno di PCL. Per comprendere questo concetto, apriamo la cartella del progetto della libreria di classi che abbiamo creato nel capitolo precedente.

In questa cartella, puoi vedere che oltre ai file project.json e CS abbiamo anche il file * .xproj, e questo perché Visual Studio imposta il tipo di progetto .NET Core come * .xproj invece di * .csproj.

Come accennato da Microsoft, * .xproj non sarà più disponibile, ma è ancora presente negli strumenti di anteprima 2. Come abbiamo visto, l'applicazione UWP usa * .csproj.

Ora in realtà non è possibile ottenere * .csproj come riferimento e * .xproj e tale funzionalità non verrà implementata perché * .xproj verrà spostato.

Quindi, invece, abbiamo bisogno di una libreria di classi che può essere condivisa tra l'app della console e l'app UWP e qui arriva PCL.

Cos'è PCL

Cerchiamo ora di capire cos'è PCL -

  • Il progetto Portable Class Library consente di scrivere e creare assembly gestiti che funzionano su più di una piattaforma .NET Framework.

  • È possibile creare classi che contengono codice che si desidera condividere in molti progetti, come la logica aziendale condivisa, e quindi fare riferimento a tali classi da diversi tipi di progetti.

  • Può anche aiutarti a creare app e librerie multipiattaforma per piattaforme Microsoft in modo rapido e semplice.

  • Le librerie di classi portatili possono aiutarti a ridurre i tempi ei costi di sviluppo e test del codice.

  • Usa questo tipo di progetto per scrivere e creare assembly .NET Framework portatili e quindi fare riferimento a tali assembly da app destinate a più piattaforme come Windows e Windows Phone e così via.

Ora rimuoviamo la libreria di classi che abbiamo creato da Esplora soluzioni. Allo stesso tempo, eliminalo dalla cartella Soluzione e aggiungi ulteriormente un nuovo elemento del progetto.

Seleziona il Visual C# → Windows modello nel riquadro sinistro e selezionare Libreria di classi (portatile) nel riquadro centrale.

Immettere StringLibrary nel campo del nome e fare clic OK per creare questo progetto.

Ora dobbiamo selezionare i framework di destinazione a cui fare riferimento. Selezioniamo Windows Universal e ASP.NET Core per un momento, quindi lo reindirizzeremo. ClicOK.

Puoi vedere che ha creato un nuovo progetto in formato PCF. Facciamo ora clic con il pulsante destro del mouse sul progetto StringLibrary in Esplora soluzioni e seleziona Proprietà.

Fare clic su Target .NET Platform Standard.

Fare clic su Sì; ora è la stessa libreria di classi con una piccola differenza. La differenza è che può essere utilizzato anche da UWP, perché contiene il file * .csproj invece di * .xproj.

Aggiungiamo ora una nuova classe; per questo, è necessario fare clic con il pulsante destro del mouse sul progetto in Esplora soluzioni e selezionareAdd → Class...

Seleziona la classe nel riquadro centrale ed entra StringLib.cs nel campo del nome e quindi fare clic su Add. Una volta aggiunta la classe, sostituire il codice seguente nel file StringLib.cs.

using System; 
using System.Collections.Generic; 
using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
  
namespace StringLibrary { 
   public static class StringLib { 
      public static bool StartsWithUpper(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
            return false; 
         Char ch = str[0]; 
         return Char.IsUpper(ch); 
      } 
      public static bool StartsWithLower(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
            return false; 
         Char ch = str[0]; 
         return Char.IsLower(ch); 
      } 
      public static bool StartsWithNumber(this String str) { 
         if (String.IsNullOrWhiteSpace(str)) 
            return false; 
         Char ch = str[0]; 
         return Char.IsNumber(ch); 
      } 
   } 
}

Costruiamo questo progetto di libreria di classi portabile e dovrebbe essere compilato senza errori. Ora dobbiamo aggiungere un riferimento a questa libreria di classi portabile nel nostro progetto console. Quindi, espandi FirstApp e fai clic con il pulsante destro del mouse su Riferimenti e selezionaAdd Reference…

Nella finestra di dialogo Gestione riferimenti, selezionare StringLibrary, che è il nostro progetto di libreria di classi portabile, e quindi fare clic su OK.

Puoi vedere che il riferimento StringLibrary viene aggiunto al progetto della console e può essere visto anche nel file project.json.

Ora puoi eseguire nuovamente l'applicazione e vedrai lo stesso output.

Usiamo ora gli altri metodi di estensione della tua libreria di classi portabile nel tuo progetto. La stessa libreria portatile verrà utilizzata anche nell'applicazione UWP.

In questo capitolo, discuteremo come aggiungere riferimenti alla tua libreria. Aggiungere riferimenti alla libreria è come aggiungere riferimenti ad altri progetti, come il progetto console e il progetto UWP.

È ora possibile vedere che il progetto PCL ha alcuni riferimenti per impostazione predefinita. È inoltre possibile aggiungere altri riferimenti secondo le esigenze dell'applicazione.

Nella libreria PCL, puoi anche vedere il file project.json.

{ 
   "supports": {}, 
   "dependencies": { 
      "NETStandard.Library": "1.6.0", 
      "Microsoft.NETCore.Portable.Compatibility": "1.0.1" 
   }, 
   "frameworks": { 
      "netstandard1.3": {} 
   } 
}

Un metodo per aggiungere riferimenti alla tua libreria è digitarlo direttamente nel file project.json. Come puoi vedere, abbiamo aggiunto alcuni riferimenti nella sezione delle dipendenze come mostrato nel codice seguente.

{ 
   "supports": {}, 
   "dependencies": { 
      "NETStandard.Library": "1.6.0", 
      "Microsoft.NETCore.Portable.Compatibility": "1.0.1", 
      "System.Runtime.Serialization.Json": "4.0.3", 
      "Microsoft.EntityFrameworkCore": "1.1.0" 
   }, 
   "frameworks": { 
      "netstandard1.3": {} 
   } 
}

Salviamo ora questo file e vedrai che i riferimenti vengono aggiunti alla tua libreria ora.

L'altro metodo per aggiungere riferimenti alla libreria è NuGet Package Manager. Facciamo ora clic con il pulsante destro del mouse sul fileStringLibrary (Portable) progetto e seleziona Mange NuGet Packages…

Nella scheda Sfoglia è possibile cercare qualsiasi pacchetto NuGet; diciamo di voler aggiungere il pacchetto "System.Runtime.Serialization.Primitives".

Clicca il Install pulsante, che visualizzerà la seguente schermata.

Ora, fai clic su OK pulsante.

Infine, fai clic su I Acceptpulsante per avviare l'installazione di questo pacchetto NuGet. Al termine dell'installazione, vedrai che il pacchetto NuGet "System.Runtime.Serialization.Primitives" viene aggiunto alla tua libreria.

In questo capitolo, discuteremo come condividere la tua libreria come NuGet Packagein modo che possa essere consumato all'interno di un altro progetto. La creazione di un pacchetto inizia con il codice che desideri impacchettare e condividere con altri, tramite la galleria pubblica nuget.org o una galleria privata all'interno della tua organizzazione. Il pacchetto può anche includere file aggiuntivi come un filereadme che viene visualizzato quando il pacchetto viene installato e può includere trasformazioni a determinati file di progetto.

Consideriamo ora un semplice esempio in cui creeremo un pacchetto NuGet dalla nostra libreria. Per fare ciò, apri il prompt dei comandi e vai alla cartella in cui si trova il file project.json del tuo progetto di libreria.

Eseguiamo ora il seguente comando.

dotnet help

Alla fine, puoi vedere diversi comandi come nuovo, ripristino e build, ecc.

L'ultimo comando è pack;questo creerà un pacchetto NuGet. Eseguiamo ora il seguente comando.

dotnet pack

È ora possibile vedere che i pacchetti NuGet vengono prodotti nella cartella bin; apriamo la cartella bin \ Debug.

Ora la domanda è cosa c'è dentro i pacchetti NuGet, per vedere che possiamo usare NuGet Package Explorer. Apriamo ora NuGet Package Explorer.

Seleziona la prima opzione Open a local package.

Seleziona il StringLibrary.1.0.0.nupkg e fare clic Open.

Puoi vedere che nella sezione Contenuto del pacchetto abbiamo solo StringLibrary.dll. Nella sezione Metadati del pacchetto, vedrai un po 'di informazioni su questa libreria come Id, Versioni e tutte le dipendenze.

Apriamo ora il file StringLibrary.1.0.0.symbols.nupkg.

In questo pacchetto NuGet vedrai i file di origine e il file *.pdbanche file. Se fai doppio clic sul fileStringLib.cs file, vedi anche il codice sorgente.

Qui la domanda è: come configurare i metadati come versione, autori e descrizione, ecc.

Il file project.json viene usato nei progetti .NET Core per definire i metadati del progetto, le informazioni di compilazione e le dipendenze. Apriamo ora il file project.json e aggiungiamo le seguenti informazioni aggiuntive.

{ 
   "authors": [ "Mark Junior" ], 
   "description": "String Library API", 
   "version" : "1.0.1-*", 
   "supports": {}, 
   
   "dependencies": { 
      "Microsoft.EntityFrameworkCore": "1.1.0", 
      "Microsoft.NETCore.Portable.Compatibility": "1.0.1", 
      "NETStandard.Library": "1.6.0", 
      "System.Runtime.Serialization.Json": "4.0.3", 
      "System.Runtime.Serialization.Primitives": "4.3.0" 
   }, 
   "frameworks": { 
      "netstandard1.3": {} 
   } 
}

Ora puoi vedere ulteriori informazioni come il nome dell'autore, la descrizione e la versione aggiunte qui. Salviamo questo file, compiliamo il progetto della libreria, quindi eseguiamo nuovamente il comando "dotnet pack".

All'interno della cartella bin \ Debug è possibile vedere che i pacchetti NuGet StringLibrary vengono prodotti con la versione 1.0.1; apriamolo in NuGet Package Explorer.

Vedrai i metadati aggiornati. La domanda ora è: come possiamo usarlo in un altro pacchetto.

Dobbiamo iniziare pubblicando da qualche parte nel feed NuGet e quindi possiamo utilizzarlo in un altro progetto.

Sono disponibili due opzioni per pubblicare i metadati aggiornati:

  • Pubblicalo su nuget.org
  • Esegui il push dei metadati nel feed NuGet privato

Qui useremo il feed NuGet privato perché è molto più semplice che configurare un account su nuget.org. Per sapere come pubblicare il tuo pacchetto su nuget.org, puoi seguire tutte le linee guida specificate quihttps://docs.microsoft.com/en-us/nuget/create-packages/publish-a-package.

Segui questi passaggi per inviare i metadati aggiornati al feed NuGet privato.

Step 1- Per cominciare, abbiamo bisogno dell'utilità della riga di comando nuget e dobbiamo installarla. Apriamo ora NuGet Package Manager e cerchiamo nuget.commandline.

Step 2 - Seleziona Nuget.Commandline e fai clic su Install.

Step 3 - Fare clic su OKper installare Nuget.Commandline. Puoi anche installarlo manualmente scaricandolo dal seguente Urlhttps://dist.nuget.org/index.html e quindi impostare la variabile di ambiente.

Step 4 - Al termine dell'installazione, apriamo di nuovo il prompt dei comandi e andiamo al bin\Debug cartella in cui si trovano i pacchetti NuGet e specificare il comando seguente:

nuget add StringLibrary.1.0.1.nupkg -Source D:\PrivateNugetPackages

Step 5 - Nel comando precedente, aggiungiamo il pacchetto StringLibrary.1.0.1.nupkg al nostro feed privato e la posizione è D:\PrivateNugetPackages, -Source specifica l'origine del pacchetto.

Step 6 - Puoi vedere che il file StringLibraryè installato; ilStringLibrary può essere ulteriormente aggiunto al feed privato.

Step 7 - Andiamo in quella cartella.

Step 8 - All'interno del stringlibrary cartella, vedrai un'altra cartella con il nome della versione ed eccola 1.0.1.

Il pacchetto NuGet si trova qui.

In questo capitolo verrà illustrato come utilizzare il pacchetto NuGet che abbiamo creato e pubblicato in un feed NuGet privato. Quindi, prima creeremo un progetto Xamarin.Forms. Dobbiamo prima capire cos'è Xamarin.Forms.

  • Xamarin.Forms è un framework che consente agli sviluppatori di creare rapidamente interfacce utente multipiattaforma.

  • Xamarin.Forms è un'astrazione del toolkit dell'interfaccia utente con supporto nativo multipiattaforma che consente agli sviluppatori di creare facilmente interfacce utente che possono essere condivise tra Android, iOS, Windows e Windows Phone.

  • Il rendering delle interfacce utente viene eseguito utilizzando i controlli nativi della piattaforma di destinazione, consentendo alle applicazioni Xamarin.Forms di mantenere l'aspetto appropriato per ogni piattaforma.

Per avviare Xamarin.Forms, sono necessarie alcune funzionalità aggiuntive in Visual Studio 2015. Modifichiamo Visual Studio 2015 e assicuriamoci che sia selezionata la seguente opzione di sviluppo mobile multipiattaforma.

Al termine dell'installazione, aggiorniamo Xamarin selezionando Tools → Options…

Scorri verso il basso ed espandi Xamarin nel riquadro sinistro, quindi seleziona Other. Nell'angolo in alto a destra della finestra di dialogo, fare clic suCheck Now per vedere se sono disponibili aggiornamenti.

Puoi vedere che gli aggiornamenti sono disponibili, facciamo clic su Downloadpulsante per avviare il download. Al termine del download, ti verrà notificato di installare gli aggiornamenti.

Apriamo ora di nuovo Visual Studio e selezioniamo il file File → New → Project… opzione di menu.

Nel riquadro sinistro, seleziona il file Visual C# → Cross-Platform modello e nel riquadro centrale selezionare Blank Xaml App (Xamarin.Forms Portable). Immettere il nome nel campo Nome e fare clic su OK.

Selezionare la versione di destinazione e la versione minima e fare clic su OK.

Vedrai una serie di progetti; in alto abbiamo la libreria PCL che sarà condivisa tra tutte le piattaforme come Android, iOS, UWP, Windows 8.1 e Windows Phone 8.1.

Qui ci concentreremo sulla libreria PCL e porteremo qui del codice. Cerchiamo di espandere il codice.

In questo modello Xamarin.Forms, puoi vedere il generico App.xaml e MainPage.xaml, usa il framework XAML Xamarin.Forms che funziona su queste piattaforme.

Dobbiamo importare i nostri codici e abbiamo anche bisogno del feed NuGet privato che abbiamo impostato nell'ultimo capitolo.

Apriamo ora NuGet Package Manager. Fare clic sulla rotellina accanto all'elenco a discesa Origine pacchetto.

Dobbiamo aggiungere il nostro feed privato qui, facciamo clic sul plus (+) button.

Vedrai che un'altra casella di controllo è stata aggiunta nel file Available package sources sezione, specificare un nome e un percorso di origine e fare clic OK.

Andiamo ora alla scheda Sfoglia e seleziona PrivateSource dall'elenco a discesa Origine pacchetto e vedrai il pacchetto NuGet StringLibrary. Seleziona StringLibrary e fai clic suInstall.

Fare clic su OK e verrà visualizzato un errore.

Non possiamo usare la libreria con il profilo .NETPortable versione 259, correggeremo questo errore nel prossimo capitolo.

In questo capitolo correggeremo l'errore riscontrato durante l'installazione del pacchetto NuGet dal nostro feed privato nel progetto Xamarin.Forms.

Comprenderemo ulteriormente il problema in breve. Per iniziare, fare clic con il pulsante destro del mouse sulla libreria PCL e selezionare Proprietà.

In questa pagina vedrai l'intera serie di framework mirati. Dall'errore, puoi vedere che il profilo .NETPortable 259 non è compatibile con la nostra StringLibrary 1.0.1. Tuttavia, sta cercando di prendere riferimento dalla libreria .NET Standard 1.1.

Vediamo ora la libreria .NET Standard e identifichiamo quale piattaforma non è compatibile con la nostra libreria.

Puoi vedere che Windows Phone Silverlight 8 è compatibile con .NET Standard 1.0. Se apri la seguente pagina web, vedrai che Profile259 può supportare solo .NET Standard 1.0.

Deselezioniamo ora Windows Phone Silverlight 8.

Clicca il OK pulsante.

Ora per risolvere questo problema, fai clic su OK e cancella la finestra di dialogo Cambia destinazioni, quindi apri la console di Gestione pacchetti ed esegui il comando seguente.

PM > Uninstall-Package Xamarin.Forms

Passiamo ora alle proprietà della libreria PCL. Fare clic sul pulsante Modifica.

Deseleziona Windows Phone Silverlight 8 e fai clic su OK.

Ora puoi vedere che Windows Phone Silverlight 8 non è più disponibile nel framework mirato. Puoi anche vedere il profilo che è l'obiettivo ora. Per vedere ciò, è possibile scaricare la libreria PCL e modificare il file XamarinApp.csproj.

Ora puoi vedere che TargetFrameworkProfile è ora Profile111.

Se apri la documentazione, vedrai che Profile111 supporta .NET Standard 1.1.

Ricarichiamo ora di nuovo il PCL, apriamo NuGet Package Manager e proviamo a installare il pacchetto StringLibrary dal feed privato.

Dall'elenco a discesa Comportamento delle dipendenze, selezionare Ignora dipendenze e quindi fare clic su Install.

Puoi vedere che il pacchetto StringLibrary è ora installato dal feed privato. Se espandi i riferimenti di PCL, vedrai che anche il riferimento StringLibrary viene aggiunto come mostrato di seguito.

Abbiamo disinstallato Xamarin.Forms per il problema di Silverlight 8 di Windows Phone. Xamarin.Forms deve essere installato di nuovo. Si consiglia di installare la stessa versione.

Una volta completata l'installazione, usiamo la funzionalità StringLibrary nella tua applicazione.

In questo capitolo verrà illustrato come creare un progetto di test utilizzando .NET Core. Il test unitario è un processo di sviluppo per il software che ha le parti testabili più piccole di un'applicazione, chiamate unità. Sono esaminati individualmente e indipendentemente per qualsiasi operazione corretta. Il test unitario può essere automatizzato o eseguito anche manualmente.

Apriamo ora la finestra di dialogo Nuovo progetto e selezioniamo Visual C# → .NET Core modello.

In questa finestra di dialogo è possibile vedere che non esiste un modello di progetto per i test unitari. Per creare un progetto di unit test, dovremmo usare l'utilità della riga di comando. Andiamo alla cartella Solution che abbiamo creato; creare una cartella di test e all'interno della cartella di test creare un'altra cartella e chiamarlaStringLibraryTests.

Usiamo ora l'utilità della riga di comando dotnet per creare un nuovo progetto di test eseguendo il seguente comando:

dotnet new -t xunittest

È ora possibile vedere che viene creato un nuovo progetto C #; esaminiamo la cartella eseguendo il filev comando e vedrai project.json e Tests.cs file come mostrato di seguito.

Ecco il codice nel file project.json.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "debugType": "portable" 
   }, 
   "dependencies": { 
      "System.Runtime.Serialization.Primitives": "4.1.1", 
      "xunit": "2.1.0", 
      "dotnet-test-xunit": "1.0.0-rc2-192208-24" 
   }, 
   "testRunner": "xunit", 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { 
            "Microsoft.NETCore.App": { 
               "type": "platform", 
               "version": "1.0.1" 
            } 
         }, 
         "imports": [ 
            "dotnet5.4", 
            "portable-net451+win8" 
         ] 
      } 
   } 
}

Di seguito è riportato il codice nel file Test.cs.

using System; 
using Xunit; 
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void Test1() { 
         Assert.True(true); 
      } 
   } 
}

Per recuperare le dipendenze necessarie da NuGet, eseguiamo il comando seguente:

dotnet restore

Possiamo eseguire il test quando vengono ripristinate le dipendenze necessarie.

Puoi vedere che la compilazione è riuscita; man mano che scendi puoi vedere alcune informazioni sul test eseguito.

Attualmente abbiamo 1 test eseguito, 0 errore, 0 fallito, 0 saltato e il tempo impiegato dal processo di esecuzione viene anche menzionato come informazione.

In questo capitolo, discuteremo come eseguire i test in Visual Studio. .NET Core è stato progettato pensando alla testabilità, in modo che la creazione di unit test per le applicazioni sia più semplice che mai. In questo capitolo, eseguiremo ed eseguiremo il nostro progetto di test in Visual Studio.

Apriamo la soluzione FirstApp in Visual Studio.

Puoi vedere che ha solo due progetti e non sarai in grado di vedere il progetto di test perché non abbiamo aggiunto quel progetto nella nostra soluzione.

Aggiungiamo prima una cartella e chiamiamola test.

Fare clic con il pulsante destro del mouse sul file test cartella.

Selezionare project.json file e fare clic Open.

Lo screenshot seguente mostra il codice in formato Tests.cs file come output.

È l'implementazione predefinita e sta solo verificando che True sia uguale a true. È il framework di test xUnit e vedrai l'attributo Fact che annota e denota il metodo di test.

using System; 
using Xunit; 
  
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void Test1() { 
         Assert.True(true); 
      } 
   } 
}

Di seguito è riportata l'implementazione di project.json file.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "debugType": "portable" 
   }, 
   "dependencies": { 
      "System.Runtime.Serialization.Primitives": "4.1.1", 
      "xunit": "2.1.0", 
      "dotnet-test-xunit": "1.0.0-rc2-192208-24" 
   }, 
   "testRunner": "xunit", 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { 
            "Microsoft.NETCore.App": { 
               "type": "platform", 
               "version": "1.0.1" 
            }
         }, 
         "imports": [ 
            "dotnet5.4", 
            "portable-net451+win8" 
         ] 
      } 
   } 
}

In project.jsonfile, la dipendenza più importante dal framework di test è xunit, che porta l'attributo Fact. Porta il framework di test e le API per i test con xunit.

Abbiamo anche il file dotnet-test-xunit, questo è un adottante in modo che xunit possa funzionare con .NET Core, in particolare con dotnet testutilità della riga di comando. Quindi vedrai il filetestRunner che eseguirà xunit e puoi anche vedere il file netcoreapp1.0 struttura.

Vedrai la dipendenza .NETCore.App di seguito.

Per eseguire il test in Visual Studio, apriamo Esplora test da Test → Window → Test Explorer opzione di menu.

E puoi vedere che Visual Studio rileva automaticamente il test. Il nome del test è composto danamespace.className.TestMethodName. Facciamo ora clic suRun All button in Test Explorer.

Prima costruirà il codice ed eseguirà il test e vedrai il tempo totale impiegato dal test. Cambiamo il metodo di test in modo da poter vedere l'output quando il test fallisce.

using System; 
using Xunit; 
  
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void Test1() { 
         Assert.True(false); 
      } 
   } 
}

Eseguiamo nuovamente il test facendo clic su Run All collegamento del pulsante.

Ora puoi vedere il file test fallimento.

In questo capitolo, testeremo la nostra StringLibrary e per farlo, dobbiamo riorganizzare i nostri progetti in modo da poter seguire la convenzione predefinita.

Apriamo il file global.json file.

{ 
   "projects": [ "src", "test" ], 
   "sdk": { 
      "version": "1.0.0-preview2-003131" 
   } 
}

Nella parte superiore di questo file vedrai le impostazioni del progetto e configura alcune cartelle come src e test per impostazione predefinita.

Poiché per convenzione dobbiamo avere progetti in queste cartelle, questa è la nuova convenzione e verrà utilizzata come parte di .NET Core.

In Esplora soluzioni, puoi vedere che sia il progetto della console che il progetto della libreria si trovano all'interno del file src cartella mentre il progetto Testing è all'interno test cartella.

E la struttura dei progetti in Esplora soluzioni non rappresenta dove esistono fisicamente i progetti sul disco. Apriamo ora la cartella Soluzione e lo vedraiStringLibrary il progetto non è all'interno di src cartella.

Puoi vederlo entrambi src e test cartelle mappate alla convenzione specificata in global.jsonfile. Tuttavia, abbiamo un progetto StringLibrary che è fuori convenzione. Aggiungiamo ora il fileStringLibrary progetto all'interno del src cartella.

Nella cartella src, abbiamo due progetti e dobbiamo risolvere il problema in modo da poter utilizzare correttamente tutti i progetti. Torniamo a Visual Studio e fare clic con il pulsante destro del mouse sul progetto StringLibrary e selezionare l'opzione Rimuovi. Non lo cancellerà, ma rimuoverà solo il progetto.

Ora fai clic con il tasto destro sulla cartella src e seleziona Add → Existing Project…

Passare al progetto StringLibrary che ora si trova all'interno di src cartella, seleziona il file StringLibrary.csproj file e fare clic Open.

Ora dobbiamo rimuovere il riferimento di StringLibrary dal project.json file dell'app console.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      }, 
      "NuGet.CommandLine": "3.5.0", 
      "System.Runtime.Serialization.Json": "4.0.3" 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { }, 
         "imports": "dnxcore50" 
      } 
   } 
}

Salvare le modifiche e quindi aggiungere un riferimento di StringLibrary di nuovo nel progetto della console.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      }, 
   "NuGet.CommandLine": "3.5.0", 
      "System.Runtime.Serialization.Json": "4.0.3" 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "dependencies": { 
            "StringLibrary": { 
               "target": "project" 
            } 
         }, 
         "imports": "dnxcore50" 
      } 
   } 
}

Ora tutto dovrebbe funzionare di nuovo e puoi costruire StringLibrary e poi FirstApp(progetto console) senza errori. Proviamo ora a testare la funzionalità StringLibrary utilizzando xunit. Dobbiamo aggiungere il riferimento di StringLibrary al nostro progetto di test. Fare clic con il pulsante destro del mouse sul progetto Riferimenti di StringLibraryTests e selezionare Aggiungi riferimento ...

Clic OK che aggiungerà un riferimento di StringLibraryal nostro progetto di test. Sostituiamo ora il codice seguente nel fileTests.cs file.

using System; 
using Xunit; 
using StringLibrary; 
  
namespace Tests { 
   public class Tests { 
      [Fact] 
      public void StartsWithUpperCaseTest() { 
         string input = "Mark"; 
         Assert.True(input.StartsWithUpper()); 
      } 
      [Fact] 
      public void StartsWithLowerCaseTest() { 
         string input = "mark"; 
         Assert.True(input.StartsWithLower()); 
      } 
      [Fact] 
      public void StartsWithNumberCaseTest() { 
         string input = "123"; 
         Assert.True(input.StartsWithNumber()); 
      } 
   } 
}

Puoi vedere che abbiamo tre metodi di test che testeranno la funzionalità di StringLibrary. Facci clic sul fileRun All e vedrai il seguente output in Esplora test.

Puoi anche eseguire i test dalla riga di comando. Apriamo il prompt dei comandi ed eseguiamo il filedotnet test comando.

In questo capitolo, discuteremo del Managed Extensibility Framework (MEF). MEF può essere utilizzato per l'estensibilità di plug-in di terze parti o può portare i vantaggi di un'architettura simile a plug-in a connessione libera alle normali applicazioni.

  • MEF è una libreria per creare applicazioni leggere ed estensibili.

  • Consente agli sviluppatori di applicazioni di scoprire e utilizzare estensioni senza necessità di configurazione.

  • MEF è parte integrante di .NET Framework 4 ed è disponibile ovunque venga utilizzato .NET Framework che migliora la flessibilità, la manutenibilità e la testabilità di applicazioni di grandi dimensioni.

  • È possibile utilizzare MEF nelle applicazioni client, indipendentemente dal fatto che utilizzino Windows Form, WPF o qualsiasi altra tecnologia o nelle applicazioni server che utilizzano ASP.NET.

  • MEF è stato portato come Microsoft.Composition anche a .NET Core, ma parzialmente.

  • Solo System.Composition è portato, e System.ComponentModel.Compositionnon è ancora disponibile. Ciò significa che non abbiamo i cataloghi che possono caricare i tipi dagli assembly in una directory.

In questo capitolo, impareremo solo come utilizzare MEF nell'applicazione .NET Core.

Comprendiamo un semplice esempio in cui useremo MEF nell'applicazione console .NET Core. Creiamo ora un nuovo progetto console .NET Core.

Nel riquadro di sinistra, seleziona Templates → Visual C# → .NET Core e quindi nel riquadro centrale selezionare Applicazione console (.NET Core).

Immettere il nome del progetto nel campo Nome e fare clic su OK.

Una volta creato il progetto, dobbiamo aggiungere un riferimento a Microsoft.Composition in modo da poter utilizzare MEF. A tale scopo, fare clic con il pulsante destro del mouse sul progetto in Esplora soluzioni eManage NuGet Packages…

Cercare Microsoft.Composition e fare clic Install.

Clicca il OK pulsante.

Clicca il I Accept pulsante.

Al termine dell'installazione, troverai un errore in Riferimenti.

Apriamo il file project.json file.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
  
   "dependencies": { 
      "Microsoft.Composition": "1.0.30", 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1" 
      } 
   }, 
  
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "dnxcore50" 
      } 
   } 
}

Puoi vedere che il file Microsoft.Composition viene aggiunta la dipendenza, ma il problema è che questo pacchetto non è compatibile con dnxcore50. Quindi dobbiamo importareportablenet45+win8+wp8+wpa81. Sostituiamo ora il tuo fileproject.json file con il codice seguente.

{ 
   "version": "1.0.0-*", 
   "buildOptions": { 
      "emitEntryPoint": true 
   }, 
   "dependencies": { 
      "Microsoft.Composition": "1.0.30", 
      "Microsoft.NETCore.App": { 
         "type": "platform", 
         "version": "1.0.1"
      } 
   }, 
   "frameworks": { 
      "netcoreapp1.0": { 
         "imports": "portable-net45+win8+wp8+wpa81" 
      } 
   } 
}

Salva questo file e vedrai che l'errore è stato corretto.

Se espandi i riferimenti, vedrai un riferimento di Microsoft.Composition.

Per prima cosa dobbiamo creare un'interfaccia che deve essere esportata e implementare l'interfaccia e decorare la classe con l'attributo export. Aggiungiamo ora una nuova classe.

Immettere il nome della classe nel campo Nome e fare clic Add.

Aggiungiamo il seguente codice nel file PrintData.cs file.

using System; 
using System.Collections.Generic; 
using System.Composition; 
using System.Linq; 
using System.Threading.Tasks; 
  
namespace MEFDemo { 
   public interface IPrintData { 
      void Send(string message); 
   } 
   [Export(typeof(IPrintData))] 
   public class PrintData : IPrintData { 
      public void Send(string message) { 
         Console.WriteLine(message); 
      } 
   } 
}

Come accennato in precedenza, i cataloghi non sono disponibili nello spazio dei nomi Microsoft.Composition. Quindi, caricherà tutti i tipi dall'Assembly con l'attributo di esportazione e si collegherà all'attributo di importazione come mostrato nel metodo Compose nel file Program.cs.

using System; 
using System.Collections.Generic; 
using System.Composition; 
using System.Composition.Hosting; 
using System.Linq; 
using System.Reflection; 
using System.Threading.Tasks; 
  
namespace MEFDemo { 
   public class Program { 
      public static void Main(string[] args) { 
         Program p = new Program(); 
         p.Run(); 
      } 
      public void Run() { 
         Compose(); 
         PrintData.Send("Hello,this is MEF demo"); 
      } 
      [Import] 
      public IPrintData PrintData { get; set; } 
      
      private void Compose() { 
         var assemblies = new[] { typeof(Program).GetTypeInfo().Assembly }; 
         var configuration = new ContainerConfiguration() 
            .WithAssembly(typeof(Program).GetTypeInfo().Assembly); 
         
         using (var container = configuration.CreateContainer()) { 
            PrintData = container.GetExport<IPrintData>(); 
         } 
      } 
   } 
}

Eseguiamo ora la tua applicazione e vedrai che è in esecuzione istanziando il file PrintData classe.

Per saperne di più su MEF, visita il seguente URL https://msdn.microsoft.com/en-us/library/dd460648%28v=vs.110%29.aspx per ulteriori dettagli.

In questo capitolo verranno illustrate le funzionalità in arrivo in .NET Core. Inizieremo con gli strumenti della riga di comando .NET aprendo il seguente URL nel browserhttps://github.com/dotnet/cli

Per saperne di più sullo stato di avanzamento, puoi scaricare l'ultima versione di .NET Core SDK scorrendo verso il basso e vedrai la sezione Installer and Binaries.

Puoi vedere l'ultima versione degli strumenti di anteprima per diversi sistemi operativi, selezioniamo il programma di installazione in base al tuo sistema operativo.

Stiamo lavorando all'anteprima 1 di .NET Core 2.0.

Esaminiamo ora i nostri strumenti attuali aprendo il prompt dei comandi ed eseguiamo il comando seguente.

dotnet --info

Vedrai le informazioni sulla versione attualmente installata di .NET Command Line Tools sul tuo sistema come mostrato di seguito.

Puoi vedere che attualmente abbiamo gli strumenti di anteprima 2. Eseguiamo ora il seguente comando per vedere i filenew comando.

dotnet help new

Per il nuovo linguaggio di comando del progetto, puoi selezionare come C # e F # e il tipo di progetto, ecc.

Vediamo ora le modifiche nell'ultima versione di .NET Core. Una volta scaricato il programma di installazione, fai doppio clic su di esso per installarlo. Fare clic su Installa.

La seguente schermata mostra il processo di installazione.

Inizierà il processo di installazione. Al termine dell'installazione, chiudere questa finestra di dialogo.

Apri il prompt dei comandi ed esegui il seguente comando.

dotnet --info

Vedrai le informazioni sulla versione attualmente installata di .NET Command Line Tools sul tuo sistema come mostrato di seguito.

È ora possibile vedere che sono disponibili gli strumenti preview1 di .NET Core 2. Eseguiamo ora il codice seguente nel prompt dei comandi per vedere il nuovo comando in .NET Core 2 preview1.

dotnet help new

Il comando ti aiuta anche a scaricare i pacchetti nella cache dei pacchetti.

Il comando apre la seguente pagina Web che contiene informazioni sul nuovo comando in .NET Core 2 preview1.

Scorriamo verso il basso, ora puoi vedere che possiamo creare l'applicazione .NET Core con più modelli.

Ora possiamo creare mstest, web, mvc e webapi progetti anche utilizzando la riga di comando.

.NET Core ha deciso di eliminare project.json e tornare a MSBuild e * .csproj. Questo è già accaduto negli strumenti di anteprima1 di .Net Core 2.0 appena rilasciati. Questo è abbastanza deludente, perché project.json è stata una boccata d'aria fresca. Tuttavia, è comprensibile e presenta anche molti vantaggi.

Parliamo ora dei vantaggi che il cambiamento comporta:

  • Renderebbe semplice la transizione delle soluzioni Visual Studio esistenti a .NET Core.

  • Si tratta di un cambiamento enorme e consentirà anche di sfruttare gli investimenti esistenti in CI / RM basati su MSBuild.

  • Durante la compilazione in MSBuild, possiamo pensare alla compilazione incrementale, alla risoluzione delle dipendenze del tempo di compilazione, alla gestione della configurazione, ecc.

  • È necessario molto lavoro per inviare puntualmente dotnet cli, perché non si tratta più solo di ASP.NET Core, ma anche di app console, app UWP e così via.

Di seguito sono riportate le modifiche in MSBuild e * .csproj:

  • Il file Project.json (* .xproj) verrà sostituito da MSBuild (* .csproj).

  • Le funzionalità in project.json inizieranno a essere unite di nuovo in * .csproj.

  • Non è ancora chiaro cosa faranno dell'elenco dei pacchetti, ma è stato detto che potrebbero tenerlo come json sotto nuget.json o uniscilo nel file *.csproj.

  • Presumibilmente, la transizione dovrebbe essere fluida e potenzialmente automatica se si utilizza Visual Studio.

Vantaggi di MSBuild

  • MSBuild è open source e disponibile su GitHub ed è destinato a diventare completamente multipiattaforma.

  • MSBuild semplificherà e ridurrà notevolmente la struttura di *.csproj.

  • Microsoft sta anche introducendo un nuovo sistema di progetto che consentirà molti scenari senza la necessità di Visual Studio ei dettagli sono forniti su questo Url https://github.com/dotnet/roslyn-project-system/.

  • L'obiettivo è che anche con l'installazione di MSBuild, lavorare con build e progetti sarà semplice nell'IDE di Visual Studio come al di fuori di esso.

MSBuild vs project.json

Creiamo ora un nuovo progetto console con gli strumenti .NET Core preview2 eseguendo il comando seguente.

dotnet new -t console

Per vedere tutti i file creati all'interno di questo progetto, esegui il dir comando.

Puoi vedere che vengono creati due file, Program.cs e project.json file.

Creiamo ora un'app console con gli strumenti di anteprima di .NET Core 2 eseguendo il comando seguente.

dotnet new console

Per vedere tutti i file creati all'interno di questo progetto, esegui il dircomando. Puoi vedere che vengono creati tre file,Program.cs, NuGet.config e MSBuild.csproj invece del file project.json.

Facciamo ora un confronto project.json e MSBuild.csproj file fianco a fianco.

A sinistra, abbiamo il file in formato json mentre a destra, il file è in formato XML. Puoi vedere che nel file project.json, all'interno della sezione delle dipendenze, c'ènetcoreapp1.0, mentre nel file MSBuild.csproj, vedrai il file netcoreapp2.0.

In questo capitolo, discuteremo come ripristinare e creare il file MSBuild (* .csproj) utilizzando l'utilità della riga di comando. Per vedere quali comandi sono disponibili nell'anteprima 1 di .NET Core 2.0, eseguiamo il comando seguente.

dotnet help

Vedrai tutti i comandi come nuovo, ripristino, compilazione, ecc.

Di seguito è riportata l'implementazione predefinita in Program.cs file.

using System;  
namespace MSBuild { 
   class Program { 
      static void Main(string[] args) { 
         Console.WriteLine("Hello World!"); 
      } 
   } 
}

Eseguiamo ora il seguente comando per vedere lo stato di avanzamento.

dotnet build

Vedrai molti errori. Questi errori devono essere corretti.

Eseguiamo ora il seguente comando.

dotnet restore

Puoi vedere che tutti i pacchetti sono stati ripristinati. Sono state inoltre generate alcune nuove cartelle e file.

Per vedere la struttura della directory, eseguiamo il seguente comando.

tree /f

Di seguito è riportata la struttura della directory:

Ricostruiamo ora il progetto eseguendo nuovamente il seguente comando.

dotnet build

Ora il progetto verrà compilato correttamente senza errori e viene creato anche MSBuild.dll.

Per vedere l'output, eseguiamo il seguente comando:

dotnet run

Puoi vedere il seguente output sulla tua console.

In questo capitolo, migreremo l'applicazione console che contiene il file project.json file build system invece di MSBuild (*.csproj). Quindi, abbiamo un vecchio progetto che contiene i seguenti file.

La domanda è: perché abbiamo bisogno della migrazione? Questo progetto è stato creato utilizzando gli strumenti di anteprima 2 di .NET Core 1.0 e ora abbiamo installato gli strumenti di anteprima 1 di .NET Core 2.0. Ora, quando crei questa applicazione utilizzando l'utilità della riga di comando .NET Core 2.0, vedrai il seguente errore.

Questo perché il project.jsonbuild system non è più disponibile in .NET Core 2.0, quindi è necessaria la migrazione in modo che possa funzionare correttamente. Per vedere i comandi disponibili, eseguiamo il seguente comando.

dotnet help

Nella sezione comandi puoi vedere i diversi comandi e puoi anche vedere il file migrate comando che migrerà un progetto basato su project.json in un progetto basato su MSBuild.

Eseguiamo ora il seguente comando.

dotnet migrate

Vedrai un riepilogo del processo di migrazione e qui puoi anche vedere che un progetto è stato migrato correttamente.

Vediamo ora la struttura delle directory utilizzando il seguente comando.

tree /f

Ora vedrai il file * .csproj insieme al file Program.cs nella directory principale del progetto e project.json viene spostato nella cartella di backup.

Apriamo il file console.csprojfile. Ora puoi ripristinare e creare questo progetto utilizzando il sistema MSBuild eseguendo il comando seguente.

dotnet restore

Ora puoi vedere che tutti i pacchetti sono stati ripristinati.

Ora puoi costruire il tuo progetto con il seguente comando.

dotnet build

Ora puoi vedere che il progetto è stato creato con successo utilizzando MSBuild e console.dll viene generato anche in ..\bin\Debug\netcoreapp1.0 cartella.

La seguente schermata mostra la struttura della directory e i file.