跳過到頁腳內容
.NET幫助

C# iList(對於開發者的運行原理)

CODE-808 簡介

IList 是.NET Framework 的 Collections 命名空間的一部份。 它是一個非通用的集合接口,為物件集合提供了藍圖,可以透過索引單獨存取這些物件。 與陣列不同, IList允許動態數量的物件值元素,這表示您可以根據需要向集合中新增或刪除元素。 它作為.NET Framework中所有非泛型列表的基本接口,提供了一種比數組更靈活的物件集合管理方式。 在本教程中,我們將學習 IList 介面和IronPDF C# PDF 庫

了解 IList 接口

public interface IList 宣告是 C# 中建立符合.NET Framework 的 Collections 命名空間所指定的 IList 約定的自訂集合的基本組成部分。 IList 包含能夠存取集合中的元素、計算元素數量以及透過新增、插入或刪除元素來修改集合的屬性和方法。 以下是 IList 介面中定義的一些關鍵屬性和方法:

  • 諸如 IsFixedSizeIsReadOnly 之類的屬性分別顯示集合是固定大小還是唯讀的。
  • 諸如 RemoveRemoveAt 之類的方法用於修改集合中的元素。 您可以新增、插入和刪除元素。
  • IndexOf 方法用於定位元素,而 Item 屬性(或 C# 中的索引器)允許根據元素的索引取得和設定元素。

IList 介面的實際應用

為了展示 IList 的工作原理,讓我們建立一個簡單的範例。 本範例將示範如何聲明一個 IList,向其中新增項目,並遍歷其內容。

建立和修改 IList

首先,讓我們來看看如何宣告一個 IList 並在其中加入項目:

using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        // Creating an IList instance
        IList myIList = new ArrayList();

        // Adding elements to the IList
        myIList.Add("Hello");
        myIList.Add(10);
        myIList.Add(new object());

        // Displaying the number of values in the IList using the Count property
        Console.WriteLine($"Number of elements: {myIList.Count}");

        // Accessing elements using a loop
        foreach (var element in myIList)
        {
            Console.WriteLine(element);
        }
    }
}
using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        // Creating an IList instance
        IList myIList = new ArrayList();

        // Adding elements to the IList
        myIList.Add("Hello");
        myIList.Add(10);
        myIList.Add(new object());

        // Displaying the number of values in the IList using the Count property
        Console.WriteLine($"Number of elements: {myIList.Count}");

        // Accessing elements using a loop
        foreach (var element in myIList)
        {
            Console.WriteLine(element);
        }
    }
}
$vbLabelText   $csharpLabel

在上面的例子中,我們使用 ArrayList 建立了一個 IList 實例,該類別實作了 IList。 我們添加了各種不同類型的對象,以證明 IList 可以容納任何對象。 最後,我們遍歷了集合,印出每個元素。

基於索引的存取和修改

透過索引存取和修改元素是 IList 的關鍵特性。 以下範例展示如何操作:

using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        IList myIList = new ArrayList { "Hello", 10, new object() };

        // Accessing an element by index
        object value = myIList[1];
        Console.WriteLine($"Element at index 1: {value}");

        // Modifying an element by index
        myIList[1] = 20;
        Console.WriteLine($"Modified element at index 1: {myIList[1]}");
    }
}
using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        IList myIList = new ArrayList { "Hello", 10, new object() };

        // Accessing an element by index
        object value = myIList[1];
        Console.WriteLine($"Element at index 1: {value}");

        // Modifying an element by index
        myIList[1] = 20;
        Console.WriteLine($"Modified element at index 1: {myIList[1]}");
    }
}
$vbLabelText   $csharpLabel

實作自訂 IList

有時您可能需要一個繼承自 IList 的客製化集合。 這樣可以更好地控制元素的儲存、存取和修改方式。 以下是實作 IList 的簡單自訂集合範例:

using System;
using System.Collections;

public class CustomCollection : IList
{
    private ArrayList _innerList = new ArrayList();

    public object this[int index]
    {
        get => _innerList[index];
        set => _innerList[index] = value;
    }

    public bool IsFixedSize => _innerList.IsFixedSize;
    public bool IsReadOnly => _innerList.IsReadOnly;
    public int Count => _innerList.Count;
    public bool IsSynchronized => _innerList.IsSynchronized;
    public object SyncRoot => _innerList.SyncRoot;

    public int Add(object value)
    {
        return _innerList.Add(value);
    }

    public void Clear()
    {
        _innerList.Clear();
    }

    public bool Contains(object value)
    {
        return _innerList.Contains(value);
    }

    public int IndexOf(object value)
    {
        return _innerList.IndexOf(value);
    }

    public void Insert(int index, object value)
    {
        _innerList.Insert(index, value);
    }

    public void Remove(object value)
    {
        _innerList.Remove(value);
    }

    public void RemoveAt(int index)
    {
        _innerList.RemoveAt(index);
    }

    public void CopyTo(Array array, int index)
    {
        _innerList.CopyTo(array, index);
    }

    public IEnumerator GetEnumerator()
    {
        return _innerList.GetEnumerator();
    }
}
using System;
using System.Collections;

public class CustomCollection : IList
{
    private ArrayList _innerList = new ArrayList();

    public object this[int index]
    {
        get => _innerList[index];
        set => _innerList[index] = value;
    }

    public bool IsFixedSize => _innerList.IsFixedSize;
    public bool IsReadOnly => _innerList.IsReadOnly;
    public int Count => _innerList.Count;
    public bool IsSynchronized => _innerList.IsSynchronized;
    public object SyncRoot => _innerList.SyncRoot;

    public int Add(object value)
    {
        return _innerList.Add(value);
    }

    public void Clear()
    {
        _innerList.Clear();
    }

    public bool Contains(object value)
    {
        return _innerList.Contains(value);
    }

    public int IndexOf(object value)
    {
        return _innerList.IndexOf(value);
    }

    public void Insert(int index, object value)
    {
        _innerList.Insert(index, value);
    }

    public void Remove(object value)
    {
        _innerList.Remove(value);
    }

    public void RemoveAt(int index)
    {
        _innerList.RemoveAt(index);
    }

    public void CopyTo(Array array, int index)
    {
        _innerList.CopyTo(array, index);
    }

    public IEnumerator GetEnumerator()
    {
        return _innerList.GetEnumerator();
    }
}
$vbLabelText   $csharpLabel

這個 CustomCollection 類別封裝了一個 ArrayList 類,該類本身實作了 IList 介面。 我們的 CustomCollection 將呼叫轉送到底層 ArrayList,使其能夠像任何其他實作了 IList 的集合一樣運作。 本範例示範如何建立一個可透過索引存取、修改(新增、插入或刪除項目)和迭代的集合,就像任何實作了 IList 的內建.NET集合一樣。

使用 IList 進行進階操作

除了基本的新增、刪除和存取操作之外,IList 還允許進行更複雜的操作和查詢。 例如,檢查集合中是否包含特定物件或查找物件在集合中的索引等操作對於某些應用程式來說至關重要:

using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        IList myIList = new ArrayList { "Hello", 10, new object() };

        // Check if the IList contains a specific object
        bool contains = myIList.Contains(10); // Assuming 10 was added previously
        Console.WriteLine($"Contains 10: {contains}");

        // Find the index of a specific object
        int index = myIList.IndexOf(10);
        Console.WriteLine($"Index of 10: {index}");
    }
}
using System;
using System.Collections;

class Program
{
    static void Main(string[] args)
    {
        IList myIList = new ArrayList { "Hello", 10, new object() };

        // Check if the IList contains a specific object
        bool contains = myIList.Contains(10); // Assuming 10 was added previously
        Console.WriteLine($"Contains 10: {contains}");

        // Find the index of a specific object
        int index = myIList.IndexOf(10);
        Console.WriteLine($"Index of 10: {index}");
    }
}
$vbLabelText   $csharpLabel

當需要確定特定項目是否存在或位置,而無需遍歷整個集合時,這些操作在處理物件集合時特別有用。

IronPDF:C# PDF 庫

C# iList(開發者使用方法):圖 1 - IronPDF

IronPDF是一個.NET開發人員的 PDF 庫,允許直接在.NET應用程式中建立和操作 PDF 文件。 它支援將HTML 轉換為 PDF 文件、圖像和網頁轉換為 PDF。 開發者可以利用這個程式庫輕鬆地為他們的應用程式添加 PDF 功能。 IronPDF還包含編輯、合併和分割 PDF 文件的功能,從而提供對 PDF 操作的全面控制。

IronPDF在HTML 轉 PDF 方面表現出色,可確保精確保留原始佈局和樣式。 它非常適合從基於 Web 的內容(例如報告、發票和文件)建立 PDF。 IronPDF支援 HTML 檔案、URL 和原始 HTML 字串,可以輕鬆產生高品質的 PDF 文件。

using IronPdf;

class Program
{
    static void Main(string[] args)
    {
        var renderer = new ChromePdfRenderer();

        // 1. Convert HTML String to PDF
        var htmlContent = "<h1>Hello, IronPDF!</h1><p>This is a PDF from an HTML string.</p>";
        var pdfFromHtmlString = renderer.RenderHtmlAsPdf(htmlContent);
        pdfFromHtmlString.SaveAs("HTMLStringToPDF.pdf");

        // 2. Convert HTML File to PDF
        var htmlFilePath = "path_to_your_html_file.html"; // Specify the path to your HTML file
        var pdfFromHtmlFile = renderer.RenderHtmlFileAsPdf(htmlFilePath);
        pdfFromHtmlFile.SaveAs("HTMLFileToPDF.pdf");

        // 3. Convert URL to PDF
        var url = "http://ironpdf.com"; // Specify the URL
        var pdfFromUrl = renderer.RenderUrlAsPdf(url);
        pdfFromUrl.SaveAs("URLToPDF.pdf");
    }
}
using IronPdf;

class Program
{
    static void Main(string[] args)
    {
        var renderer = new ChromePdfRenderer();

        // 1. Convert HTML String to PDF
        var htmlContent = "<h1>Hello, IronPDF!</h1><p>This is a PDF from an HTML string.</p>";
        var pdfFromHtmlString = renderer.RenderHtmlAsPdf(htmlContent);
        pdfFromHtmlString.SaveAs("HTMLStringToPDF.pdf");

        // 2. Convert HTML File to PDF
        var htmlFilePath = "path_to_your_html_file.html"; // Specify the path to your HTML file
        var pdfFromHtmlFile = renderer.RenderHtmlFileAsPdf(htmlFilePath);
        pdfFromHtmlFile.SaveAs("HTMLFileToPDF.pdf");

        // 3. Convert URL to PDF
        var url = "http://ironpdf.com"; // Specify the URL
        var pdfFromUrl = renderer.RenderUrlAsPdf(url);
        pdfFromUrl.SaveAs("URLToPDF.pdf");
    }
}
$vbLabelText   $csharpLabel

程式碼範例

以下是一個簡單的範例,示範如何使用IronPDF和 IList 介面從字串清單產生簡單的 PDF 文件:

using IronPdf;
using System.Collections.Generic;

public class PDFGenerator
{
    public static void GeneratePDFFromList(IList<string> dataList)
    {
        // Initialize the HtmlToPdf renderer
        var renderer = new ChromePdfRenderer();

        // Start building HTML content from the dataList
        var htmlContent = "<h1>My Data List</h1><ul>";
        foreach (var item in dataList)
        {
            htmlContent += $"<li>{item}</li>";
        }
        htmlContent += "</ul>";

        // Convert HTML string to PDF
        var pdfDocument = renderer.RenderHtmlAsPdf(htmlContent);

        // Save the PDF to a file
        pdfDocument.SaveAs("DataList.pdf");
    }
}

// Example usage
class Program
{
    static void Main(string[] args)
    {
        License.LicenseKey = "License-Key";
        IList<string> myDataList = new List<string> { "Apple", "Banana", "Cherry" };
        PDFGenerator.GeneratePDFFromList(myDataList);
    }
}
using IronPdf;
using System.Collections.Generic;

public class PDFGenerator
{
    public static void GeneratePDFFromList(IList<string> dataList)
    {
        // Initialize the HtmlToPdf renderer
        var renderer = new ChromePdfRenderer();

        // Start building HTML content from the dataList
        var htmlContent = "<h1>My Data List</h1><ul>";
        foreach (var item in dataList)
        {
            htmlContent += $"<li>{item}</li>";
        }
        htmlContent += "</ul>";

        // Convert HTML string to PDF
        var pdfDocument = renderer.RenderHtmlAsPdf(htmlContent);

        // Save the PDF to a file
        pdfDocument.SaveAs("DataList.pdf");
    }
}

// Example usage
class Program
{
    static void Main(string[] args)
    {
        License.LicenseKey = "License-Key";
        IList<string> myDataList = new List<string> { "Apple", "Banana", "Cherry" };
        PDFGenerator.GeneratePDFFromList(myDataList);
    }
}
$vbLabelText   $csharpLabel

在這個例子中,使用 IList<string> 來儲存水果名稱的集合。 然後,該方法遍歷此列表,建立一個包含無序列表每個項目的 HTML 字串。 IronPDF 的該方法將此 HTML 內容轉換為 PDF 文檔,並將其儲存到文件中。

C# iList(開發者使用方法):圖 2 - PDF 輸出

結論

C# iList(開發者使用方法):圖 3 - 授權

本入門級指南旨在介紹 C# 中 IList 的基礎知識和實際用途。 從簡單的用法到自訂實現,IList 的範例表明,它是 C# 開發人員工具包中的強大工具。 無論您是在處理資料集合還是建立集合類型,IList 都提供了有效軟體開發所需的功能和靈活性。 IronPDF提供有興趣的使用者免費試用其 PDF 庫,許可證價格從 $799 起。

常見問題解答

什麼是C#中的IList介面?

`IList`介面是.NET Framework的Collections命名空間的一部分,用於創建可以通過索引訪問的動態集合。它提供了添加、插入、刪除和訪問元素的方法,提供比靜態數組更大的靈活性。

如何在 C# 中將 HTML 轉換為 PDF?

可以使用IronPDF的`RenderHtmlAsPdf`方法在C#中將HTML轉換為PDF。這允許您將HTML字串、文件或URL轉換為高質量的PDF文件。

IList介面的一些關鍵方法是什麼?

`IList`介面的關鍵方法包括`Add`、`Insert`、`Remove`、`RemoveAt`和`IndexOf`。這些方法對動態管理和修改集合內的元素至關重要。

如何在C#中創建自定義的IList?

要在C#中創建自定義的`IList`,您可以在一個類中實現`IList`介面,重寫必要的方法和屬性,如`Add`、`Remove`和`IndexOf`,以自定義集合如何處理其元素。

IronPDF如何從HTML創建PDF?

IronPDF使用`ChromePdfRenderer`類將HTML內容轉換為PDF。它支持從HTML字串、文件或URL進行轉換,確保從網路內容準確地創建PDF。

可以從IList中的數據生成PDF嗎?

是的,您可以從IList中生成PDF,通過遍歷列表構建HTML字串,然後使用IronPDF的`ChromePdfRenderer`將HTML轉換為PDF文件,並可以使用`SaveAs`方法保存。

IList支持哪些高級操作?

`IList`中的高級操作包括使用`Contains`檢查集合中是否包含特定對象,以及使用`IndexOf`查找對象的位置。這些功能有助於有效管理集合,而無需手動搜索元素。

如何在C#中排除PDF生成問題?

如果您在C#中遇到PDF生成問題,請確保您的HTML內容格式正確,並且您正在使用IronPDF的最新版本。檢查在轉換過程中引發的任何異常以獲取進一步的洞察。

Jacob Mellor, Team Iron 首席技術官
首席技術官

Jacob Mellor是Iron Software的首席技術官,也是開創C# PDF技術的前瞻性工程師。作為Iron Software核心代碼庫的原始開發者,他自公司成立以來就塑造了公司的產品架構,並與CEO Cameron Rimington將公司轉型為服務NASA、Tesla以及全球政府機構的50多人公司。

Jacob擁有曼徹斯特大學土木工程一級榮譽學士學位(1998年–2001年)。他於1999年在倫敦開立首家軟體公司,並於2005年建立了他的第一個.NET組件,專注於解決Microsoft生態系統中的複雜問題。

他的旗艦作品IronPDF和Iron Suite .NET程式庫全球已獲得超過3000萬次NuGet安裝,他的基礎代碼不斷在全球各地驅動開發者工具。擁有25年以上的商業經驗和41年的編碼專業知識,Jacob仍然專注於推動企業級C#、Java和Python PDF技術的創新,同時指導下一代技術領導者。

Iron Support Team

We're online 24 hours, 5 days a week.
Chat
Email
Call Me