フッターコンテンツにスキップ
.NETヘルプ

LazyCache C#(開発者向けの仕組み)

キャッシングは、よくアクセスされるデータをメモリやより高速なストレージ媒体に保存することでパフォーマンスを向上させる、ソフトウェア開発における基本的な技術です。 C#では、LazyCacheはスレッドセーフキャッシュ実装を簡素化するための人気のライブラリで、開発者が負荷の高いシナリオでキャッシングを効果的に利用できるようにします。

LazyCacheとは何ですか?

LazyCacheは、.NET/ASP.NET Coreアプリケーションのための基盤となるキャッシングプロバイダライブラリで、データをキャッシングするためのシンプルで直感的なAPIを提供します。 これはNuGetパッケージとして利用可能で、C#プロジェクトに簡単に統合できます。 LazyCacheの主な目的はキャッシング実装を簡素化し、ダブルロックキャッシュパターンを使用してキャッシュされた情報を管理するために必要な定型コードを減らすことです。

LazyCacheの主な機能:

  1. シンプルなAPI: LazyCacheは、キャッシュ項目を追加、取得、削除するためのわかりやすいAPIを提供します。 開発者は、複雑なキャッシングメカニズムを扱うことなく、アプリケーションやWebサービスコールに素早くキャッシングを統合できます。

  2. 自動有効期限: LazyCacheは、設定可能な期限ポリシーに基づいてキャッシュ項目の自動有効期限をサポートします。 開発者はキャッシュ項目の有効期限を指定でき、LazyCacheは期限切れになった項目をキャッシュデータから削除します。

  3. インメモリキャッシング: LazyCacheはデフォルトでキャッシュ項目をメモリ内に保存し、キャッシュデータへの高速アクセスが必要なシナリオに適しています。 インメモリキャッシングは、キャッシュデータアクセスの低遅延と高スループットを保証します。

  4. スレッドセーフ操作: LazyCacheは、キャッシュ項目の追加、取得、削除のためのスレッドセーフな操作を提供します。 これにより、複数のスレッドがデータの破損や不整合のリスクなしにキャッシュに同時にアクセスできることが保証されます。

  5. 拡張性: LazyCacheは拡張可能に設計されており、開発者が特定の要件に応じてキャッシングの動作をカスタマイズできるようにします。 カスタムキャッシング戦略を実装するためのフックを提供します。

C#でLazyCacheを使用する方法:

C#でLazyCacheを使用するのは、直感的なAPIのおかげで簡単です。 以下に、IdleCacheを使用してメソッド呼び出しの結果をキャッシュする方法の基本的な例を示します。

using LazyCache;

public class DataService
{
    // Define a private readonly field for the cache
    private readonly IAppCache _cache;

    // Constructor to initialize the cache
    public DataService(IAppCache cache)
    {
        _cache = cache;
    }

    // Method to retrieve data (cached or fetched)
    public string GetData()
    {
        return _cache.GetOrAdd("dataKey", () =>
        {
            // Simulate expensive operation such as database calls
            return FetchDataFromDatabase();
        });
    }

    // Simulate fetching data from a database
    private string FetchDataFromDatabase()
    {
        return "Cached Data";
    }
}
using LazyCache;

public class DataService
{
    // Define a private readonly field for the cache
    private readonly IAppCache _cache;

    // Constructor to initialize the cache
    public DataService(IAppCache cache)
    {
        _cache = cache;
    }

    // Method to retrieve data (cached or fetched)
    public string GetData()
    {
        return _cache.GetOrAdd("dataKey", () =>
        {
            // Simulate expensive operation such as database calls
            return FetchDataFromDatabase();
        });
    }

    // Simulate fetching data from a database
    private string FetchDataFromDatabase()
    {
        return "Cached Data";
    }
}
$vbLabelText   $csharpLabel

この例では、DataServiceクラスがLazyCacheを使用してGetData()の結果をキャッシュします。 GetOrAdd()メソッドは、指定されたキー("dataKey")に関連付けられたキャッシュデータを取得します。 データがキャッシュされていない場合、提供されたデリゲートFetchDataFromDatabase()が実行されてデータが取得され、それが将来の使用のためにキャッシュされます。

IronPDFの紹介

LazyCache C#(開発者にとっての動作方法):図1 - IronPDF

IronPDFは、.NETプロジェクト内でPDF文書からコンテンツを生成、編集、および抽出することができる強力なC# PDFライブラリです。 ここにいくつかの重要な特徴を示します:

  1. HTMLからPDFへの変換:

    • HTML、CSS、JavaScriptコンテンツをPDF形式に変換します。
    • ピクセル単位で正確なPDFを作成するためにChrome Rendering Engineを使用します。
    • URL、HTML ファイル、または HTML 文字列から PDF を生成します。

2.画像とコンテンツの変換:

  • 画像をPDFに変換したり、PDFから画像に変換したりできます。
  • 既存のPDFからテキストや画像を抽出します。
  • さまざまな画像フォーマットをサポートします。

3.編集と操作:

  • PDFのプロパティ、セキュリティ、および権限を設定します。
  • デジタル署名を追加します。
  • メタデータや履歴を編集。

4.クロスプラットフォームサポート:

  • .NET Core (8、7、6、5、および 3.1+)、.NET Standard (2.0+)、.NET Framework (4.6.2+) 対応。
  • Windows、Linux、および macOS 互換。
  • NuGet で簡単にインストール可能。

IronPDFとLazyCacheを使用してPDFドキュメントを生成する

はじめに、以下のように Visual Studio を使用してコンソールアプリケーションを作成します。

LazyCache C#(開発者にとっての動作方法):図2 - コンソールアプリ

プロジェクト名を提供します。

LazyCache C#(開発者にとっての動作方法):図3 - プロジェクト設定

.NETのバージョンを提供してください。

LazyCache C#(開発者にとっての動作方法):図4 - 対象フレームワーク

IronPDFパッケージをインストールします。

LazyCache C#(開発者にとっての動作方法):図5 - IronPDF

キャッシュされたメソッド呼び出しを追加するためにLazyCacheパッケージをインストールします。

LazyCache C#(開発者にとっての動作方法):図6 - LazyCache

using LazyCache;
using IronPdf; // Add the IronPdf namespace
using System;

namespace CodeSample
{
    internal class LazyCacheDemo
    {
        public static void Execute()
        {
            // Instantiate the Chrome PDF Renderer
            var renderer = new ChromePdfRenderer();
            var content = "<h1>Demo LazyCache and IronPDF</h1>";
            content += "<h2>Create CachingService</h2>";

            // Create the cache service using LazyCache
            IAppCache cache = new CachingService();

            var cacheKey = "uniqueKey"; // Unique key for caching the content

            // Define a factory method to generate the cacheable data
            Func<string> expensiveLongRunMethod = () =>
            {
                // Render the HTML content to a PDF
                var pdf = renderer.RenderHtmlAsPdf(content);

                // Export the rendered PDF to a file
                pdf.SaveAs("AwesomeLazyCacheAndIronPdf.pdf");

                // Return the content as a string
                return content;
            };

            // Get the cached value or execute expensiveLongRunMethod to cache it
            string cachedValue = cache.GetOrAdd(cacheKey, expensiveLongRunMethod);

            // Output the cached value to the console
            Console.WriteLine(cachedValue);
        }
    }
}
using LazyCache;
using IronPdf; // Add the IronPdf namespace
using System;

namespace CodeSample
{
    internal class LazyCacheDemo
    {
        public static void Execute()
        {
            // Instantiate the Chrome PDF Renderer
            var renderer = new ChromePdfRenderer();
            var content = "<h1>Demo LazyCache and IronPDF</h1>";
            content += "<h2>Create CachingService</h2>";

            // Create the cache service using LazyCache
            IAppCache cache = new CachingService();

            var cacheKey = "uniqueKey"; // Unique key for caching the content

            // Define a factory method to generate the cacheable data
            Func<string> expensiveLongRunMethod = () =>
            {
                // Render the HTML content to a PDF
                var pdf = renderer.RenderHtmlAsPdf(content);

                // Export the rendered PDF to a file
                pdf.SaveAs("AwesomeLazyCacheAndIronPdf.pdf");

                // Return the content as a string
                return content;
            };

            // Get the cached value or execute expensiveLongRunMethod to cache it
            string cachedValue = cache.GetOrAdd(cacheKey, expensiveLongRunMethod);

            // Output the cached value to the console
            Console.WriteLine(cachedValue);
        }
    }
}
$vbLabelText   $csharpLabel

コードの説明

*レンダラーのインスタンス化: HTML コンテンツを PDF 形式に変換する処理を処理するために、 ChromePdfRendererのインスタンスが作成されます。

  • Define Content: HTML content ("

    Demo LazyCache and IronPDF

    ", "

    Create CachingService

    ", etc.) is prepared. このコンテンツはPDFとしてレンダリングされ、再利用のためにキャッシュされます。

*キャッシュ サービスの作成:キャッシュ サービス ( IAppCache ) は、LazyCache のCachingServiceを使用してインスタンス化されます。 このレイジーキャッシュサービスはキャッシュデータの保存と取得を管理します。

*キャッシュ キー:キャッシュされた PDF コンテンツを表す一意の識別子 ("uniqueKey") が割り当てられます。

*高価なメソッドの定義:キャッシュ可能なデータを生成するためにファクトリ メソッド ( expensiveLongRunMethod ) が定義されます。 このメソッドはHTMLコンテンツをPDFとしてレンダリングするためにChromePdfRendererを呼び出します。 生成されたPDFは保存され、文字列として返されます。

*キャッシュの取得または追加:サービスのGetOrAddメソッドが呼び出され、 cacheKeyに関連付けられたキャッシュされた値が取得されます。 値がキャッシュに存在しない場合、expensiveLongRunMethodが実行されて計算され、キャッシュに保存され、返されます。 値がすでにキャッシュされている場合、それが直接返されます。

*出力:キャッシュされた PDF コンテンツ (文字列として) がコンソール ( Console.WriteLine(cachedValue) ) に出力され、キャッシュされたデータの取得が示されます。

出力

LazyCache C#(開発者にとっての動作方法):図7 - コンソール出力

PDF

LazyCache C#(開発者にとっての動作方法):図8 - PDF出力

IronPDFのライセンス(試用版あり)

IronPDFパッケージは、PDFを実行および生成するためにライセンスが必要です。 パッケージをアクセスする前に、アプリケーションの開始時に次のコードを追加します。

IronPdf.License.LicenseKey = "IRONPDF-MYLICENSE-KEY";
IronPdf.License.LicenseKey = "IRONPDF-MYLICENSE-KEY";
$vbLabelText   $csharpLabel

試用ライセンスはIronPDFの試用版ライセンスページで入手可能です。

結論

LazyCacheは、キャッシュ項目の自動有効期限と直感的なAPIを提供することで、C#アプリケーションにおけるキャッシングの実装を簡素化します。 LazyCacheをプロジェクトに統合することで、よくアクセスされるデータを効率的にキャッシュしてパフォーマンスを向上させ、レイテンシーを削減し、リソースの利用を効率化することができます。 Webアプリケーション、API、またはサービスを構築する場合でも、LazyCacheはC#アプリケーションのパフォーマンスとスケーラビリティを向上させるための貴重なツールとなります。

一方で、IronPDFは.NETアプリケーション内でPDFドキュメントを操作するための強力で多機能なC#ライブラリとして際立っています。 その強力な機能は、PDFの作成、編集、HTMLをPDFにレンダリング、およびPDFのプログラムによる操作を網羅しています。 暗号化やデジタル署名による安全な文書処理の機能を備えたIronPDFは、PDFワークフローを効率的に管理・カスタマイズするための能力を開発者に提供し、C#開発における広範囲のドキュメント管理および生成タスクにとって価値あるツールとなっています。

よくある質問

LazyCacheとは何ですか、そしてそれは.NETアプリケーションにどのように恩恵をもたらしますか?

LazyCache は、.NET/ASP.NET Core アプリケーション向けに設計されたキャッシングプロバイダライブラリです。キャッシングの実装を簡素化し、ボイラープレートコードを削減し、メモリ内データストレージを通じてパフォーマンスを向上させることで、これらのアプリケーションに利益をもたらします。

LazyCache を使用して C# でキャッシングを実装する方法は何ですか?

LazyCache を使用して C# にキャッシングを実装するには、NuGet を通じてライブラリをインストールし、LazyCache の CachingService を使ってキャッシングサービスを設定する必要があります。GetOrAdd メソッドを使用して、メソッドコールの結果を保存し、すでにキャッシュされていない場合にデータを取得するためのユニークキーとデリゲートを提供することでデータをキャッシュできます。

LazyCache は、データをどのようにキャッシュ内で最新に保つのでしょうか?

LazyCache は、設定可能なポリシーに基づいてキャッシュされたアイテムの自動期限切れをサポートすることで、データが最新の状態であることを保証します。この機能により、開発者は期限切れ時間を設定し、古いデータがユーザーに提供されるのを防ぎます。

何が LazyCache をスレッドセーフにしているのですか?

LazyCache は、その設計によってスレッドセーフであり、複数のスレッドがデータの破損を心配することなくキャッシュと対話することができます。ダブルロックメカニズムを使用して、マルチスレッドアプリケーションでのキャッシュ操作が安全に行われることを保証します。

C# プロジェクトにおける PDF ドキュメント管理を最適化する方法は何ですか?

C# プロジェクトにおける PDF ドキュメント管理は、HTML から PDF への変換、コンテンツ抽出、PDF 編集などの強力な機能を提供する IronPDF を使用して最適化できます。クロスプラットフォームの互換性をサポートしており、生成された PDF をキャッシュするために LazyCache と統合してパフォーマンスを向上させることができます。

LazyCache を分散キャッシングに使用することは可能ですか?

はい、LazyCache はカスタムキャッシングストラテジーを実装するための拡張性を提供しており、分散キャッシングを含む柔軟性を持っています。この柔軟性により、分散環境をサポートするために、他のキャッシングシステムとの統合が可能です。

LazyCacheと一緒にC# PDFライブラリを使う利点は何ですか?

LazyCacheと一緒にIronPDFのようなC# PDFライブラリを使用することで、PDF ドキュメントを効率的に生成およびキャッシュできます。この組み合わせにより、余分なPDF生成を避けてアプリケーションのパフォーマンスが向上し、頻繁に要求されるドキュメントへの迅速なアクセスが可能になります。

IronPDFのようなC# PDFライブラリを使用するためのライセンス要件は何ですか?

IronPDF をフル機能で利用するにはライセンスが必要です。開発者は IronPDF のウェブサイトで利用可能なトライアルライセンスから始めることができ、アプリケーションコードにライセンスキーを含めて PDF を生成するためにライブラリをアクティブ化する必要があります。

LazyCacheはアプリケーションパフォーマンスをどのように向上させるのですか?

LazyCache は、頻繁にアクセスされるデータをメモリに保存することで、繰り返しのデータ取得操作の必要性を減らし、アプリケーションのパフォーマンスを向上させます。これにより、応答時間が短縮され、データベースや外部データソースにかかる負荷が軽減されます。

Jacob Mellor、Ironチームの最高技術責任者(CTO)
最高技術責任者(CTO)

Jacob Mellorは、Iron Softwareの最高技術責任者であり、C# PDF技術の開拓者としてその先進的な役割を担っています。Iron Softwareのコアコードベースのオリジナルデベロッパーである彼は、創業時から製品のアーキテクチャを形作り、CEOのCameron Rimingtonと協力してNASA、Tesla、全世界の政府機関を含む50人以上の会社に成長させました。

Jacobは、1998年から2001年にかけてマンチェスター大学で土木工学の第一級優等学士号(BEng)を取得しました。1999年にロンドンで最初のソフトウェアビジネスを立ち上げ、2005年には最初の.NETコンポーネントを作成し、Microsoftエコシステムにおける複雑な問題の解決を専門にしました。

彼の旗艦製品であるIronPDFとIronSuite .NETライブラリは、全世界で3000万以上のNuGetインストールを達成しており、彼の基本コードが世界中で使用されている開発者ツールを支えています。商業的な経験を25年間積み、コードを書くことを41年間続けるJacobは、企業向けのC#、Java、およびPython PDF技術の革新を推進し続け、次世代の技術リーダーを指導しています。