.NET Core - Panduan Cepat

.NET Core adalah platform pengembangan tujuan umum terbaru yang dikelola oleh Microsoft. Ini berfungsi di berbagai platform dan telah didesain ulang dengan cara yang membuat .NET cepat, fleksibel, dan modern. Ini merupakan salah satu kontribusi utama Microsoft. Pengembang sekarang dapat membangun aplikasi Android, iOS, Linux, Mac, dan Windows dengan .NET, semuanya dalam Sumber Terbuka.

Dalam tutorial ini, kami akan membahas .NET Core dan beberapa inovasi baru termasuk pembaruan .NET Framework, .NET Standard, dan pembaruan Universal Windows Platform, dll.

Karakteristik .NET Core

Berikut ini adalah karakteristik utama dari .NET Core -

Sumber terbuka

  • .NET Core adalah implementasi open source, menggunakan lisensi MIT dan Apache 2.

  • .NET Core adalah proyek .NET Foundation dan tersedia di GitHub.

  • Sebagai proyek sumber terbuka, ini mempromosikan proses pengembangan yang lebih transparan dan mempromosikan komunitas yang aktif dan terlibat.

Lintas platform

  • Aplikasi yang diimplementasikan dalam .NET Core dapat dijalankan dan kodenya dapat digunakan kembali terlepas dari target platform Anda.

  • Saat ini mendukung tiga sistem operasi utama (OS)

    • Windows

    • Linux

    • MacOS

  • Sistem Operasi (OS), CPU, dan skenario aplikasi yang didukung akan berkembang dari waktu ke waktu, disediakan oleh Microsoft, perusahaan lain, dan individu.

Penerapan fleksibel

  • Ada dua jenis penerapan untuk aplikasi .NET Core -

    • Penerapan yang bergantung pada kerangka kerja

    • Penerapan mandiri

  • Dengan penerapan yang bergantung pada framework, aplikasi Anda bergantung pada versi seluruh sistem .NET Core tempat aplikasi dan dependensi pihak ketiga Anda diinstal.

  • Dengan penerapan mandiri, versi .NET Core yang digunakan untuk membangun aplikasi Anda juga disebarkan bersama dengan aplikasi Anda dan dependensi pihak ketiga dan dapat berjalan berdampingan dengan versi lain.

Alat baris perintah

  • Semua skenario produk dapat dilakukan di baris perintah.

Cocok

  • .NET Core kompatibel dengan .NET Framework, Xamarin dan Mono, melalui .NET Standard Library

Modular

  • .NET Core dirilis melalui NuGet dalam paket perakitan yang lebih kecil.

  • .NET Framework adalah salah satu rakitan besar yang berisi sebagian besar fungsi inti.

  • .NET Core tersedia sebagai paket fitur-sentris yang lebih kecil.

  • Pendekatan modular ini memungkinkan pengembang untuk mengoptimalkan aplikasi mereka hanya dengan memasukkan paket NuGet yang mereka butuhkan dalam aplikasi mereka.

  • Manfaat dari area permukaan aplikasi yang lebih kecil mencakup keamanan yang lebih ketat, layanan yang berkurang, kinerja yang lebih baik, dan penurunan biaya dalam model bayar untuk apa yang Anda gunakan.

Platform Inti .NET

Platform Inti .NET berisi bagian utama berikut -

  • .NET Runtime - Ini menyediakan sistem tipe, pemuatan perakitan, pengumpul sampah, interop asli, dan layanan dasar lainnya.

  • Fundamental Libraries - Satu set pustaka kerangka kerja, yang menyediakan tipe data primitif, tipe komposisi aplikasi, dan utilitas dasar.

  • SDK & Compiler - Sekumpulan alat SDK dan penyusun bahasa yang memungkinkan pengalaman pengembang dasar, tersedia di .NET Core SDK.

  • ‘dotnet’ app host- Digunakan untuk meluncurkan aplikasi .NET Core. Ini memilih runtime dan menghosting runtime, menyediakan kebijakan pemuatan assembly dan meluncurkan aplikasi. Host yang sama juga digunakan untuk meluncurkan alat SDK dengan cara yang hampir sama.

Dalam bab ini, kita akan membahas berbagai dependensi yang perlu Anda terapkan dan jalankan. Ini termasuk aplikasi .NET Core pada mesin Windows yang dikembangkan menggunakan Visual Studio.

Versi Windows yang Didukung

.NET Core didukung pada versi Windows berikut -

  • Windows 7 SP1
  • Windows 8.1
  • Windows 10
  • Windows Server 2008 R2 SP1 (Server Penuh atau Server Core)
  • Windows Server 2012 SP1 (Server Penuh atau Server Core)
  • Windows Server 2012 R2 SP1 (Server Penuh atau Server Core)
  • Windows Server 2016 (Server Penuh, Server Core atau Nano Server)

Dependensi

  • Jika Anda menjalankan aplikasi .NET Core pada versi Windows yang lebih lama dari Windows 10 dan Windows Server 2016, aplikasi tersebut juga memerlukan Visual C ++ Redistributable.

  • Ketergantungan ini secara otomatis diinstal untuk Anda jika Anda menggunakan penginstal .NET Core.

  • Anda perlu menginstal Visual C ++ Redistributable untuk Visual Studio 2015 secara manual jika Anda menginstal .NET Core melalui skrip penginstal atau menyebarkan aplikasi .NET Core mandiri.

  • Untuk mesin Windows 7 dan Windows Server 2008, Anda perlu memastikan bahwa penginstalan Windows Anda mutakhir dan juga menyertakan hotfix KB2533623 yang diinstal melalui Pembaruan Windows.

Prasyarat dengan Visual Studio .NET

  • Untuk mengembangkan aplikasi .NET Core menggunakan .NET Core SDK, Anda dapat menggunakan editor pilihan Anda.

  • Namun, jika Anda ingin mengembangkan aplikasi .NET Core di Windows menggunakan Visual Studio, Anda dapat menggunakan dua versi berikut -

    • Visual Studio 2015

    • Visual Studio 2017 RC

  • Proyek yang dibuat dengan Visual Studio 2015 akan berbasis project.json secara default sementara proyek yang dibuat dengan Visual Studio 2017 RC akan selalu berbasis MSBuild.

Dalam bab ini, kita akan membahas Pengaturan Lingkungan dari .NET Core. Ini adalah desain ulang yang signifikan dari .NETFramework. Untuk menggunakan .NET Core di aplikasi Anda, ada dua versi yang dapat Anda gunakan -

  • Visual Studio 2015
  • Visual Studio 2017 RC

Visual Studio 2015

Untuk menggunakan Visual Studio 2015, Anda harus menginstal berikut ini -

  • Pembaruan Microsoft Visual Studio 2015 3
  • Microsoft .NET Core 1.0.1 - VS 2015 Tooling Preview 2

Microsoft menyediakan versi gratis dari studio visual yang juga berisi SQL Server dan dapat diunduh dari https://www.visualstudio.com/en-us/downloads/download-visual-studio-vs.aspx dan Microsoft .NET Core 1.0.1 - VS 2015 Tooling Preview 2 dapat diunduh dari https://www.visualstudio.com/downloads/

Anda juga dapat mengikuti panduan instalasi di Url berikut https://www.microsoft.com/net/core/#windowsvs2017

Penginstalan Visual Studio 2015

Ikuti langkah-langkah berikut untuk menginstal Visual Studio 2015 -

Step 1- Setelah pengunduhan selesai, jalankan penginstal. Kotak dialog berikut akan ditampilkan.

Step 2 - Klik Install untuk memulai proses instalasi.

Step 3 - Setelah penginstalan selesai, Anda akan melihat kotak dialog berikut.

Step 4 - Tutup dialog ini dan restart komputer Anda jika diperlukan.

Step 5- Buka Visual Studio dari Start Menu; Anda akan menerima kotak dialog berikut. Mungkin perlu beberapa menit untuk memuat dan akhirnya dapat digunakan untuk pertama kali.

Step 6 - Setelah dimuat, Anda akan melihat layar berikut.

Step 7 - Setelah penginstalan Visual Studio selesai, tutup Visual Studio dan luncurkan Microsoft .NET Core - VS 2015 Tooling Preview 2.

Step 8 - Centang kotak dan klik Instal.

Step 9 - Setelah penginstalan selesai, Anda akan melihat kotak dialog berikut.

Sekarang Anda siap untuk memulai aplikasi Anda menggunakan .NET Core.

Visual Studio 2017

Dalam tutorial ini, kami akan menggunakan Visual Studio 2015, tetapi jika Anda ingin menggunakan Visual Studio 2017, rilis eksperimental alat .NET Core untuk Visual Studio disertakan dalam Visual Studio 2017 RC dan Anda dapat melihat panduan penginstalan di sini https://www.microsoft.com/net/core/#windowsvs2017

Visual Studio 2015 menyediakan lingkungan pengembangan berfitur lengkap untuk mengembangkan aplikasi .NET Core. Dalam bab ini, kami akan membuat proyek baru di dalam Visual Studio. Setelah Anda menginstal perkakas Visual Studio 2015, Anda dapat mulai membangun Aplikasi Inti .NET baru.

Dalam New Project kotak dialog, dalam daftar Templat, perluas simpul Visual C # dan pilih .NET Core dan Anda akan melihat tiga templat proyek baru berikut

  • Perpustakaan Kelas (.NET Core)
  • Aplikasi Konsol (.NET Core)
  • Aplikasi Web ASP.NET Core (.NET Core)

Di panel tengah pada kotak dialog Proyek Baru, pilih Aplikasi Konsol (.NET Core) dan beri nama "FirstApp", lalu klik OK.

Visual Studio akan membuka proyek yang baru dibuat, dan Anda akan melihat di jendela Solution Explorer semua berkas yang ada dalam proyek ini.

Untuk menguji apakah aplikasi konsol inti .NET berfungsi, mari kita tambahkan baris berikut.

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!"); 
      } 
   } 
}

Sekarang, jalankan aplikasinya. Anda harus melihat output berikut.

.NET Core mendukung integral numerik standar dan primitif floating-point. Ini juga mendukung jenis berikut -

  • System.Numerics.BigInteger yang merupakan tipe integral tanpa batas atas atau bawah.

  • System.Numerics.Complex adalah jenis yang mewakili bilangan kompleks.

  • Satu set tipe vektor yang mengaktifkan Single Instruction Multiple Data (SIMD) di ruang nama System.Numerics.

Tipe integral

.NET Core mendukung bilangan bulat yang ditandatangani dan tidak ditandatangani dengan rentang yang berbeda dari satu byte hingga delapan byte. Semua bilangan bulat adalah tipe nilai.

Tabel berikut merepresentasikan tipe integral dan ukurannya;

Tipe Ditandatangani / Tidak Ditandatangani Ukuran (byte) Nilai Minimum Nilai maksimum
Byte Tidak ditandatangani 1 0 255
Int16 Tertanda 2 −32.768 32.767
Int32 Tertanda 4 −2.147.483.648 2.147.483.647
Int64 Tertanda 8 −9.223.372.036.854.775.808 9.223.372.036.854.775.807
SByte Tertanda 1 -128 127
UInt16 Tidak ditandatangani 2 0 65.535
UInt32 Tidak ditandatangani 4 0 4.294.967.295
UInt64 Tidak ditandatangani 8 0 18.446.744.073.709.551.615

Setiap tipe integral mendukung satu set standar aritmatika, perbandingan, persamaan, konversi eksplisit, dan operator konversi implisit.

Anda juga dapat bekerja dengan bit individu dalam nilai integer dengan menggunakan kelas System.BitConverter.

Jenis floating-point

.NET Core mencakup tiga tipe floating point primitif, yang ditunjukkan pada tabel berikut.

Tipe Ukuran (byte) Nilai Minimum Nilai maksimum
Dua kali lipat 8 −1.79769313486232e308 1.79769313486232e308
Tunggal 4 −3.402823e38 3.402823e38
Desimal 16 −79.228.162.514.264.337.593,5 43.950.335 79.228.162.514.264.337.593.543,9 50.335
  • Setiap jenis floating-point mendukung satu set standar aritmatika, perbandingan, persamaan, konversi eksplisit, dan operator konversi implisit.

  • Anda juga dapat bekerja dengan bit individual dalam nilai Ganda dan Tunggal dengan menggunakan kelas BitConverter.

  • Struktur Desimal memiliki metodenya sendiri, Decimal.GetBits dan Decimal.Decimal (Int32 ()), untuk bekerja dengan bit individual nilai desimal, serta kumpulan metode sendiri untuk melakukan beberapa operasi matematika tambahan.

BigInteger

  • System.Numerics.BigInteger adalah tipe yang tidak dapat diubah yang mewakili bilangan bulat besar yang nilainya secara teori tidak memiliki batas atas atau bawah.

  • Metode tipe BigInteger sangat mirip dengan metode tipe integral lainnya.

Kompleks

  • Tipe System.Numerics.Complex mewakili bilangan kompleks, yaitu bilangan dengan bagian bilangan real dan bagian bilangan imajiner

  • Ini mendukung seperangkat standar aritmatika, perbandingan, persamaan, konversi eksplisit, dan operator konversi implisit, serta metode matematika, aljabar, dan trigonometri.

SIMD

  • Ruang nama Numerik mencakup serangkaian jenis vektor yang mendukung SIMD untuk .NET Core.

  • SIMD memungkinkan beberapa operasi untuk diparalelkan pada tingkat perangkat keras, yang menghasilkan peningkatan kinerja yang sangat besar dalam aplikasi matematika, ilmiah, dan grafik yang melakukan komputasi melalui vektor.

  • Jenis vektor yang mendukung SIMD di .NET Core termasuk yang berikut -

    • System.Numerics.Vector2, System.Numerics.Vector3, dan System.Numerics.Vector4 berjenis vektor 2, 3, dan 4 dimensi berjenis Single.

    • Struktur Vector <T> yang memungkinkan Anda membuat vektor dari semua tipe numerik primitif. Tipe numerik primitif menyertakan semua tipe numerik di namespace Sistem kecuali untuk Desimal.

    • Dua jenis matriks, System.Numerics.Matrix3 × 2, yang merepresentasikan matriks 3 × 2; dan System.Numerics.Matrix4 × 4, yang merepresentasikan matriks 4 × 4.

    • Jenis System.Numerics.Plane, yang mewakili bidang tiga dimensi, dan jenis System.Numerics.Quaternion, yang mewakili vektor yang digunakan untuk menyandikan rotasi fisik tiga dimensi.

Dalam bab ini, kita akan membahas konsep pengumpulan Sampah yang merupakan salah satu fitur terpenting dari platform kode yang dikelola .NET. Pengumpul sampah (GC) mengelola alokasi dan pelepasan memori. Pengumpul sampah berfungsi sebagai pengelola memori otomatis.

  • Anda tidak perlu mengetahui cara mengalokasikan dan melepaskan memori atau mengelola masa pakai objek yang menggunakan memori tersebut

  • Alokasi dibuat setiap kali Anda mendeklarasikan objek dengan kata kunci "baru" atau jenis nilai dikotakkan. Alokasi biasanya sangat cepat

  • Jika tidak ada cukup memori untuk mengalokasikan objek, GC harus mengumpulkan dan membuang memori sampah agar memori tersedia untuk alokasi baru.

  • Proses ini dikenal sebagai garbage collection.

Keuntungan Pengumpulan Sampah

Pengumpulan Sampah memberikan manfaat berikut -

  • Anda tidak perlu mengosongkan memori secara manual saat mengembangkan aplikasi Anda.

  • Ini juga mengalokasikan objek di heap terkelola secara efisien.

  • Saat objek tidak lagi digunakan, maka objek tersebut akan diambil kembali dengan mengosongkan memorinya, dan membuat memori tetap tersedia untuk alokasi di masa mendatang.

  • Objek yang dikelola secara otomatis mendapatkan konten bersih untuk memulai, sehingga konstruktornya tidak perlu menginisialisasi setiap bidang data.

  • Ini juga memberikan keamanan memori dengan memastikan bahwa suatu objek tidak dapat menggunakan konten objek lain.

Ketentuan Pengumpulan Sampah

Pengumpulan sampah terjadi jika salah satu dari kondisi berikut ini benar.

  • Sistem memiliki memori fisik yang rendah.

  • Memori yang digunakan oleh objek yang dialokasikan di heap terkelola melampaui ambang batas yang dapat diterima. Ambang batas ini terus disesuaikan saat proses berjalan.

  • Itu GC.Collectmetode ini dipanggil dan di hampir semua kasus, Anda tidak perlu memanggil metode ini, karena pengumpul sampah terus berjalan. Metode ini terutama digunakan untuk situasi dan pengujian unik.

Generasi

Pengumpul Sampah .NET memiliki 3 generasi dan setiap generasi memiliki tumpukannya sendiri yang digunakan untuk penyimpanan objek yang dialokasikan. Ada prinsip dasar bahwa kebanyakan benda berumur pendek atau berumur panjang.

Generasi Pertama (0)

  • Di Generasi 0, objek dialokasikan pertama kali.

  • Dalam generasi ini, objek sering kali tidak melewati generasi pertama, karena tidak lagi digunakan (di luar cakupan) saat pengumpulan sampah berikutnya terjadi.

  • Generasi 0 cepat dikumpulkan karena heap terkaitnya kecil.

Generasi Kedua (1)

  • Di Generasi 1, objek memiliki ruang kesempatan kedua.

  • Objek yang berumur pendek tetapi bertahan dari koleksi generasi 0 (sering kali didasarkan pada waktu kebetulan) pergi ke generasi 1.

  • Koleksi Generasi 1 juga cepat karena heap yang terkait juga kecil.

  • Dua heap pertama tetap kecil karena objek dikumpulkan atau dipromosikan ke heap generasi berikutnya.

Generasi Ketiga (2)

  • Di Generasi 2, semua objek panjang hidup dan tumpukannya bisa tumbuh menjadi sangat besar.

  • Objek dalam generasi ini dapat bertahan lama dan tidak ada tumpukan generasi berikutnya untuk mempromosikan objek lebih lanjut.

  • Pengumpul Sampah memiliki tumpukan tambahan untuk benda besar yang disebut Tumpukan Benda Besar (LOH).

  • Ini dicadangkan untuk objek yang berukuran 85.000 byte atau lebih besar.

  • Objek besar tidak dialokasikan ke heap generasi tetapi dialokasikan langsung ke LOH

  • Koleksi Generasi 2 dan LOH membutuhkan waktu yang cukup lama untuk program yang telah berjalan lama atau beroperasi pada data dalam jumlah besar.

  • Program server besar diketahui memiliki tumpukan dalam 10s GB.

  • GC menggunakan berbagai teknik untuk mengurangi jumlah waktu yang menghalangi eksekusi program.

  • Pendekatan utamanya adalah melakukan pekerjaan pengumpulan sampah sebanyak mungkin pada thread latar belakang dengan cara yang tidak mengganggu eksekusi program.

  • GC juga memaparkan beberapa cara bagi pengembang untuk memengaruhi perilakunya, yang bisa sangat berguna untuk meningkatkan kinerja.

Dalam bab ini, kita akan memahami proses eksekusi .NET Core dan membandingkannya dengan .NET Framework. Proses eksekusi terkelola mencakup langkah-langkah berikut.

  • Memilih kompiler
  • Mengompilasi kode Anda ke MSIL
  • Mengompilasi MSIL ke kode asli
  • Menjalankan kode

Memilih Compiler

  • Ini adalah lingkungan eksekusi multi-bahasa, runtime mendukung berbagai tipe data dan fitur bahasa.

  • Untuk mendapatkan manfaat yang disediakan oleh runtime bahasa umum, Anda harus menggunakan satu atau beberapa kompiler bahasa yang menargetkan waktu proses.

Mengompilasi kode Anda ke MSIL

  • Kompilasi menerjemahkan kode sumber Anda ke dalam Microsoft Intermediate Language (MSIL) dan menghasilkan metadata yang diperlukan.

  • Metadata mendeskripsikan tipe dalam kode Anda, termasuk definisi tiap tipe, tanda tangan tiap anggota tipe, anggota yang direferensikan kode Anda, dan data lain yang digunakan runtime pada waktu eksekusi.

  • Runtime mencari dan mengekstrak metadata dari file serta dari framework class library (FCL) sesuai kebutuhan selama eksekusi.

Mengompilasi MSIL ke Kode Asli

  • Pada waktu eksekusi, kompiler just-in-time (JIT) menerjemahkan MSIL ke dalam kode native.

  • Selama kompilasi ini, kode harus melewati proses verifikasi yang memeriksa MSIL dan metadata untuk mengetahui apakah kode tersebut dapat ditentukan sebagai jenis aman.

Menjalankan Kode

  • Runtime bahasa umum menyediakan infrastruktur yang memungkinkan eksekusi berlangsung dan layanan yang dapat digunakan selama eksekusi.

  • Selama eksekusi, kode yang dikelola menerima layanan seperti pengumpulan sampah, keamanan, interoperabilitas dengan kode yang tidak dikelola, dukungan debugging lintas bahasa, serta dukungan penerapan dan versi yang ditingkatkan.

Proses Eksekusi Kode Inti .NET

Sekarang mari kita hubungkan bagaimana kode dijalankan dengan .NET Core dibandingkan dengan .NET Framework. Di .NET Core ada banyak penggantian komponen ini yang merupakan bagian dari .NET Framework.

  • Di .NET Core sekarang kami memiliki rangkaian kompiler baru, seperti kami memiliki Roslyn untuk C # dan VB.

  • Anda juga dapat menggunakan compiler F # 4.1 baru jika Anda ingin menggunakan F # dengan .NET Core.

  • Sebenarnya alat ini berbeda dan kita dapat menggunakan Roslyn dengan .NET Framework juga jika kita menggunakan C # 6 atau yang lebih baru, karena kompiler C # hanya dapat mendukung hingga C # 5.

  • Di .NET Core, kami tidak memiliki perpustakaan kelas kerangka kerja (FCL), sehingga kumpulan perpustakaan yang berbeda digunakan dan kami sekarang memiliki CoreFx.

  • CoreFx adalah implementasi ulang pustaka kelas untuk .NET Core.

  • Kami juga memiliki waktu pengoperasian baru dengan .NET Core yang dikenal sebagai CoreCLR dan memanfaatkan JIT Compiler.

  • Sekarang pertanyaannya adalah mengapa kita memiliki implementasi ulang dari semua komponen ini yang sudah kita miliki dalam kerangka .NET.

  • Jadi jawabannya sama dengan mengapa Microsoft menerapkan .NET Core.

Ini adalah pertimbangan lain dari .NET Core untuk membangun dan mengimplementasikan aplikasi yang modular. Alih-alih menginstal seluruh .NET Framework, aplikasi Anda sekarang dapat menginstal apa yang diperlukan. Mari kita pergi ke studio visual dan melihat modularitasnya.

Berikut adalah aplikasi .NET Core sederhana kami, di Solution Explorer. Izinkan kami memperluas Referensi dan Anda akan melihat referensi ke .NETCoreApp

Di dalam .NETCoreApp, Anda akan melihat referensi paket ke NuGet; mari kita kembangkan.

Anda akan melihat seluruh rangkaian referensi Paket NuGet. Jika Anda telah bekerja di .NETFramework, maka banyak dari ruang nama ini akan terlihat familier, karena Anda sudah terbiasa dengan menggunakan di .NETFramework.

.NETFramework dibagi menjadi banyak bagian berbeda dan diimplementasikan kembali dengan CoreFx; potongan-potongan ini selanjutnya didistribusikan sebagai paket individual.

  • Sekarang jika Anda memperluas NETStandard.Library, Anda akan melihat referensi tambahan. Anda bahkan akan melihat System.Console yang kami gunakan dalam aplikasi ini.

  • Sekarang Anda tidak perlu memasukkan semua yang ada di dalam .NET Framework, tetapi cukup bawa apa yang Anda butuhkan untuk aplikasi Anda.

  • Ada beberapa manfaat lain juga; misalnya, modul-modul ini dapat diperbarui secara individual jika diinginkan.

Modularitas memberikan keuntungan kinerja dan aplikasi Anda dapat berjalan lebih cepat, terutama aplikasi ASP.NET Core.

Dalam bab ini, kita akan membahas file proyek .NET Core dan bagaimana Anda dapat menambahkan file yang ada di proyek Anda.

Mari kita pahami contoh sederhana di mana kita memiliki beberapa file yang sudah dibuat; kami harus menambahkan file-file ini di proyek FirstApp kami.

Berikut adalah implementasi dari Student.cs mengajukan

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; } 
   } 
}

Berikut adalah implementasi dari Course.cs mengajukan.

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; } 
   } 
}

Biarkan kami sekarang menyimpan ketiga file ini di disk Anda dan folder sumber proyek Anda.

  • Sekarang jika Anda terbiasa dengan .NET dan yang ini adalah aplikasi konsol kerangka kerja .NET tradisional, penting untuk memahami cara menambahkan file-file ini dalam proyek Anda di Visual Studio.

  • Pertama-tama Anda perlu menyeret file ke penjelajah solusi untuk menyalinnya di folder proyek Anda, karena proyek Anda memerlukan referensi ke file ini.

  • Salah satu keuntungan dari .NET Core adalah pendekatan yang diambil dengan file proyek (project.json); kita cukup meletakkan file ke root proyek kita dan kemudian ini akan secara otomatis dimasukkan dalam proyek kita.

  • Kami tidak perlu mereferensikan file secara manual seperti yang kami lakukan di masa lalu untuk aplikasi .NET Framework tradisional di Visual Studio.

Sekarang mari kita buka root proyek Anda.

Sekarang mari kita salin ketiga file tersebut ke root proyek Anda.

Sekarang Anda dapat melihat semua file yang disalin ke folder root.

Sekarang mari kita pergi ke Visual Studio; Anda akan menerima kotak dialog berikut.

Klik Yes to All untuk memuat ulang proyek Anda.

Sekarang Anda akan mengetahui bahwa file secara otomatis disertakan dalam proyek Anda.

Di bab ini, kita akan membahas cara menambahkan paket di aplikasi .NET Core Anda dan cara menemukan paket tertentu. Kita bisa langsung pergi ke NuGet dan menambahkan paket, tapi disini kita akan melihat beberapa tempat lain.

Sekarang mari kita pergi ke kode sumber .NET Core yang terletak di sini - https://github.com/dotnet/corefx

Di repo CoreFx, buka file src folder -

Dan Anda akan melihat seluruh daftar folder yang sesuai dengan paket yang berbeda. Sekarang mari kita cari Json -

Ada cara lain untuk menemukan paket Anda, Anda mungkin tahu berbagai jenis jika Anda terbiasa dengan .NETFramework, tetapi perakitan paket di .NET Core sangat berbeda dan Anda tidak akan tahu di mana paket itu masuk.

Jika Anda tahu tipenya, Anda dapat mencari untuk membalikkan pencarian paket dengan menggunakan https://packagesearch.azurewebsites.net/

Di sini Anda dapat memasukkan semua jenis paket yang ingin Anda temukan. Kemudian, situs ini akan memindai NuGet dan menemukan paket yang relevan untuk Anda.

Sekarang mari kita cari DataContractJson.

Sekarang Anda akan melihat bahwa kami mendapatkan paket yang sama; mari kita klik paketnya.

Anda sekarang akan melihat halaman NuGet; Anda perlu mengkonfirmasi bahwa Anda membutuhkan paket ini. Anda dapat menambahkan ini di aplikasi Anda menggunakan beberapa metode.

Mari kita buka 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" 
      } 
   } 
}

Ini adalah format proyek baru dan di dalam file ini Anda akan melihat bagian dependensi. Mari kita tambahkan dependensi baru seperti yang ditunjukkan di bawah ini.

{ 
   "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" 
      } 
   } 
}

Sekarang jika Anda melihat referensi Anda, maka Anda akan melihatnya System.Runtime.Serialization.Json paket ditambahkan ke proyek Anda.

Cara lain adalah pergi ke NuGet Manager dan telusuri paket yang ingin Anda tambahkan.

Pada bab ini, kita akan membahas cara membuat aplikasi UWP menggunakan .NET Core. UWP juga dikenal sebagai aplikasi Windows 10 UWP. Aplikasi ini tidak berjalan pada versi Windows sebelumnya tetapi hanya akan berjalan pada versi Windows yang akan datang.

Berikut adalah beberapa pengecualian di mana UWP akan berjalan lancar.

  • Jika Anda ingin menjalankannya secara lokal, Anda harus memiliki Windows 10, Anda juga dapat mengembangkannya di Windows 8 dan kemudian Anda harus menjalankannya di Emulator, tetapi disarankan untuk menggunakan Windows 10.

  • Untuk aplikasi UWP Anda juga membutuhkan Windows 10 SDK. Mari kita buka penataan Visual Studio 2015 dan kemudian ubah Visual Studio.

  • Pada halaman fitur pilihan, gulir ke bawah dan Anda akan melihat Alat Pengembangan Aplikasi Windows Universal, periksa opsi itu seperti yang ditunjukkan di bawah ini.

Di sini Anda dapat melihat berbagai versi SDK dan pembaruan terbaru pada Alat juga, klik Berikutnya.

Sekarang, klik Install tombol.

Setelah penginstalan selesai, Anda perlu memulai ulang sistem Anda.

Mari kita sekarang mengimplementasikan UWP dengan mengikuti langkah-langkah ini.

  • Pertama, luncurkan Visual Studio 2015.

  • Klik pada menu File dan pilih New → Project; dialog New Project akan muncul. Anda dapat melihat berbagai jenis templat di panel kiri kotak dialog.

  • Di panel kiri, Anda dapat melihat tampilan hierarki, sekarang pilih Template universal dari Template → Visual C # → Windows.

  • Dari panel tengah, pilih template Aplikasi Kosong (Universal Windows).

  • Beri nama proyek dengan mengetik UWPFirstApp di kolom Name dan klik OK.

  • Dialog versi target / versi minimum muncul. Pengaturan default baik-baik saja untuk tutorial ini, jadi pilih OK untuk membuat proyek.

  • Di sini, kami memiliki satu proyek yang dapat menargetkan semua Perangkat Windows 10, dan Anda akan melihat bahwa .NET Core dan UWP adalah penyederhanaan multi-penargetan.

  • Ketika proyek baru terbuka, file-nya ditampilkan di sisi kanan panel Penjelajah Solusi. Anda mungkin perlu memilih tab Penjelajah Solusi daripada tab Properti untuk melihat file Anda.

  • Meskipun Aplikasi Kosong (Jendela Universal) adalah template minimal, namun masih berisi banyak file. File-file ini penting untuk semua aplikasi UWP yang menggunakan C #. Setiap proyek yang Anda buat di Visual Studio berisi berkas.

  • Untuk melihat contoh yang sedang berjalan, mari kita buka MainPage.XAML dan tambahkan kode berikut.

<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 bawah ini adalah peristiwa klik tombol di 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"; 
      } 
   } 
}

Sekarang mari kita jalankan kode di atas pada mesin lokal dan Anda akan melihat jendela berikut. Sekarang ketikkan nama apa pun di kotak teks dan tekanClick Me tombol.

Pada bab ini, kita akan membahas apa itu MSBuild dan cara kerjanya dengan .NET Core. MSBuild adalah platform pembuatan untuk Microsoft dan Visual Studio. Pada aplikasi UWP jika Anda membuka folder project, maka Anda akan melihat file project.json dan * .csproj.

Tetapi jika Anda membuka aplikasi .NET Core Console kami sebelumnya, Anda akan melihat file project.json dan * .xproj.

  • Sistem build .NET Core atau sistem build project.json tidak cukup untuk kebutuhan UWP; inilah mengapa UWP masih menggunakan sistem Build * .csproj (MSBuild).

  • Tapi project.json akan pindah sejauh menyangkut sistem build.

  • Sekarang jika Anda ingin menambahkan beberapa file yang ada ke aplikasi UWP Anda seperti yang telah kami tambahkan di aplikasi Console, Anda perlu menambahkan file tersebut di folder proyek. Selanjutnya, Anda juga perlu memasukkan proyek Anda di Solution Explorer juga.

Sekarang mari kita pertimbangkan file-file berikut; salin file ini ke folder proyek Anda.

Mari kita kembali ke Visual Studio dan buka Solution Explorer.

  • Sekarang Anda dapat melihat bahwa hanya menyalin file tidak cukup dalam kasus aplikasi UWP, karena di Solution Explorer, kami tidak dapat melihat file tersebut.

  • Sekarang kita harus memasukkan file-file itu juga dengan mengklik Show All Files ikon seperti yang disorot pada gambar di atas dan Anda akan melihat sekarang semua file di folder proyek.

Kedua file ini masih belum termasuk dalam proyek kami. Untuk menyertakan file-file ini, pilih file-file ini dan klik kanan pada file apa saja lalu pilihInclude in Project.

Sekarang file-file ini juga disertakan. Satu hal baik yang dapat diramalkan adalah pendekatan project.json untuk menjatuhkan file untuk * .csproj di versi alat SKD yang akan datang dan juga ke Visual Studio.

Dalam bab ini, kita akan membahas referensi antara aplikasi Konsol dan aplikasi UWP kita. Jika Anda melihat Referensi di Solution Explorer aplikasi Konsol Anda, Anda akan melihat .NETCoreApp seperti yang ditunjukkan di bawah ini.

.NETCoreApp adalah kerangka kerja baru yang menargetkan aplikasi .NET Core. Sekarang jika Anda melihat di bawah Referensi aplikasi UWP, itu akan terlihat sedikit berbeda seperti gambar di bawah ini.

  • Alasan utama untuk ini adalah karena di UWP kami memiliki * .csproj, jadi kami kembali ke gaya referensi lama dan kami hanya dapat menargetkan satu kerangka kerja dengan jenis proyek ini.

  • Namun referensinya serupa. Sekarang Anda dapat melihat bahwa di aplikasi UWP, referensi Miscrosoft.NETCore.UniversalWindowsPlatform NuGet Package mirip dengan referensi Microsoft.NETCore.App NuGet di aplikasi Console.

  • Baik Miscrosoft.NETCore.UniversalWindowsPlatform dan Microsoft.NETCore.App adalah meta-paket yang berarti bahwa mereka terdiri dari paket lain.

  • Dalam aplikasi Console, kita dapat menelusuri dan melihat paket lain di dalam Microsoft.NETCore.App, tetapi kita tidak dapat melakukan Miscrosoft.NETCore.UniversalWindowsPlatform yang sama di Solution Explorer.

  • Namun, kita dapat menggunakan alat lain, Penjelajah Paket NuGet untuk melihat ini. Sekarang mari kita buka url ini di browser -https://npe.codeplex.com/downloads/get/clickOnce/NuGetPackageExplorer.application dan Anda akan melihat utilitas kecil sedang mengunduh.

  • Setelah pengunduhan selesai, klik dua kali pada file itu.

  • Klik Install untuk memulai penginstalan di NuGet Package Explorer.

  • Setelah penginstalan selesai, Anda akan melihat kotak dialog berikut.

  • Sekarang mari kita klik Open a package from online feed pilihan.

  • Secara default akan mencari feed nuget.org. Mari kita sekarang mencari Microsoft.NETCore.UniversalWindowsPlatform di kotak pencarian dan Anda akan melihat 1 hasil seperti yang ditunjukkan di bawah ini.

  • Klik open link dan itu akan membuka dependensi tingkat atas dari metapackage ini.

  • Sekarang mari kita buka paket meta .NETCore untuk aplikasi .NETCore dan paket meta untuk aplikasi UWP secara berdampingan.

  • Sekarang Anda dapat melihat bahwa setiap meta-paket terdiri dari kumpulan paket yang berbeda.

  • .NET Core adalah bagian dari kelas yang tersedia di .NET Framework setidaknya pada saat ini, tetapi sedang berkembang dan akan sesuai dengan kelas dasar .NET Framework.

  • UWP didasarkan pada .NET Core, ini adalah superset dari API yang tersedia untuk pengembangan Windows Store.

Kami sekarang memiliki lebih banyak API yang tersedia untuk pengembangan karena .NET Core.

Komponen Windows Runtime adalah objek mandiri yang dapat Anda buat dan gunakan dari bahasa apa pun, termasuk C #, Visual Basic, JavaScript, dan C ++. Selain meta-package .NET Core yang kita lihat di bab sebelumnya, aplikasi UWP juga memiliki referensi default ke Universal Windows SDK.

Universal Windows adalah referensi ke Windows Runtime dan telah diperhitungkan dalam serangkaian kontrak API.

Kumpulan API dalam keluarga perangkat dipecah menjadi subdivisi yang dikenal sebagai kontrak API. Anda dapat menemukan daftar kontrak API yang berbeda di sinihttps://msdn.microsoft.com/en-us/library/windows/apps/dn706135.aspx

Sebagian besar API tersebut di dalam runtime jendela difaktorkan ke dalam satu kontrak. Sekarang mari kita mencari kata kunci Universal di halaman Kontrak API.

Anda dapat melihat tautan ke berbagai API dan Anda juga dapat melihat keluarga Universal begitu besar sehingga memiliki 12 halaman dokumentasi.

Anda juga dapat mencari kontrak API telepon di halaman ini.

Sekarang mari kita klik Windows.Phone.PhoneContractdan gulir ke bawah; Anda sekarang akan melihat informasi baterai telepon atau perangkat seluler.

Jika Anda ingin menambahkan informasi ini di atas apa yang sudah Anda miliki, maka Anda harus menambahkan referensi secara manual. Mari kita sekarang pergi ke Visual Studio dan klik kanan pada Referensi di Solution Explorer.

Pilih Add References…

Sekarang Anda dapat melihat kategori referensi baru untuk Universal Windows; di bawah kategori ini terdapat Core yang mengacu pada kontrak API Windows Universal inti

  • Ekstensi memungkinkan kami untuk memperluas fungsionalitas dan Anda akan melihat referensi berbeda Seluler, Desktop dan Ekstensi lainnya.

  • Ada berbagai ekstensi SKD dan Anda dapat menambahkan di atasnya untuk mendapatkan lebih banyak API.

  • Anda juga dapat melihat versi yang berbeda. Jadi, pastikan Anda mendapatkan versi terbaru untuk mendapatkan API yang diperbarui, lalu klik OK.

Sekarang Anda bisa melihatnya Windows Mobile Extensions for the UWP ditambahkan sebagai referensi.

Pustaka kelas mendefinisikan tipe dan metode yang bisa dipanggil dari aplikasi apa pun.

  • Pustaka kelas yang dikembangkan menggunakan .NET Core mendukung Pustaka Standar .NET, yang memungkinkan pustaka Anda dipanggil oleh platform .NET apa pun yang mendukung versi Pustaka Standar .NET tersebut.

  • Saat Anda menyelesaikan pustaka kelas, Anda bisa memutuskan apakah Anda ingin mendistribusikannya sebagai komponen pihak ketiga, atau apakah Anda ingin memasukkannya sebagai komponen yang dipaketkan dengan satu atau beberapa aplikasi.

Mari kita mulai dengan menambahkan proyek perpustakaan kelas di aplikasi Konsol kita; klik kanan padasrc folder di Solution Explorer dan pilih Add → New Project…

Dalam Add New Project kotak dialog, pilih node .NET Core, lalu pilih template proyek Class Library (.NET Core).

Di kotak teks Name, masukkan "UtilityLibrary" sebagai nama proyek, seperti yang ditunjukkan gambar berikut.

Klik Oke untuk membuat proyek perpustakaan kelas. Setelah proyek dibuat, mari kita tambahkan kelas baru. Klik kananproject di Solution Explorer dan pilih Add → Class...

Pilih kelas di panel tengah dan masukkan StringLib.cs di nama dan bidang lalu klik Add. Setelah kelas ditambahkan, maka ganti kode berikut di 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); 
      } 
   } 
}
  • Perpustakaan kelas, UtilityLibrary.StringLib, berisi beberapa metode seperti, StartsWithUpper, StartsWithLower, dan StartsWithNumber yang mengembalikan nilai Boolean yang menunjukkan apakah instance string saat ini dimulai dengan huruf besar, huruf kecil, dan angka.

  • Di .NET Core, file Char.IsUpper Metode mengembalikan nilai benar jika karakter dalam huruf besar, metode Char.IsLower mengembalikan nilai benar jika karakter dalam huruf kecil, dan demikian pula metode Char.IsNumber mengembalikan nilai benar jika karakter adalah numerik.

  • Pada bilah menu, pilih Bangun, Bangun Solusi. Proyek harus dikompilasi tanpa kesalahan.

  • Proyek konsol .NET Core kami tidak memiliki akses ke perpustakaan kelas kami.

  • Sekarang untuk menggunakan pustaka kelas ini, kita perlu menambahkan referensi pustaka kelas ini di proyek konsol kita.

Untuk melakukannya, perluas FirstApp dan klik kanan pada Referensi dan pilih Add Reference…

Di kotak dialog Manajer Referensi, pilih UtilityLibrary, proyek perpustakaan kelas kami, dan kemudian klik OK.

Sekarang mari kita buka file Program.cs dari proyek konsol dan ganti semua kode dengan kode berikut.

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); 
      } 
   } 
}

Sekarang mari kita jalankan aplikasi Anda dan Anda akan melihat output berikut.

Untuk pemahaman yang lebih baik, mari kita gunakan metode ekstensi lain dari perpustakaan kelas Anda dalam proyek Anda.

Pada bab ini kita akan membahas apa itu PCL (Portable Class Library), dan juga mengapa kita membutuhkan PCL. Untuk memahami konsep ini, mari kita buka folder proyek perpustakaan kelas yang telah kita buat di bab sebelumnya.

Di folder ini, Anda dapat melihat bahwa selain file project.json dan CS kami juga memiliki file * .xproj, dan itu karena Visual Studio menyiapkan jenis proyek .NET Core sebagai * .xproj daripada * .csproj.

Seperti yang disebutkan oleh Microsoft, * .xproj akan ditiadakan, tetapi masih ada di alat pratinjau 2. Seperti yang telah kita bahas bahwa aplikasi UWP menggunakan * .csproj.

Sekarang sebenarnya tidak layak untuk mendapatkan * .csproj sebagai referensi dan * .xproj dan fungsionalitas itu tidak akan diimplementasikan karena * .xproj akan dipindahkan.

Jadi sebagai gantinya, kita membutuhkan pustaka kelas yang dapat dibagikan antara aplikasi konsol dan aplikasi UWP dan inilah PCL.

Apa itu PCL

Sekarang mari kita pahami apa itu PCL -

  • Proyek Perpustakaan Kelas Portabel memungkinkan Anda untuk menulis dan membangun rakitan terkelola yang bekerja di lebih dari satu platform .NET Framework.

  • Anda dapat membuat kelas yang berisi kode yang ingin Anda bagikan ke banyak proyek, seperti logika bisnis bersama, lalu mereferensikan kelas tersebut dari berbagai jenis proyek.

  • Ini juga dapat membantu Anda membangun aplikasi dan perpustakaan lintas platform untuk platform Microsoft dengan cepat dan mudah.

  • Pustaka kelas portabel dapat membantu Anda mengurangi waktu dan biaya pengembangan dan pengujian kode.

  • Gunakan jenis proyek ini untuk menulis dan membangun rakitan .NET Framework portabel, lalu mereferensikan rakitan tersebut dari aplikasi yang menargetkan beberapa platform seperti Windows dan Windows Phone, dll.

Sekarang mari kita hapus pustaka kelas yang telah kita buat dari Solution Explorer. Pada saat yang sama, hapus dari folder Solusi dan selanjutnya tambahkan item proyek baru.

Pilih Visual C# → Windows template di panel kiri dan pilih Class Library (Portable) di panel tengah.

Masukkan StringLibrary di bidang nama dan klik OK untuk membuat proyek ini.

Sekarang kita perlu memilih kerangka kerja target untuk referensi. Mari kita pilih sebentar Windows Universal dan ASP.NET Core kemudian kita akan targetkan ulang. KlikOK.

Anda dapat melihat bahwa itu telah membuat proyek baru dalam format PCF. Mari kita sekarang klik kanan proyek StringLibrary di Solution Explorer dan pilih Properties.

Klik pada Target .NET Platform Standard.

Klik Ya; sekarang perpustakaan kelas yang sama dengan satu perbedaan kecil. Perbedaannya adalah UWP juga dapat digunakan oleh UWP, karena berisi file * .csproj, bukan * .xproj.

Sekarang mari kita tambahkan kelas baru; untuk ini, Anda perlu mengklik kanan pada proyek di Solution Explorer dan pilihAdd → Class...

Pilih kelas di panel tengah dan masukkan StringLib.cs di bidang nama dan kemudian Klik Add. Setelah kelas ditambahkan, maka ganti kode berikut di 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); 
      } 
   } 
}

Mari kita membangun proyek perpustakaan kelas portabel ini dan harus dikompilasi tanpa kesalahan. Sekarang kita perlu menambahkan referensi perpustakaan kelas portabel ini di proyek konsol kita. Jadi, perluas FirstApp dan klik kanan pada Referensi dan pilihAdd Reference…

Di kotak dialog Manajer Referensi, pilih StringLibrary yang merupakan proyek perpustakaan kelas portabel kami, lalu klik OK.

Anda dapat melihat bahwa referensi StringLibrary ditambahkan ke proyek konsol dan juga dapat dilihat di file project.json.

Sekarang Anda dapat menjalankan aplikasi lagi dan Anda akan melihat output yang sama.

Sekarang, mari kita gunakan metode ekstensi lain dari perpustakaan kelas portabel Anda dalam proyek Anda. Pustaka portabel yang sama akan digunakan dalam aplikasi UWP Anda juga.

Pada bab ini, kita akan membahas bagaimana menambahkan referensi ke perpustakaan Anda. Menambahkan referensi ke perpustakaan seperti menambahkan referensi ke proyek Anda yang lain, seperti proyek konsol dan proyek UWP.

Sekarang Anda dapat melihat bahwa proyek PCL memiliki beberapa referensi secara default. Anda juga dapat menambahkan referensi lain sesuai kebutuhan aplikasi Anda.

Di perpustakaan PCL, Anda juga dapat melihat file project.json.

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

Salah satu metode untuk menambahkan referensi ke perpustakaan Anda adalah dengan mengetiknya langsung di file project.json. Seperti yang Anda lihat bahwa kami telah menambahkan beberapa referensi di bawah bagian dependensi seperti yang ditunjukkan pada kode berikut.

{ 
   "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": {} 
   } 
}

Biarkan kami sekarang menyimpan file ini dan Anda akan melihat bahwa referensi telah ditambahkan ke perpustakaan Anda sekarang.

Metode lain untuk menambahkan referensi ke perpustakaan Anda adalah NuGet Package Manager. Mari kita sekarang klik kanan padaStringLibrary (Portable) proyek dan pilih Mange NuGet Packages…

Pada tab Browse, Anda dapat mencari paket NuGet apa saja; misalkan kita ingin menambahkan paket "System.Runtime.Serialization.Primitives".

Klik Install tombol, yang akan menampilkan layar berikut.

Sekarang, klik OK tombol.

Terakhir, klik I Accepttombol untuk memulai instalasi paket NuGet ini. Setelah instalasi selesai, Anda akan melihat bahwa paket NuGet “System.Runtime.Serialization.Primitives” telah ditambahkan ke perpustakaan Anda.

Dalam bab ini, kami akan membahas cara membagikan perpustakaan Anda sebagai NuGet Packagesehingga dapat digunakan dalam proyek lain. Membuat paket dimulai dengan kode yang ingin Anda paketkan dan bagikan dengan orang lain, baik melalui galeri nuget.org publik atau galeri pribadi dalam organisasi Anda. Paket juga dapat menyertakan file tambahan seperti filereadme yang ditampilkan saat paket diinstal, dan dapat menyertakan transformasi ke file proyek tertentu.

Sekarang mari kita pertimbangkan contoh sederhana di mana kita akan membuat paket NuGet dari perpustakaan kita. Untuk melakukannya, buka command prompt dan masuk ke folder tempat file project.json dari proyek perpustakaan Anda berada.

Sekarang mari kita jalankan perintah berikut.

dotnet help

Pada akhirnya, Anda dapat melihat berbagai perintah seperti baru, memulihkan dan membangun, dll.

Perintah terakhir adalah pack;ini akan membuat paket NuGet. Sekarang mari kita jalankan perintah berikut.

dotnet pack

Sekarang Anda dapat melihat bahwa paket NuGet diproduksi di folder bin; mari kita buka folder bin \ Debug.

Sekarang pertanyaannya adalah apa yang ada di dalam paket NuGet, untuk melihat bahwa kita dapat menggunakan Penjelajah Paket NuGet. Sekarang mari kita buka Penjelajah Paket NuGet.

Pilih opsi pertama Open a local package.

Pilih StringLibrary.1.0.0.nupkg dan klik Open.

Anda dapat melihat bahwa di bagian Isi paket kami hanya memiliki StringLibrary.dll. Di bagian Metadata paket, Anda akan melihat sedikit informasi tentang pustaka ini seperti Id, Versi, dan semua dependensi.

Sekarang mari kita buka StringLibrary.1.0.0.symbols.nupkg.

Dalam paket NuGet ini, Anda akan melihat file sumber dan *.pdbmengajukan juga. Jika Anda mengklik dua kali fileStringLib.cs file, Anda akan melihat kode sumbernya juga.

Di sini pertanyaannya adalah, bagaimana cara mengkonfigurasi metadata seperti versi, penulis dan deskripsi, dll.

File project.json digunakan pada proyek .NET Core untuk menentukan metadata proyek, informasi kompilasi, dan dependensi. Sekarang mari kita buka file project.json dan tambahkan informasi tambahan berikut.

{ 
   "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": {} 
   } 
}

Anda sekarang dapat melihat informasi tambahan seperti nama penulis, deskripsi dan versi ditambahkan di sini. Mari kita simpan file ini, buat proyek perpustakaan, lalu jalankan kembali perintah "paket dotnet".

Di dalam folder bin \ Debug, Anda dapat melihat bahwa paket StringLibrary NuGet diproduksi dengan versi 1.0.1; mari kita buka di NuGet Package Explorer.

Anda akan melihat metadata yang diperbarui. Pertanyaannya sekarang adalah, bagaimana kita bisa menggunakannya di paket lain.

Kita perlu mulai dengan menerbitkan di suatu tempat di feed NuGet dan kemudian kita dapat menggunakannya di proyek lain.

Ada dua opsi untuk menerbitkan metadata yang diperbarui -

  • Publikasikan ke nuget.org
  • Dorong metadata ke umpan NuGet pribadi

Di sini kita akan menggunakan feed NuGet pribadi karena jauh lebih mudah daripada membuat akun di nuget.org. Untuk mempelajari cara mempublikasikan paket Anda ke nuget.org, Anda dapat mengikuti semua pedoman yang ditentukan di sinihttps://docs.microsoft.com/en-us/nuget/create-packages/publish-a-package.

Ikuti langkah-langkah berikut untuk memasukkan metadata yang diperbarui ke umpan NuGet pribadi.

Step 1- Untuk memulai, kita memerlukan utilitas baris perintah nuget dan kita harus menginstalnya. Sekarang mari kita buka NuGet Package Manager dan cari nuget.commandline.

Step 2 - Pilih Nuget.Commandline dan klik Install.

Step 3 - Klik OKuntuk menginstal Nuget.Commandline. Anda juga dapat menginstalnya secara manual dengan mengunduhnya dari Url berikuthttps://dist.nuget.org/index.html dan kemudian menyiapkan variabel lingkungan.

Step 4 - Setelah instalasi selesai, mari kita buka command prompt lagi dan pergi ke bin\Debug folder tempat paket NuGet berada dan tentukan perintah berikut -

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

Step 5 - Pada perintah di atas, kami menambahkan paket StringLibrary.1.0.1.nupkg ke umpan pribadi kami dan lokasinya adalah D:\PrivateNugetPackages, -Source menentukan sumber paket.

Step 6 - Anda dapat melihat bahwa StringLibrarydipasang; ituStringLibrary selanjutnya dapat ditambahkan ke umpan pribadi.

Step 7 - Ayo kita pergi ke folder itu.

Step 8 - Di dalam stringlibrary folder, Anda akan melihat folder lain dengan nama versi dan ini adalah 1.0.1.

Paket NuGet ada di sini.

Pada bab ini, kita akan membahas bagaimana menggunakan paket NuGet yang telah kita buat dan publikasikan ke feed NuGet pribadi. Jadi, pertama kita akan membuat proyek Xamarin.Forms. Pertama-tama kita perlu memahami apa itu Xamarin.Forms.

  • Xamarin.Forms adalah kerangka kerja yang memungkinkan pengembang dengan cepat membuat antarmuka pengguna lintas platform.

  • Xamarin.Forms adalah abstraksi toolkit UI yang didukung secara native lintas platform yang memungkinkan pengembang dengan mudah membuat antarmuka pengguna yang dapat digunakan bersama di Android, iOS, Windows, dan Windows Phone.

  • Antarmuka pengguna dirender menggunakan kontrol asli dari platform target, memungkinkan aplikasi Xamarin.Forms mempertahankan tampilan dan nuansa yang sesuai untuk setiap platform.

Untuk memulai Xamarin.Forms, kami memerlukan beberapa fitur tambahan di Visual Studio 2015. Mari kita ubah Visual Studio 2015 Anda dan pastikan opsi pengembangan seluler lintas platform berikut dipilih.

Setelah instalasi selesai, mari kita perbarui Xamarin dengan memilih Tools → Options…

Gulir ke bawah dan luaskan Xamarin di panel kiri lalu pilih Other. Di pojok kanan atas kotak dialog, klikCheck Now untuk melihat apakah pembaruan tersedia.

Anda dapat melihat bahwa pembaruan tersedia, mari kita klik Downloadtombol untuk mulai mengunduh. Setelah pengunduhan selesai, Anda akan diberitahu untuk menginstal pembaruan.

Sekarang mari kita buka Visual studio lagi dan pilih File → New → Project… opsi menu.

Di panel kiri, pilih file Visual C# → Cross-Platform template dan di panel tengah, pilih Blank Xaml App (Xamarin.Forms Portable). Masukkan nama di kolom Name dan klik OK.

Pilih Versi Target dan Versi Minimum dan klik OK.

Anda akan melihat serangkaian proyek; di bagian atas kami memiliki pustaka PCL yang akan dibagikan di antara semua platform seperti Android, iOS, UWP, Windows 8.1, dan Windows Phone 8.1.

Di sini, kami akan fokus pada pustaka PCL dan akan membawa beberapa kode ke sini. Mari kita kembangkan kodenya.

Dalam template Xamarin.Forms ini, Anda dapat melihat App.xaml dan MainPage.xaml generik, menggunakan kerangka kerja Xamarin.Forms XAML yang bekerja di seluruh platform ini.

Kami perlu mengimpor kode kami dan kami juga membutuhkan umpan NuGet pribadi yang kami siapkan di bab terakhir.

Sekarang mari kita buka NuGet Package Manager. Klik roda di samping daftar tarik-turun Sumber paket.

Kita perlu menambahkan umpan pribadi kita di sini, mari kita klik plus (+) button.

Anda akan melihat bahwa kotak centang lain ditambahkan di Available package sources bagian, mari kita tentukan nama dan jalur sumber dan klik OK.

Sekarang mari kita pergi ke tab Browse dan pilih PrivateSource dari daftar dropdown Package source dan Anda akan melihat paket StringLibrary NuGet. Pilih StringLibrary dan klikInstall.

Klik OK dan Anda akan melihat satu kesalahan.

Kami tidak dapat menggunakan perpustakaan dengan profil .NETPortable versi 259, kami akan memperbaiki kesalahan ini di bab berikutnya.

Dalam bab ini, kami akan memperbaiki kesalahan yang kami dapatkan saat menginstal paket NuGet dari umpan pribadi kami di proyek Xamarin.Forms.

Kami akan memahami masalahnya secara singkat. Untuk memulai, mari kita klik kanan pada perpustakaan PCL dan pilih Properties.

Di halaman ini, Anda akan melihat seluruh rangkaian kerangka kerja yang ditargetkan. Dari kesalahan tersebut, Anda dapat melihat bahwa profil .NETPortable 259 tidak kompatibel dengan StringLibrary 1.0.1 kami. Namun, mencoba untuk mengambil referensi dari pustaka .NET Standard 1.1.

Sekarang, mari kita lihat Perpustakaan Standar .NET dan mengidentifikasi platform mana yang tidak kompatibel dengan perpustakaan kami.

Anda dapat melihat bahwa Windows Phone Silverlight 8 kompatibel dengan .NET Standard 1.0. Jika Anda membuka halaman web berikut, Anda akan melihat bahwa Profile259 hanya dapat mendukung .NET Standard 1.0.

Sekarang mari kita hapus centang pada Windows Phone Silverlight 8.

Klik OK tombol.

Sekarang untuk memperbaiki masalah ini klik OK dan batalkan dialog Ubah Target dan kemudian buka Konsol Manajer Paket dan jalankan perintah berikut.

PM > Uninstall-Package Xamarin.Forms

Sekarang mari kita pergi ke Properties of PCL library. Klik pada tombol Ubah.

Hapus centang Windows Phone Silverlight 8 dan Klik OK.

Sekarang Anda dapat melihat bahwa Windows Phone Silverlight 8 tidak lagi tersedia dalam kerangka kerja Bertarget. Anda juga bisa melihat profil yang menjadi target sekarang. Untuk melihat ini, mari kita bongkar pustaka PCL dan edit file XamarinApp.csproj.

Anda sekarang dapat melihat bahwa TargetFrameworkProfile sekarang menjadi Profile111.

Jika Anda membuka dokumentasi, maka Anda akan melihat bahwa Profile111 mendukung .NET Standard 1.1.

Sekarang mari kita muat ulang PCL lagi dan buka NuGet Package Manager dan coba instal paket StringLibrary dari umpan pribadi.

Dari daftar tarik-turun Perilaku ketergantungan, pilih Abaikan Ketergantungan dan kemudian klik Install.

Anda dapat melihat bahwa paket StringLibrary sekarang diinstal dari umpan pribadi. Jika Anda memperluas Referensi PCL, maka Anda akan melihat bahwa referensi StringLibrary juga ditambahkan seperti yang ditunjukkan di bawah ini.

Kami telah mencopot pemasangan Xamarin.Forms untuk masalah Windows Phone Silverlight 8. Xamarin.Forms perlu diinstal lagi. Direkomendasikan agar versi yang sama diinstal.

Setelah penginstalan selesai, izinkan kami menggunakan fungsionalitas StringLibrary di aplikasi Anda.

Pada bab ini, kita akan membahas cara membuat proyek Pengujian menggunakan .NET Core. Pengujian unit adalah proses pengembangan perangkat lunak yang memiliki bagian terkecil yang dapat diuji dari suatu aplikasi, yang disebut unit. Mereka secara individu dan independen diteliti untuk setiap operasi yang tepat. Pengujian unit dapat dilakukan secara otomatis atau dilakukan secara manual juga.

Sekarang mari kita buka kotak dialog Proyek Baru dan pilih Visual C# → .NET Core template.

Pada kotak dialog ini, Anda dapat melihat bahwa tidak ada template proyek untuk pengujian unit. Untuk membuat proyek uji unit, kita harus menggunakan utilitas baris perintah. Mari kita masuk ke folder Solution yang kita buat; buat folder uji dan di dalam folder uji buat folder lain dan beri namaStringLibraryTests.

Sekarang mari kita menggunakan utilitas baris perintah dotnet untuk membuat proyek uji baru dengan menjalankan perintah berikut -

dotnet new -t xunittest

Sekarang Anda dapat melihat bahwa proyek C # baru dibuat; mari kita lihat folder tersebut dengan menjalankan filev perintah dan Anda akan lihat project.json dan Tests.cs file seperti yang ditunjukkan di bawah ini.

Berikut adalah kode di 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" 
         ] 
      } 
   } 
}

Berikut adalah kode di file Test.cs.

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

Untuk mengambil dependensi yang diperlukan dari NuGet, mari kita jalankan perintah berikut -

dotnet restore

Kami dapat menjalankan pengujian ketika dependensi yang diperlukan dipulihkan.

Anda dapat melihat bahwa kompilasi berhasil; saat Anda turun, Anda dapat melihat beberapa informasi tentang pengujian yang dijalankan.

Saat ini kami memiliki 1 tes yang dijalankan, 0 kesalahan, 0 gagal, 0 dilewati dan waktu yang dibutuhkan oleh proses eksekusi juga disebutkan sebagai informasi.

Pada bab ini, kita akan membahas bagaimana menjalankan tes di Visual Studio. .NET Core telah dirancang dengan mempertimbangkan kemampuan pengujian, sehingga membuat pengujian unit untuk aplikasi Anda lebih mudah daripada sebelumnya. Dalam bab ini, kami akan menjalankan dan menjalankan proyek pengujian kami di Visual Studio.

Mari kita buka solusi FirstApp di Visual Studio.

Anda dapat melihat bahwa ini hanya memiliki dua proyek dan Anda tidak akan dapat melihat proyek uji karena kami belum menambahkan proyek itu dalam solusi kami.

Mari kita tambahkan folder dulu dan beri nama test.

Klik kanan pada file test map.

Pilih project.json file dan klik Open.

Tangkapan layar berikut menunjukkan kode dalam Tests.cs file sebagai output.

Ini adalah implementasi default dan hanya menguji apakah True sama dengan true. Ini adalah framework pengujian xUnit dan Anda akan melihat atribut Fact yang menjelaskan dan menunjukkan metode pengujian.

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

Berikut adalah implementasi dari project.json mengajukan.

{ 
   "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 project.jsonfile, ketergantungan paling penting ke framework pengujian adalah xunit, yang membawa atribut Fact. Ini membawa kerangka pengujian dan API untuk pengujian dengan xunit.

Kami juga memiliki dotnet-test-xunit, ini adalah adopter sehingga xunit dapat bekerja dengan .NET Core, khususnya dengan .NET dotnet testutilitas baris perintah. Kemudian Anda akan melihattestRunner yang akan menjalankan xunit dan Anda juga dapat melihat file netcoreapp1.0 kerangka.

Anda akan melihat dependen .NETCore.App di bawah ini.

Untuk menjalankan pengujian di Visual Studio, mari kita buka Test Explorer dari Test → Window → Test Explorer opsi menu.

Dan Anda dapat melihat bahwa Visual Studio secara otomatis mendeteksi pengujian tersebut. Nama tes terdiri darinamespace.className.TestMethodName. Sekarang mari kita klikRun All button in Test Explorer.

Ini pertama-tama akan membangun kode dan menjalankan pengujian dan Anda akan melihat total waktu yang dibutuhkan oleh pengujian. Mari kita ubah metode pengujian sehingga kita dapat melihat hasilnya saat pengujian gagal.

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

Mari kita jalankan tes lagi dengan mengklik Run All tautan tombol.

Sekarang Anda dapat melihat file test kegagalan.

Dalam bab ini, kami akan menguji StringLibrary kami dan untuk melakukannya, kami perlu mengatur ulang proyek kami sehingga kami dapat mengikuti konvensi default.

Mari kita buka global.json mengajukan.

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

Di bagian atas file ini Anda akan melihat pengaturan proyek dan menyiapkan beberapa folder seperti src dan test secara default.

Sesuai konvensi, kita harus memiliki proyek di folder ini, ini adalah konvensi baru dan akan digunakan sebagai bagian dari .NET Core.

Di Solution Explorer, Anda dapat melihat bahwa proyek konsol dan proyek perpustakaan berada di dalam file src folder saat proyek Pengujian ada di dalam test map.

Dan struktur proyek di Solution Explorer tidak menunjukkan lokasi proyek secara fisik di disk. Sekarang mari kita buka folder Solusi dan Anda akan melihatnyaStringLibrary proyek tidak ada di dalam src map.

Anda dapat melihat keduanya src dan test folder dipetakan ke konvensi yang ditentukan dalam global.jsonmengajukan. Namun, kami memiliki satu proyek StringLibrary yang di luar konvensi. Sekarang mari kita tambahkanStringLibrary proyek di dalam src map.

Di folder src, kami memiliki dua proyek dan kami perlu memperbaiki masalahnya agar kami dapat menggunakan semua proyek dengan benar. Mari kita kembali ke Visual Studio dan klik kanan pada proyek StringLibrary dan pilih opsi Hapus. Ini tidak akan menghapusnya, tetapi hanya akan menghapus proyek.

Sekarang klik kanan pada folder src dan pilih Add → Existing Project…

Jelajahi proyek StringLibrary yang sekarang ada di dalam file src folder, pilih StringLibrary.csproj file dan klik Open.

Kami sekarang harus menghapus referensi dari StringLibrary dari project.json file dari aplikasi konsol.

{ 
   "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" 
      } 
   } 
}

Simpan perubahan dan tambahkan referensi StringLibrary lagi di proyek konsol Anda.

{ 
   "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" 
      } 
   } 
}

Sekarang semuanya harus berfungsi kembali dan Anda dapat membangunnya StringLibrary lalu FirstApp(proyek konsol) tanpa kesalahan apa pun. Mari kita sekarang menguji fungsionalitas StringLibrary menggunakan xunit. Kita perlu menambahkan referensi StringLibrary ke dalam proyek pengujian kita. Klik kanan pada Referensi proyek StringLibraryTests dan pilih Tambahkan Referensi…

Klik OK yang akan menambah referensi StringLibraryuntuk proyek pengujian kami. Sekarang mari kita ganti kode berikut diTests.cs mengajukan.

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()); 
      } 
   } 
}

Anda dapat melihat bahwa kami memiliki tiga metode pengujian yang akan menguji fungsionalitas StringLibrary. Mari kita klikRun All link dan Anda akan melihat output berikut di Test Explorer.

Anda juga dapat menjalankan pengujian dari baris perintah. Mari kita buka command prompt dan jalankan filedotnet test perintah.

Pada bab ini, kita akan membahas tentang Managed Extensibility Framework (MEF). MEF dapat digunakan untuk ekstensibilitas plugin pihak ketiga, atau dapat membawa manfaat dari arsitektur mirip plugin yang digabungkan secara longgar ke aplikasi biasa.

  • MEF adalah perpustakaan untuk membuat aplikasi yang ringan dan dapat diperluas.

  • Ini memungkinkan pengembang aplikasi untuk menemukan dan menggunakan ekstensi tanpa memerlukan konfigurasi.

  • MEF merupakan bagian integral dari .NETFramework 4, dan tersedia di mana pun .NETFramework digunakan yang meningkatkan fleksibilitas, kemampuan pemeliharaan, dan kemampuan pengujian aplikasi besar.

  • Anda dapat menggunakan MEF di aplikasi klien Anda, apakah mereka menggunakan Formulir Windows, WPF, atau teknologi lainnya, atau dalam aplikasi server yang menggunakan ASP.NET.

  • MEF telah diporting sebagai Microsoft.Composition ke .NET Core juga, tetapi sebagian.

  • Hanya System.Composition porting, dan System.ComponentModel.Compositionbelum tersedia. Artinya, kami tidak memiliki katalog yang dapat memuat tipe dari rakitan dalam direktori.

Pada bab ini, kita hanya akan mempelajari bagaimana kita dapat menggunakan MEF pada aplikasi .NET Core.

Mari kita pahami contoh sederhana di mana kita akan menggunakan MEF di aplikasi konsol .NET Core. Sekarang mari kita buat proyek konsol .NET Core baru.

Di panel kiri, pilih Templates → Visual C# → .NET Core dan kemudian di panel tengah, pilih Aplikasi Konsol (.NET Core).

Masukkan nama proyek di kolom Name dan klik OK.

Setelah proyek dibuat, kita perlu menambahkan referensi Microsoft.Composition agar kita dapat menggunakan MEF. Untuk melakukannya, mari kita klik kanan pada proyek di Solution Explorer danManage NuGet Packages…

Pencarian untuk Microsoft.Composition dan klik Install.

Klik OK tombol.

Klik I Accept tombol.

Saat penginstalan selesai, Anda akan menemukan kesalahan di Referensi.

Mari kita buka project.json mengajukan.

{ 
   "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" 
      } 
   } 
}

Anda dapat melihat bahwa file Microsoft.Composition ketergantungan ditambahkan, tetapi masalahnya adalah paket ini tidak kompatibel dengan dnxcore50. Jadi kita perlu mengimporportablenet45+win8+wp8+wpa81. Mari kita ganti fileproject.json file dengan kode berikut.

{ 
   "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" 
      } 
   } 
}

Simpan file ini dan Anda akan melihat bahwa kesalahan telah diperbaiki.

Jika Anda memperluas Referensi, maka Anda akan melihat referensi dari Microsoft.Composition.

Pertama kita perlu membuat antarmuka yang akan diekspor dan mengimplementasikan antarmuka dan menghias kelas dengan atribut export. Sekarang mari kita tambahkan kelas baru.

Masukkan nama untuk kelas Anda di kolom Name dan klik Add.

Mari kita tambahkan kode berikut di PrintData.cs mengajukan.

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); 
      } 
   } 
}

Seperti disebutkan di atas, Katalog tidak tersedia di ruang nama Microsoft.Composition. Jadi, ini akan memuat semua tipe dari Assembly dengan atribut export dan melampirkan ke atribut import seperti yang ditunjukkan pada metode Compose di 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>(); 
         } 
      } 
   } 
}

Biarkan kami sekarang menjalankan aplikasi Anda dan Anda akan melihat bahwa itu berjalan dengan membuat instance PrintData kelas.

Untuk mempelajari lebih lanjut tentang MEF, mari kita kunjungi Url berikut https://msdn.microsoft.com/en-us/library/dd460648%28v=vs.110%29.aspx untuk lebih jelasnya.

Dalam bab ini, kita akan memahami fitur yang akan datang di .NET Core. Kita akan mulai dengan alat baris perintah .NET dengan membuka Url berikut di browserhttps://github.com/dotnet/cli

Untuk mengetahui lebih lanjut tentang kemajuannya, Anda dapat mengunduh versi terbaru .NET Core SDK dengan menggulir ke bawah dan Anda akan melihat bagian Penginstal dan Binari.

Anda dapat melihat versi terbaru alat pratinjau untuk sistem operasi yang berbeda, izinkan kami memilih Penginstal sesuai sistem operasi Anda.

Kami sedang mengerjakan pratinjau 1 dari .NET Core 2.0.

Sekarang mari kita lihat perkakas kita saat ini dengan membuka command prompt dan menjalankan perintah berikut.

dotnet --info

Anda akan melihat informasi tentang versi yang saat ini diinstal dari .NET Command Line Tools di sistem Anda seperti yang ditunjukkan di bawah ini.

Anda dapat melihat bahwa saat ini kami memiliki pratinjau 2 perkakas. Sekarang mari kita jalankan perintah berikut untuk melihat tentangnew perintah.

dotnet help new

Untuk bahasa perintah baru proyek, Anda dapat memilih seperti C # dan F # dan jenis proyek, dll.

Sekarang mari kita lihat perubahan dalam versi terbaru .NET Core. Setelah penginstal diunduh, klik dua kali untuk menginstalnya. Klik Instal.

Tangkapan layar berikut menunjukkan proses instalasi.

Ini akan memulai proses instalasi. Setelah penginstalan selesai, Tutup dialog ini.

Buka command prompt dan jalankan perintah berikut.

dotnet --info

Anda akan melihat informasi versi .NET Command Line Tools yang saat ini terinstal di sistem Anda seperti yang ditunjukkan di bawah ini.

Anda sekarang dapat melihat bahwa kami memiliki pratinjau1 perkakas dari .NET Core 2. Sekarang mari kita jalankan kode berikut di command prompt untuk melihat tentang perintah baru di .NET Core 2 preview1.

dotnet help new

Perintah ini membantu Anda mengunduh paket juga ke cache paket.

Perintah membuka halaman web berikut yang berisi informasi tentang perintah baru di .NET Core 2 preview1.

Mari kita gulir ke bawah, sekarang Anda dapat melihat bahwa kita dapat membuat aplikasi .NET Core dengan lebih banyak templat.

Sekarang kita dapat membuat mstest, web, mvc dan webapi proyek juga menggunakan baris perintah.

.NET Core telah memutuskan untuk menghentikan project.json dan kembali ke MSBuild dan * .csproj. Ini adalah sesuatu yang sudah terjadi di tooling .Net Core 2.0 preview1 yang baru saja dirilis. Ini cukup mengecewakan, karena project.json menghirup udara segar. Namun, hal itu bisa dimengerti dan memiliki banyak keuntungan juga.

Sekarang mari kita bahas keuntungan dari perubahan tersebut -

  • Ini akan membuat transisi dari solusi Visual Studio yang ada ke .NET Core langsung.

  • Ini adalah perubahan besar dan juga akan memungkinkan peningkatan investasi yang ada di CI / RM yang berbasis di sekitar MSBuild.

  • Selama build di MSBuild, kita dapat memikirkan kompilasi tambahan, menyelesaikan dependensi waktu build, manajemen konfigurasi, dll.

  • Banyak pekerjaan yang diperlukan untuk mengirimkan dotnet cli tepat waktu, karena ini tidak lagi hanya tentang ASP.NET Core, tetapi juga aplikasi konsol, aplikasi UWP, dll.

Berikut adalah perubahan di MSBuild dan * .csproj -

  • File Project.json (* .xproj) akan diganti dengan MSBuild (* .csproj).

  • Fitur di project.json akan mulai digabungkan kembali ke file * .csproj.

  • Belum jelas apa yang akan mereka lakukan tentang daftar paket, tetapi disebutkan mereka mungkin menyimpannya sebagai json di bawah nuget.json atau gabungkan menjadi *.csproj.

  • Seharusnya transisi itu harus lancar dan berpotensi otomatis jika menggunakan Visual Studio.

Keuntungan dari MSBuild

  • MSBuild adalah open source dan tersedia di GitHub dan terikat untuk menjadi sepenuhnya lintas platform.

  • MSBuild akan secara dramatis menyederhanakan dan memangkas struktur file *.csproj.

  • Microsoft juga memperkenalkan sistem proyek baru yang akan memungkinkan banyak skenario tanpa perlu Visual Studio dan detailnya diberikan di Url ini. https://github.com/dotnet/roslyn-project-system/.

  • Tujuannya adalah bahwa bahkan dengan pengaturan MSBuild, bekerja dengan build dan proyek akan berjalan mulus di Visual Studio IDE seperti di luarnya.

MSBuild vs project.json

Sekarang mari kita buat proyek konsol baru dengan alat pratinjau2 .NET Core dengan menjalankan perintah berikut.

dotnet new -t console

Untuk melihat semua file yang dibuat dalam proyek ini, jalankan dir perintah.

Anda dapat melihat bahwa dua file dibuat, Program.cs dan project.json mengajukan.

Sekarang mari kita membuat aplikasi konsol dengan alat pratinjau .NET Core 2 dengan menjalankan perintah berikut.

dotnet new console

Untuk melihat semua file yang dibuat dalam proyek ini, jalankan dirperintah. Anda dapat melihat bahwa tiga file dibuat,Program.cs, NuGet.config dan MSBuild.csproj alih-alih file project.json.

Sekarang mari kita bandingkan project.json dan MSBuild.csproj file berdampingan.

Di sebelah kiri, kami memiliki file dalam format json sedangkan di sebelah kanan, file tersebut dalam format XML. Anda dapat melihat bahwa di file project.json, di dalam bagian dependencies, adanetcoreapp1.0, sementara di file MSBuild.csproj, Anda akan melihat file netcoreapp2.0.

Pada bab ini, kita akan membahas cara memulihkan dan membangun file MSBuild (* .csproj) Anda menggunakan utilitas baris perintah. Untuk melihat perintah apa yang tersedia di .NET Core 2.0 preview 1, mari kita jalankan perintah berikut.

dotnet help

Anda akan melihat semua perintah seperti baru, memulihkan, membangun, dll.

Berikut adalah implementasi default di Program.cs mengajukan.

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

Sekarang mari kita jalankan perintah berikut untuk melihat kemajuannya.

dotnet build

Anda akan melihat banyak kesalahan. Kesalahan ini perlu diperbaiki.

Sekarang mari kita jalankan perintah berikut.

dotnet restore

Anda dapat melihat bahwa semua paket dipulihkan. Beberapa folder dan file baru juga telah dibuat.

Untuk melihat struktur direktori, mari kita jalankan perintah berikut.

tree /f

Berikut adalah struktur direktori -

Sekarang mari kita membangun kembali proyek dengan menjalankan perintah berikut lagi.

dotnet build

Sekarang Anda memproyeksikan akan berhasil membangun tanpa kesalahan dan MSBuild.dll juga dibuat.

Untuk melihat hasilnya, mari kita jalankan perintah berikut -

dotnet run

Anda dapat melihat output berikut di konsol Anda.

Pada bab ini, kita akan memigrasi aplikasi konsol yang berisi project.json file build system, bukan MSBuild (*.csproj). Jadi, kami memiliki proyek lama yang berisi file-file berikut.

Sekarang pertanyaannya adalah, mengapa kita membutuhkan migrasi? Proyek ini dibuat menggunakan perkakas .NET Core 1.0 preview 2 dan sekarang kami telah menginstal perkakas .NET Core 2.0 preview 1. Sekarang ketika Anda membangun aplikasi ini menggunakan utilitas baris perintah .NET Core 2.0, Anda akan melihat kesalahan berikut.

Ini karena project.jsonsistem build tidak lagi tersedia di .NET Core 2.0, jadi kami memerlukan migrasi agar dapat berfungsi dengan baik. Untuk melihat perintah yang tersedia, mari kita jalankan perintah berikut.

dotnet help

Di bagian perintah, Anda dapat melihat berbagai perintah dan Anda juga dapat melihat file migrate perintah yang akan memigrasi proyek berbasis project.json ke proyek berbasis MSBuild.

Sekarang mari kita jalankan perintah berikut.

dotnet migrate

Anda akan melihat ringkasan proses migrasi dan di sini Anda juga dapat melihat bahwa proyek berhasil dimigrasi.

Sekarang mari kita lihat struktur direktori dengan menggunakan perintah berikut.

tree /f

Anda sekarang akan melihat file * .csproj bersama dengan file Program.cs di direktori root proyek dan project.json dipindahkan ke folder backup.

Mari kita buka console.csprojmengajukan. Sekarang Anda dapat memulihkan dan membangun proyek ini menggunakan sistem MSBuild dengan menjalankan perintah berikut.

dotnet restore

Sekarang Anda dapat melihat bahwa semua paket telah dipulihkan.

Anda sekarang dapat membangun proyek Anda dengan perintah berikut.

dotnet build

Sekarang Anda dapat melihat bahwa proyek berhasil dibangun menggunakan MSBuild dan console.dll juga dibuat di ..\bin\Debug\netcoreapp1.0 map.

Tangkapan layar berikut menunjukkan struktur direktori dan file.