Natasha相關輔助類 (六)

来源:https://www.cnblogs.com/wanghun315/archive/2023/05/17/17409141.html
-Advertisement-
Play Games

目錄 枚舉的基本用法回顧 枚舉常見的設計模式運用 介紹 智能枚舉 代碼示例 業務應用 小結 枚舉的基本用法回顧 以下是一個常見的 C# 枚舉(enum)的示例: enum Weekday { Monday, Tuesday, Wednesday, Thursday, Friday, Saturday ...


AccessReverser.GetAccess

獲得相關類的訪問級別

AccessReverser.GetAccess() 可以是泛型

AccessReverser.GetAccess方法中的參數可以是

屬性名稱 說明
PropertyInfo 獲取屬性的訪問級別
MethodInfo 獲取方法的訪問級別
EventInfo 獲取事件的訪問級別
FieldInfo 獲取欄位的訪問級別
Type 獲取類型的訪問級別
T 獲取泛型的訪問級別
internal class Demo6
{
    public String Field  = "";
    public void Domain()
    {
        NatashaManagement.Preheating();
        //獲取訪問級別
        String strAccess = AccessReverser.GetAccess<Object>();
        // 獲取Type
        Type ty = typeof(Demo6);
        // 獲取Demo6的訪問級別
        Console.WriteLine($"Type Access is {AccessReverser.GetAccess(ty)}");
        // 獲取Field欄位
        FieldInfo? fieldInfo = ty.GetField("Field");
        if (fieldInfo != null) {
            //輸出Field欄位的訪問級別
            Console.WriteLine($"MethodText Access is {AccessReverser.GetAccess(fieldInfo)}");
        }
        // 獲取MethodText欄位
        MethodInfo? domain = ty.GetMethod("Domain");
        if (domain != null) {
            //輸出MethodText欄位的訪問級別
            Console.WriteLine($"MethodText Access is {AccessReverser.GetAccess(domain)}");
        }
            
    }
}

運行結果:

AvailableNameReverser.GetAvailableName

獲取Type的可用名,參數為Type

// 結果為:namespace+類名
Console.WriteLine($"獲取Type的可用名:{AvailableNameReverser.GetAvailableName(ty)}");

運行結果:

DeclarationReverser.GetMethodDeclaration

展示函數信息,參數為MethodInfo

public void Domain()
{
    //MethodInfo? domain = ty.GetMethod("Domain");以下部分修改
    // 獲取Test方法
    MethodInfo? test = ty.GetMethod("Test");
    if (test != null) {
        Console.WriteLine($"函數信息: {DeclarationReverser.GetMethodDeclaration(test)}");
        //輸出MethodText欄位的訪問級別
        Console.WriteLine($"Test Access is {AccessReverser.GetAccess(test)}");
    }
}
public String Test(in String arg1, out int arg2, ref float arg3) {
    arg2 = 0;
    return "";
}

結果截圖:

TypeNatashaExtension

Natasha的類型拓展

類名 參數 返回 說明
IsImplementFrom this Type ,Type iType bool 當前類是否實現了某介面,iType為介面類型
IsImplementFrom this Type bool T為介面類型
GetRuntimeName this Type string 獲取運行時類名
GetDevelopName this Type string 獲取完整類名
GetDevelopNameWithoutFlag this Type string 同GetDevelopName
GetAvailableName this Type string 將類名替換成 文件名可使用的名字
IsSimpleType this Type bool 判斷是否為值類型,字元串類型,委托類型,Type類型,及委托的子類型其中之一
//////////////////創建的介面
public interface ITest {
	public void IClass();
}
internal class Demo6: ITest{
	public void testTypeNatashaExtension() {
		//初始化
		NatashaManagement.Preheating();
        bool bImplement = typeof(Demo6).IsImplementFrom(typeof(ITest));
        // Class 類的情況
        Console.WriteLine("Demo6類的相關結果如下:");
        Console.WriteLine($"Demo6 是否實現了 ITest 的介面:{bImplement}");
        Console.WriteLine($"GetRuntimeName 結果:\"{typeof(Demo6).GetRuntimeName()}\"");
        Console.WriteLine($"GetDevelopName 結果:\"{typeof(Demo6).GetDevelopName()}\"");
        Console.WriteLine($"GetDevelopNameWithoutFlag 結果:\"{typeof(Demo6).GetDevelopNameWithoutFlag()}\"");
        Console.WriteLine($"GetAvailableName 結果:\"{typeof(Demo6).GetAvailableName()}\"");
        Console.WriteLine($"IsSimpleType 結果:\"{typeof(Demo6).IsSimpleType()}\"");
        // Dictionary<int, String>的參數
        Console.WriteLine("Dictionary<int, String> 的相關結果如下:");
        Console.WriteLine($"GetRuntimeName 結果:\"{typeof(Dictionary<int, String>).GetRuntimeName()}\"");
        Console.WriteLine($"GetDevelopName 結果:\"{typeof(Dictionary<int, String>).GetDevelopName()}\"");
        Console.WriteLine($"GetDevelopNameWithoutFlag 結果:\"{typeof(Dictionary<int, String>).GetDevelopNameWithoutFlag()}\"");
        Console.WriteLine($"GetAvailableName 結果:\"{typeof(Dictionary<int, String>).GetAvailableName()}\"");
        Console.WriteLine($"IsSimpleType 結果:\"{typeof(Dictionary<int, String>).IsSimpleType()}\"");
        // Dictionary<String, HashSet<List<String>>>的參數
        Console.WriteLine("Dictionary<String, HashSet<List<String>>> 的相關結果如下:");
        Console.WriteLine($"GetRuntimeName 結果:\"{typeof(Dictionary<String, HashSet<List<String>>>).GetRuntimeName()}\"");
        Console.WriteLine($"GetDevelopName 結果:\"{typeof(Dictionary<String, HashSet<List<String>>>).GetDevelopName()}\"");
        Console.WriteLine($"GetDevelopNameWithoutFlag 結果:\"{typeof(Dictionary<String, HashSet<List<String>>>).GetDevelopNameWithoutFlag()}\"");
        Console.WriteLine($"GetAvailableName 結果:\"{typeof(Dictionary<String, HashSet<List<String>>>).GetAvailableName()}\"");
        Console.WriteLine($"IsSimpleType 結果:\"{typeof(Dictionary<String, HashSet<List<String>>>).IsSimpleType()}\"");
        }
        public void IClass()
        {
            Console.WriteLine("實現ITest的IClass方法");
        }
}

結果截圖:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 全面深入地介紹 Python 的控制流程,包括條件語句、迴圈結構和異常處理等關鍵部分,尤其會將列表解析、生成器、裝飾器等高級用法一網打盡。此外,我還將分享一些獨特的見解和研究發現,希望能給你帶來新的啟發。文章的結尾,我們將有一個 "One More Thing" 環節,我會分享一個很特別但又很少人知... ...
  • ###第1關 String類的常用方法 package step1; public class StringExample { public static void main(String args[]) { /********* Begin *********/ String s1 = new S ...
  • 基礎概念 進程(process):進程是電腦中的一個任務,比如打開瀏覽器、IntelliJ IDEA。 線程(thread):進程內部有多個子任務,叫線程。比如IDEA在敲代碼的同時還能自動保存、自動導包,都是子線程做的。 進程和線程的關係就是一個進程包含一個或多個線程。 線程是操作系統調度的最小 ...
  • 為了實現高效併發,虛擬機對 synchronized 做的一系列的鎖優化措施。包括:適應性自旋、鎖消除、鎖粗化、輕量級鎖、偏向鎖。 ...
  • 載入WPF界面時,需要獲取數據,而數據返回的時間比較長,這個時候可以非同步載入數據到界面。 1、首先在XAML中觸發視窗載入事件 2、在後臺代碼中處理視窗載入事件 (1)找到主視窗類 (2)在MainWindow類中添加 XAML中加入的視窗載入事件 這個事件中可以放置各種界面預處理代碼 new Th ...
  • 前言 前一篇說了NOSQL的增刪改查,今天來說說SQL資料庫MySQL的增刪改查。雖然本人已大部分是NOSQL資料庫,但是SQL類資料庫有些功能,比如查詢還是比起NOSQL還是有優勢的。 如查詢產量大於100,SQL是這樣的“xxx>100”,而NOSQL,是這樣的“{xxx:{ $gt: 100} ...
  • 前言: 自從接觸非同步(async await Task)操作後,始終都不明白,這個Task調度的問題。 接觸Quartz.net已經很久了,只知道它實現了一套Task調度的方法,自己跟著Quartz.net源代碼寫了遍,調試後我算是明白了Task調度的一部分事( )。 春風來不遠,只在屋東頭。 理解 ...
  • 微服務之間的通信方式 微服務之間的通信方式常見的有以下幾種: 同步通信:微服務之間通過請求-響應的方式進行通信,例如RESTful API和RPC。通信過程中,請求方需要等待響應方的返回結果,因此可靠性較高,但可能會出現請求排隊、線程阻塞等問題,從而影響系統的響應速度和併發性能。 非同步通信:微服務之 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...