{"id":1998,"date":"2024-12-26T16:21:35","date_gmt":"2024-12-26T07:21:35","guid":{"rendered":"https:\/\/dexall.co.jp\/articles\/?p=1998"},"modified":"2025-03-24T08:48:58","modified_gmt":"2025-03-23T23:48:58","slug":"c-%e3%82%a4%e3%83%b3%e3%82%bf%e3%83%bc%e3%83%95%e3%82%a7%e3%83%bc%e3%82%b9%e5%ae%8c%e5%85%a8%e3%82%ac%e3%82%a4%e3%83%89%ef%bc%9a%e8%a8%ad%e8%a8%88%e3%81%ae%e5%9f%ba%e7%a4%8e%e3%81%8b%e3%82%89","status":"publish","type":"post","link":"https:\/\/dexall.co.jp\/articles\/?p=1998","title":{"rendered":"C# \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u5b8c\u5168\u30ac\u30a4\u30c9\uff1a\u8a2d\u8a08\u306e\u57fa\u790e\u304b\u3089\u5b9f\u8df5\u7684\u306a\u6d3b\u7528\u307e\u30677\u3064\u306e\u30c6\u30af\u30cb\u30c3\u30af"},"content":{"rendered":"\n<div class=\"toc\"><br \/>\n<b>Warning<\/b>:  Undefined array key \"is_admin\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>116<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_category_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>121<\/b><br \/>\n<br \/>\n<b>Warning<\/b>:  Undefined array key \"is_top\" in <b>\/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/sango-theme\/library\/gutenberg\/dist\/classes\/Toc.php<\/b> on line <b>128<\/b><br \/>\n    <div id=\"toc_container\" class=\"sgb-toc--bullets js-smooth-scroll\" data-dialog-title=\"\u76ee\u6b21\">\n      <p class=\"toc_title\">\u76ee\u6b21 <\/p>\n      <ul class=\"toc_list\">  <li class=\"first\">    <a href=\"#i-0\">\u306f\u3058\u3081\u306b<\/a>  <\/li>  <li>    <a href=\"#i-1\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3068\u306f\uff1f\u4f7f\u3046\u7406\u7531\u3068\u57fa\u672c\u6982\u5ff5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-2\">\u30af\u30e9\u30b9\u3068\u7570\u306a\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u7279\u5fb4<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-6\">\u306a\u305c\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u4f7f\u3046\u306e\u304b\uff1f3\u3064\u306e\u4e3b\u8981\u306a\u30e1\u30ea\u30c3\u30c8<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-10\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u57fa\u672c\u7684\u306a\u5b9f\u88c5\u65b9\u6cd5<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-11\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5ba3\u8a00\u3068\u5b9f\u88c5\u306e\u57fa\u672c\u69cb\u6587<\/a>      <\/li>      <li>        <a href=\"#i-14\">\u8907\u6570\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/a>      <\/li>      <li>        <a href=\"#i-17\">\u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u306e\u6d3b\u7528\u65b9\u6cd5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-19\">\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-20\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-21\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u5206\u96e2\u306e\u539f\u5247(ISP)\u306e\u5b9f\u8df5<\/a>      <\/li>      <li>        <a href=\"#i-24\">\u4f9d\u5b58\u6027\u9006\u8ee2\u306e\u539f\u5247(DIP)\u3068\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9<\/a>      <\/li>      <li>        <a href=\"#i-25\">\u547d\u540d\u898f\u5247\u3068\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u898f\u7d04<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-28\">\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30ac\u30a4\u30c9\u30e9\u30a4\u30f3<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-29\">\u5b9f\u8df5\u7684\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u6d3b\u7528\u30c6\u30af\u30cb\u30c3\u30af<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-30\">\u4f9d\u5b58\u6027\u6ce8\u5165(DI)\u306b\u304a\u3051\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5f79\u5272<\/a>      <\/li>      <li>        <a href=\"#i-33\">\u30e2\u30c3\u30af\u3092\u4f7f\u7528\u3057\u305f\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8\u306e\u5b9f\u88c5<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-35\">\u30d7\u30e9\u30b0\u30a4\u30f3\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306e\u5b9f\u73fe\u65b9\u6cd5<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-38\">\u3088\u304f\u3042\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30d1\u30bf\u30fc\u30f3<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-39\">\u30ea\u30dd\u30b8\u30c8\u30ea\u30d1\u30bf\u30fc\u30f3\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u6d3b\u7528<\/a>      <\/li>      <li>        <a href=\"#i-41\">Strategy\u30d1\u30bf\u30fc\u30f3\u306e\u5b9f\u88c5\u4f8b<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-43\">Observer\u30d1\u30bf\u30fc\u30f3\u3067\u306e\u30a4\u30d9\u30f3\u30c8\u51e6\u7406<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-45\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u6ce8\u610f\u70b9<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-46\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3078\u306e\u5f71\u97ff\u3068\u6700\u9069\u5316<\/a>      <\/li>      <li>        <a href=\"#i-49\">\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\u3068\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u9032\u5316<\/a>      <\/li>      <li>        <a href=\"#i-51\">\u904e\u5270\u306a\u62bd\u8c61\u5316\u3092\u907f\u3051\u308b\u305f\u3081\u306e\u6307\u91dd<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-54\">\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8<\/a>      <\/li>    <\/ul>  <\/li>  <li>    <a href=\"#i-55\">\u5b9f\u8df5\u7684\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u6f14\u7fd2<\/a>    <ul class=\"menu_level_1\">      <li class=\"first\">        <a href=\"#i-56\">EC\u30b5\u30a4\u30c8\u306e\u652f\u6255\u3044\u51e6\u7406\u30b7\u30b9\u30c6\u30e0\u306e\u8a2d\u8a08<\/a>      <\/li>      <li>        <a href=\"#i-59\">\u30ed\u30b0\u6a5f\u80fd\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08<\/a>      <\/li>      <li>        <a href=\"#i-60\">\u30de\u30eb\u30c1\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u5bfe\u5fdc\u306e\u5b9f\u88c5\u4f8b<\/a>      <\/li>      <li class=\"last\">        <a href=\"#i-62\">\u3053\u308c\u3089\u306e\u5b9f\u88c5\u4f8b\u306f\u3001\u4ee5\u4e0b\u306e\u8a2d\u8a08\u539f\u5247\u3068\u5b9f\u8df5\u3092\u793a\u3057\u3066\u3044\u307e\u3059\u3002<\/a>      <\/li>    <\/ul>  <\/li>  <li class=\"last\">    <a href=\"#i-63\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u307e\u3068\u3081<\/a>  <\/li><\/ul>\n      <a href=\"#\" class=\"sgb-toc-button js-toc-button\" rel=\"nofollow\" data-open-dialog=\"true\"><i class=\"fa fa-list\"><\/i><span class=\"sgb-toc-button__text\">\u76ee\u6b21\u3078<\/span><\/a>\n    <\/div><\/div><h2 class=\"wp-block-heading\" id=\"i-0\">\u306f\u3058\u3081\u306b<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">C#\u306b\u304a\u3051\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u3001\u5805\u7262\u3067\u4fdd\u5b88\u6027\u306e\u9ad8\u3044\u30bd\u30d5\u30c8\u30a6\u30a7\u30a2\u3092\u8a2d\u8a08\u3059\u308b\u4e0a\u3067\u6b20\u304b\u305b\u306a\u3044\u6a5f\u80fd\u3067\u3059\u3002<br>\u672c\u8a18\u4e8b\u3067\u306f\u3001\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u57fa\u672c\u6982\u5ff5\u304b\u3089\u5b9f\u8df5\u7684\u306a\u6d3b\u7528\u65b9\u6cd5\u307e\u3067\u3001\u5b9f\u52d9\u3067\u5373\u5ea7\u306b\u6d3b\u7528\u3067\u304d\u308b\u77e5\u8b58\u3092\u4f53\u7cfb\u7684\u306b\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u672c\u8a18\u4e8b\u3067\u5b66\u3079\u308b\u3053\u3068<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<p class=\"is-style-sango-paragraph-idea-alt wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u57fa\u672c\u6982\u5ff5\u3068\u5b9f\u88c5\u65b9\u6cd5<\/p>\n\n\n\n<p class=\"is-style-sango-paragraph-idea-alt wp-block-paragraph\">SOLID\u539f\u5247\u306b\u57fa\u3065\u3044\u305f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u624b\u6cd5<\/p>\n\n\n\n<p class=\"is-style-sango-paragraph-idea-alt wp-block-paragraph\">\u4f9d\u5b58\u6027\u6ce8\u5165\u3068\u30c6\u30b9\u30c8\u3092\u8003\u616e\u3057\u305f\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/p>\n\n\n\n<p class=\"is-style-sango-paragraph-idea-alt wp-block-paragraph\">\u4e00\u822c\u7684\u306a\u30c7\u30b6\u30a4\u30f3\u30d1\u30bf\u30fc\u30f3\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u6d3b\u7528\u65b9\u6cd5<\/p>\n\n\n\n<p class=\"is-style-sango-paragraph-idea-alt wp-block-paragraph\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3068\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\u3092\u8003\u616e\u3057\u305f\u5b9f\u88c5\u306e\u30b3\u30c4<\/p>\n\n\n\n<p class=\"is-style-sango-paragraph-idea-alt wp-block-paragraph\">\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u4f7f\u3048\u308b\u5177\u4f53\u7684\u306a\u5b9f\u88c5\u4f8b<\/p>\n<\/div><\/div>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-1\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3068\u306f\uff1f\u4f7f\u3046\u7406\u7531\u3068\u57fa\u672c\u6982\u5ff5<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\uff08interface\uff09\u306f\u3001C#\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u306b\u304a\u3051\u308b\u91cd\u8981\u306a\u6982\u5ff5\u306e1\u3064\u3067\u3001\u30af\u30e9\u30b9\u304c\u5b9f\u88c5\u3059\u3079\u304d\u30e1\u30f3\u30d0\u30fc\u3092\u5b9a\u7fa9\u3059\u308b\u5951\u7d04\u306e\u3088\u3046\u306a\u5f79\u5272\u3092\u679c\u305f\u3057\u307e\u3059\u3002<br>\u5b9f\u52d9\u3067\u306f\u3001EC\u30b5\u30a4\u30c8\u3067\u306e\u6c7a\u6e08\u51e6\u7406\u3001\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u30a2\u30af\u30bb\u30b9\u3001\u30ed\u30b0\u51fa\u529b\u306a\u3069\u3001\u5b9f\u88c5\u306e\u8a73\u7d30\u3092\u62bd\u8c61\u5316\u3057\u305f\u3044\u5834\u5408\u306b\u7279\u306b\u6709\u52b9\u3067\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-2\">\u30af\u30e9\u30b9\u3068\u7570\u306a\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u7279\u5fb4<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-3\">1. <strong>\u5b9f\u88c5\u3092\u6301\u305f\u306a\u3044<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-box sng-box box6\">\n<ul class=\"wp-block-list is-style-sango-list-yubi\">\n<li>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u30e1\u30bd\u30c3\u30c9\u3084\u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u300c\u30b7\u30b0\u30cd\u30c1\u30e3\u300d\u306e\u307f\u3092\u5b9a\u7fa9<\/li>\n\n\n\n<li>\u5177\u4f53\u7684\u306a\u5b9f\u88c5\u306f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u5b9f\u88c5\u3059\u308b\u30af\u30e9\u30b9\u304c\u62c5\u5f53<\/li>\n<\/ul>\n<\/div>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9a\u7fa9\u4f8b\npublic interface ILogger\n{\n    void Log(string message);    \/\/ \u30e1\u30bd\u30c3\u30c9\u306e\u5ba3\u8a00\u306e\u307f\n    LogLevel Level { get; set; } \/\/ \u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u5ba3\u8a00\u306e\u307f\n}\n\n\/\/ \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u4f8b\npublic class FileLogger : ILogger\n{\n    public LogLevel Level { get; set; }\n\n    public void Log(string message)\n    {\n        \/\/ \u5177\u4f53\u7684\u306a\u5b9f\u88c5\u3092\u3053\u3053\u3067\u884c\u3046\n        File.WriteAllText($\"log_{DateTime.Now:yyyyMMdd}.txt\", message);\n    }\n}\n\n\/\/ \u5225\u306e\u5b9f\u88c5\u4f8b\npublic class DatabaseLogger : ILogger\n{\n    public LogLevel Level { get; set; }\n\n    public void Log(string message)\n    {\n        using var connection = new SqlConnection(\"connection_string\");\n        \/\/ \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u306b\u30ed\u30b0\u3092\u4fdd\u5b58\u3059\u308b\u5b9f\u88c5\n    }\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-4\">2. <strong>\u591a\u91cd\u7d99\u627f\u304c\u53ef\u80fd<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-box sng-box box6\">\n<ul class=\"wp-block-list is-style-sango-list-yubi\">\n<li>\u30af\u30e9\u30b9\u3068\u7570\u306a\u308a\u3001\u8907\u6570\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u540c\u6642\u306b\u5b9f\u88c5\u53ef\u80fd<\/li>\n\n\n\n<li>\u3053\u308c\u306b\u3088\u308a\u3001\u67d4\u8edf\u306a\u6a5f\u80fd\u306e\u7d44\u307f\u5408\u308f\u305b\u304c\u5b9f\u73fe\u3067\u304d\u308b<\/li>\n<\/ul>\n<\/div>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IEmailSender\n{\n    Task SendEmailAsync(string to, string subject, string body);\n}\n\npublic interface ISMSSender\n{\n    Task SendSMSAsync(string to, string message);\n}\n\n\/\/ \u8907\u6570\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u5b9f\u88c5\npublic class NotificationService : IEmailSender, ISMSSender\n{\n    public async Task SendEmailAsync(string to, string subject, string body)\n    {\n        \/\/ \u30e1\u30fc\u30eb\u9001\u4fe1\u306e\u5b9f\u88c5\n        await Task.CompletedTask; \/\/ \u5b9f\u969b\u306e\u5b9f\u88c5\u3067\u306fSMTP\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306a\u3069\u3092\u4f7f\u7528\n    }\n\n    public async Task SendSMSAsync(string to, string message)\n    {\n        \/\/ SMS\u9001\u4fe1\u306e\u5b9f\u88c5\n        await Task.CompletedTask; \/\/ \u5b9f\u969b\u306e\u5b9f\u88c5\u3067\u306fSMS\u30b5\u30fc\u30d3\u30b9\u306eAPI\u3092\u4f7f\u7528\n    }\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-5\">3. <strong>\u30d5\u30a3\u30fc\u30eb\u30c9\u3092\u6301\u3066\u306a\u3044<\/strong><\/h4>\n\n\n\n<div class=\"wp-block-sgb-box sng-box box6\">\n<ul class=\"wp-block-list is-style-sango-list-yubi\">\n<li>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u72b6\u614b\u3092\u6301\u3064\u3053\u3068\u304c\u3067\u304d\u306a\u3044<\/li>\n\n\n\n<li>\u30e1\u30bd\u30c3\u30c9\u3001\u30d7\u30ed\u30d1\u30c6\u30a3\u3001\u30a4\u30d9\u30f3\u30c8\u3001\u30a4\u30f3\u30c7\u30af\u30b5\u30fc\u306e\u307f\u3092\u5b9a\u7fa9\u53ef\u80fd<\/li>\n<\/ul>\n<\/div>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-6\">\u306a\u305c\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u4f7f\u3046\u306e\u304b\uff1f3\u3064\u306e\u4e3b\u8981\u306a\u30e1\u30ea\u30c3\u30c8<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-7\">1. <strong>\u758e\u7d50\u5408\u306e\u5b9f\u73fe<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u9593\u306e\u4f9d\u5b58\u95a2\u4fc2\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u308b<\/li>\n\n\n\n<li>\u30c6\u30b9\u30c8\u5bb9\u6613\u6027\u306e\u5411\u4e0a<\/li>\n\n\n\n<li>\u5909\u66f4\u306b\u5f37\u3044\u8a2d\u8a08\u306e\u5b9f\u73fe<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u758e\u7d50\u5408\u306e\u4f8b\npublic class OrderProcessor\n{\n    private readonly IPaymentGateway _paymentGateway;\n    private readonly ILogger _logger;\n\n    public OrderProcessor(IPaymentGateway paymentGateway, ILogger logger)\n    {\n        _paymentGateway = paymentGateway;\n        _logger = logger;\n    }\n\n    public async Task ProcessOrderAsync(Order order)\n    {\n        try\n        {\n            \/\/ \u652f\u6255\u3044\u51e6\u7406\u306e\u5b9f\u884c\n            await _paymentGateway.ProcessPaymentAsync(order.Amount);\n            _logger.Log($\"Order {order.Id} processed successfully\");\n        }\n        catch (Exception ex)\n        {\n            _logger.Log($\"Error processing order {order.Id}: {ex.Message}\");\n            throw;\n        }\n    }\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-8\">2. <strong>\u67d4\u8edf\u6027\u3068\u62e1\u5f35\u6027\u306e\u5411\u4e0a<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u65b0\u3057\u3044\u5b9f\u88c5\u306e\u8ffd\u52a0\u304c\u5bb9\u6613<\/li>\n\n\n\n<li>\u65e2\u5b58\u30b3\u30fc\u30c9\u306e\u5909\u66f4\u306a\u3057\u3067\u6a5f\u80fd\u62e1\u5f35\u304c\u53ef\u80fd<\/li>\n\n\n\n<li>\u30d7\u30e9\u30b0\u30a4\u30f3\u578b\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306e\u5b9f\u73fe<\/li>\n<\/ul>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-9\">3. <strong>\u5951\u7d04\u306b\u3088\u308b\u8a2d\u8a08\u306e\u5b9f\u73fe<\/strong><\/h4>\n\n\n\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u304c\u660e\u78ba\u306a\u5951\u7d04\u3068\u3057\u3066\u6a5f\u80fd<\/li>\n\n\n\n<li>\u30c1\u30fc\u30e0\u958b\u767a\u3067\u306e\u5f79\u5272\u5206\u62c5\u304c\u660e\u78ba\u306b<\/li>\n\n\n\n<li>\u30b3\u30fc\u30c9\u306e\u54c1\u8cea\u3068\u4fdd\u5b88\u6027\u306e\u5411\u4e0a<\/li>\n<\/ul>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u5951\u7d04\u306b\u3088\u308b\u8a2d\u8a08\u306e\u4f8b\npublic interface ICustomerRepository\n{\n    Task&lt;Customer&gt; GetByIdAsync(int id);\n    Task&lt;Customer&gt; CreateAsync(Customer customer);\n    Task UpdateAsync(Customer customer);\n    Task DeleteAsync(int id);\n}\n\n\/\/ \u30c1\u30fc\u30e0\u30e1\u30f3\u30d0\u30fcA\u304c\u5b9f\u88c5\npublic class SqlCustomerRepository : ICustomerRepository\n{\n    private readonly string _connectionString;\n\n    public SqlCustomerRepository(string connectionString)\n    {\n        _connectionString = connectionString;\n    }\n\n    \/\/ SQL\u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u3092\u4f7f\u7528\u3057\u305f\u5b9f\u88c5\n    public async Task&lt;Customer&gt; GetByIdAsync(int id)\n    {\n        using var connection = new SqlConnection(_connectionString);\n        return await connection.QueryFirstOrDefaultAsync&lt;Customer&gt;(\n            \"SELECT * FROM Customers WHERE Id = @Id\",\n            new { Id = id }\n        );\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}\n\n\/\/ \u30c1\u30fc\u30e0\u30e1\u30f3\u30d0\u30fcB\u304c\u5b9f\u88c5\npublic class MongoCustomerRepository : ICustomerRepository\n{\n    private readonly IMongoDatabase _database;\n\n    public MongoCustomerRepository(IMongoDatabase database)\n    {\n        _database = database;\n    }\n\n    \/\/ MongoDB\u3092\u4f7f\u7528\u3057\u305f\u5b9f\u88c5\n    public async Task&lt;Customer&gt; GetByIdAsync(int id)\n    {\n        var collection = _database.GetCollection&lt;Customer&gt;(\"customers\");\n        return await collection.Find(c =&gt; c.Id == id).FirstOrDefaultAsync();\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u9069\u5207\u306b\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u4fdd\u5b88\u6027\u304c\u9ad8\u304f\u3001\u62e1\u5f35\u6027\u306e\u3042\u308b\u30b3\u30fc\u30c9\u3092\u66f8\u304f\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u5b9f\u969b\u306b\u3069\u306e\u3088\u3046\u306b\u5b9f\u88c5\u3057\u3066\u3044\u304f\u306e\u304b\u3092\u3001\u3088\u308a\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-10\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u57fa\u672c\u7684\u306a\u5b9f\u88c5\u65b9\u6cd5<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u306e\u5b9f\u8df5\u3067\u306f\u3001\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u6b63\u3057\u304f\u5b9f\u88c5\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<br>\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001C#\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u65b9\u6cd5\u3092\u3001\u73fe\u4ee3\u7684\u306a\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306b\u57fa\u3065\u3044\u3066\u89e3\u8aac\u3057\u3066\u3044\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-11\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5ba3\u8a00\u3068\u5b9f\u88c5\u306e\u57fa\u672c\u69cb\u6587<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5ba3\u8a00\u3068\u5b9f\u88c5\u306b\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u57fa\u672c\u7684\u306a\u30eb\u30fc\u30eb\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-12\">1. <strong>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5ba3\u8a00<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IDataService&lt;T&gt; where T : class\n{\n    \/\/ \u975e\u540c\u671f\u30e1\u30bd\u30c3\u30c9\u306e\u5ba3\u8a00\n    Task&lt;T&gt; GetByIdAsync(int id);\n    Task&lt;IEnumerable&lt;T&gt;&gt; GetAllAsync();\n    Task&lt;T&gt; CreateAsync(T entity);\n\n    \/\/ \u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u5ba3\u8a00\n    bool IsConnected { get; }\n\n    \/\/ \u30a4\u30d9\u30f3\u30c8\u306e\u5ba3\u8a00\n    event EventHandler&lt;DataChangedEventArgs&lt;T&gt;&gt; DataChanged;\n}\n\n\/\/ \u30a4\u30d9\u30f3\u30c8\u5f15\u6570\u306e\u5b9a\u7fa9\npublic class DataChangedEventArgs&lt;T&gt; : EventArgs\n{\n    public T Data { get; }\n    public ChangeType ChangeType { get; }\n    public DateTime Timestamp { get; }\n\n    public DataChangedEventArgs(T data, ChangeType changeType)\n    {\n        Data = data;\n        ChangeType = changeType;\n        Timestamp = DateTime.UtcNow;\n    }\n}\n\npublic enum ChangeType\n{\n    Created,\n    Updated,\n    Deleted\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-13\">2. <strong>\u30b8\u30a7\u30cd\u30ea\u30c3\u30af\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public class SqlDataService&lt;T&gt; : IDataService&lt;T&gt; where T : class\n{\n    private readonly DbContext _context;\n    private readonly DbSet&lt;T&gt; _dbSet;\n    private bool _isConnected;\n\n    public SqlDataService(DbContext context)\n    {\n        _context = context;\n        _dbSet = context.Set&lt;T&gt;();\n        _isConnected = true;\n    }\n\n    \/\/ \u30d7\u30ed\u30d1\u30c6\u30a3\u306e\u5b9f\u88c5\n    public bool IsConnected =&gt; _isConnected;\n\n    \/\/ \u30a4\u30d9\u30f3\u30c8\u306e\u5b9f\u88c5\n    public event EventHandler&lt;DataChangedEventArgs&lt;T&gt;&gt; DataChanged;\n\n    \/\/ \u975e\u540c\u671f\u30e1\u30bd\u30c3\u30c9\u306e\u5b9f\u88c5\n    public async Task&lt;T&gt; GetByIdAsync(int id)\n    {\n        return await _dbSet.FindAsync(id);\n    }\n\n    public async Task&lt;IEnumerable&lt;T&gt;&gt; GetAllAsync()\n    {\n        return await _dbSet.ToListAsync();\n    }\n\n    public async Task&lt;T&gt; CreateAsync(T entity)\n    {\n        var entry = await _dbSet.AddAsync(entity);\n        await _context.SaveChangesAsync();\n\n        \/\/ \u30a4\u30d9\u30f3\u30c8\u306e\u767a\u706b\n        OnDataChanged(entity, ChangeType.Created);\n\n        return entry.Entity;\n    }\n\n    \/\/ \u30a4\u30d9\u30f3\u30c8\u767a\u706b\u7528\u306e\u4fdd\u8b77\u30e1\u30bd\u30c3\u30c9\n    protected virtual void OnDataChanged(T data, ChangeType changeType)\n    {\n        DataChanged?.Invoke(this, new DataChangedEventArgs&lt;T&gt;(data, changeType));\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-14\">\u8907\u6570\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u8907\u6570\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u5b9f\u88c5\u3059\u308b\u969b\u306e\u4e3b\u8981\u306a\u30c6\u30af\u30cb\u30c3\u30af\u3092\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-15\">1. <strong>\u660e\u793a\u7684\u5b9f\u88c5\u3092\u4f7f\u7528\u3057\u305f\u7af6\u5408\u89e3\u6c7a<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IReadableStorage\n{\n    Task&lt;string&gt; ReadAsync(string key);\n}\n\npublic interface IWritableStorage\n{\n    Task WriteAsync(string key, string value);\n}\n\npublic interface IVersionedStorage\n{\n    Task&lt;string&gt; ReadAsync(string key, int version);\n}\n\npublic class FileStorage : IReadableStorage, IWritableStorage, IVersionedStorage\n{\n    private readonly string _basePath;\n\n    public FileStorage(string basePath)\n    {\n        _basePath = basePath;\n        Directory.CreateDirectory(basePath);\n    }\n\n    \/\/ IReadableStorage\u306e\u5b9f\u88c5\n    async Task&lt;string&gt; IReadableStorage.ReadAsync(string key)\n    {\n        var path = Path.Combine(_basePath, key);\n        return await File.ReadAllTextAsync(path);\n    }\n\n    \/\/ IWritableStorage\u306e\u5b9f\u88c5\n    async Task IWritableStorage.WriteAsync(string key, string value)\n    {\n        var path = Path.Combine(_basePath, key);\n        await File.WriteAllTextAsync(path, value);\n    }\n\n    \/\/ IVersionedStorage\u306e\u5b9f\u88c5\n    async Task&lt;string&gt; IVersionedStorage.ReadAsync(string key, int version)\n    {\n        var path = Path.Combine(_basePath, $\"{key}.{version}\");\n        return await File.ReadAllTextAsync(path);\n    }\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-16\">2. <strong>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u7d99\u627f\u3092\u6d3b\u7528\u3057\u305f\u968e\u5c64\u7684\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IBaseLogger\n{\n    Task LogAsync(string message);\n}\n\npublic interface IAdvancedLogger : IBaseLogger\n{\n    Task LogWithSeverityAsync(string message, LogSeverity severity);\n    Task&lt;IEnumerable&lt;LogEntry&gt;&gt; GetRecentLogsAsync(int count);\n}\n\npublic class FullLogger : IAdvancedLogger\n{\n    private readonly List&lt;LogEntry&gt; _logs = new();\n    private readonly IConfiguration _configuration;\n\n    public FullLogger(IConfiguration configuration)\n    {\n        _configuration = configuration;\n    }\n\n    public async Task LogAsync(string message)\n    {\n        await LogWithSeverityAsync(message, LogSeverity.Information);\n    }\n\n    public async Task LogWithSeverityAsync(string message, LogSeverity severity)\n    {\n        var entry = new LogEntry\n        {\n            Message = message,\n            Severity = severity,\n            Timestamp = DateTime.UtcNow\n        };\n\n        _logs.Add(entry);\n\n        \/\/ \u8a2d\u5b9a\u306b\u57fa\u3065\u3044\u3066\u30ed\u30b0\u3092\u6c38\u7d9a\u5316\n        if (_configuration.GetValue&lt;bool&gt;(\"PersistLogs\"))\n        {\n            await PersistLogEntryAsync(entry);\n        }\n    }\n\n    public Task&lt;IEnumerable&lt;LogEntry&gt;&gt; GetRecentLogsAsync(int count)\n    {\n        return Task.FromResult(\n            _logs.OrderByDescending(l =&gt; l.Timestamp)\n                 .Take(count)\n                 .AsEnumerable()\n        );\n    }\n\n    private async Task PersistLogEntryAsync(LogEntry entry)\n    {\n        \/\/ \u30ed\u30b0\u306e\u6c38\u7d9a\u5316\u51e6\u7406\n        await Task.CompletedTask;\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-17\">\u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u306e\u6d3b\u7528\u65b9\u6cd5<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">C# 8.0\u4ee5\u964d\u3067\u5c0e\u5165\u3055\u308c\u305f\u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u6a5f\u80fd\u3092\u4f7f\u7528\u3059\u308b\u3068\u3001\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306b\u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u632f\u308b\u821e\u3044\u3092\u5b9a\u7fa9\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-18\">1. <strong>\u57fa\u672c\u7684\u306a\u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IMetricsCollector\n{\n    \/\/ \u57fa\u672c\u7684\u306a\u30e1\u30c8\u30ea\u30af\u30b9\u53ce\u96c6\u30e1\u30bd\u30c3\u30c9\n    Task CollectMetricsAsync();\n\n    \/\/ \u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u3092\u6301\u3064\u30e1\u30bd\u30c3\u30c9\n    Task&lt;MetricsSummary&gt; GetSummaryAsync() =&gt; Task.FromResult(new MetricsSummary\n    {\n        CollectedAt = DateTime.UtcNow,\n        Status = \"Default Summary\"\n    });\n\n    \/\/ \u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u3092\u6301\u3064\u30d7\u30ed\u30d1\u30c6\u30a3\n    bool IsEnabled { get =&gt; true; }\n}\n\n\/\/ \u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u3092\u4f7f\u7528\npublic class BasicMetricsCollector : IMetricsCollector\n{\n    public async Task CollectMetricsAsync()\n    {\n        \/\/ \u30e1\u30c8\u30ea\u30af\u30b9\u53ce\u96c6\u306e\u57fa\u672c\u5b9f\u88c5\n        await Task.CompletedTask;\n    }\n    \/\/ GetSummaryAsync \u3068IsEnabled \u306f\u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u3092\u4f7f\u7528\n}\n\n\/\/ \u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u3092\u30aa\u30fc\u30d0\u30fc\u30e9\u30a4\u30c9\npublic class CustomMetricsCollector : IMetricsCollector\n{\n    private readonly ILogger&lt;CustomMetricsCollector&gt; _logger;\n\n    public CustomMetricsCollector(ILogger&lt;CustomMetricsCollector&gt; logger)\n    {\n        _logger = logger;\n    }\n\n    public async Task CollectMetricsAsync()\n    {\n        await Task.CompletedTask;\n        _logger.LogInformation(\"Metrics collected\");\n    }\n\n    public async Task&lt;MetricsSummary&gt; GetSummaryAsync()\n    {\n        \/\/ \u30ab\u30b9\u30bf\u30e0\u30b5\u30de\u30ea\u30fc\u751f\u6210\u30ed\u30b8\u30c3\u30af\n        return await Task.FromResult(new MetricsSummary\n        {\n            CollectedAt = DateTime.UtcNow,\n            Status = \"Custom Summary\"\n        });\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-19\">\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8<\/h3>\n\n\n\n<ol class=\"wp-block-list is-style-sango-list-stitch-blue\">\n<li><strong>\u975e\u540c\u671f\u51e6\u7406\u306e\u4e00\u8cab\u3057\u305f\u4f7f\u7528<\/strong>\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u975e\u540c\u671f\u30e1\u30bd\u30c3\u30c9\u306b\u306f\u5fc5\u305aAsync\u63a5\u5c3e\u8f9e\u3092\u4ed8\u3051\u308b<\/li>\n\n\n\n<li>Task\/ValueTask\u306e\u9069\u5207\u306a\u4f7f\u7528<\/li>\n\n\n\n<li>\u975e\u540c\u671f\u64cd\u4f5c\u306e\u30ad\u30e3\u30f3\u30bb\u30ec\u30fc\u30b7\u30e7\u30f3\u5bfe\u5fdc\u3092\u691c\u8a0e<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u8cac\u52d9\u306e\u660e\u78ba\u5316<\/strong>\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u5358\u4e00\u8cac\u4efb\u306e\u539f\u5247\u306b\u5f93\u3046<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u7c92\u5ea6\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u5206\u5272<\/li>\n\n\n\n<li>\u660e\u78ba\u306a\u547d\u540d\u898f\u5247\u306e\u9069\u7528<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0<\/strong>\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u9069\u5207\u306a\u4f8b\u5916\u578b\u306e\u4f7f\u7528<\/li>\n\n\n\n<li>\u4f8b\u5916\u306e\u9069\u5207\u306a\u4f1d\u64ad<\/li>\n\n\n\n<li>\u30ea\u30bd\u30fc\u30b9\u306e\u78ba\u5b9f\u306a\u89e3\u653e<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n\n\n\n<p class=\"wp-block-paragraph\">\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af\u3092\u6d3b\u7528\u3057\u305f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-20\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u512a\u308c\u305f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306f\u3001\u4fdd\u5b88\u6027\u306e\u9ad8\u3044\u5805\u7262\u306a\u30b7\u30b9\u30c6\u30e0\u306e\u57fa\u76e4\u3068\u306a\u308a\u307e\u3059\u3002<br>\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001SOLID\u539f\u5247\u306b\u57fa\u3065\u3044\u305f\u5b9f\u8df5\u7684\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u539f\u5247\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-21\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u5206\u96e2\u306e\u539f\u5247(ISP)\u306e\u5b9f\u8df5<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u5206\u96e2\u306e\u539f\u5247\u306f\u3001\u300c\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u306f\u3001\u4f7f\u7528\u3057\u306a\u3044\u30e1\u30bd\u30c3\u30c9\u3078\u306e\u4f9d\u5b58\u3092\u5f37\u5236\u3055\u308c\u308b\u3079\u304d\u3067\u306f\u306a\u3044\u300d\u3068\u3044\u3046\u8003\u3048\u65b9\u3067\u3059\u3002<br>\u3053\u306e\u539f\u5247\u3092\u5b9f\u8df5\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u67d4\u8edf\u3067\u4fdd\u5b88\u6027\u306e\u9ad8\u3044\u30b3\u30fc\u30c9\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-22\">1. <strong>\u554f\u984c\u306e\u3042\u308b\u8a2d\u8a08\u4f8b<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u907f\u3051\u308b\u3079\u304d\u8a2d\u8a08\uff1a\u80a5\u5927\u5316\u3057\u305f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\npublic interface IUserService\n{\n    \/\/ \u30e6\u30fc\u30b6\u30fc\u7ba1\u7406\n    Task&lt;User&gt; CreateUserAsync(User user);\n    Task&lt;User&gt; GetUserAsync(int userId);\n    Task UpdateUserAsync(User user);\n    Task DeleteUserAsync(int userId);\n\n    \/\/ \u30e1\u30fc\u30eb\u9001\u4fe1\n    Task SendWelcomeEmailAsync(string email);\n    Task SendPasswordResetEmailAsync(string email);\n\n    \/\/ \u8a8d\u8a3c\n    Task&lt;bool&gt; ValidateCredentialsAsync(string email, string password);\n    Task&lt;string&gt; GeneratePasswordResetTokenAsync(string email);\n\n    \/\/ \u30ec\u30dd\u30fc\u30c8\u751f\u6210\n    Task&lt;UserReport&gt; GenerateUserReportAsync(int userId);\n    Task&lt;ActivityReport&gt; GenerateActivityReportAsync(DateTime startDate, DateTime endDate);\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-23\">2. <strong>\u6539\u5584\u3055\u308c\u305f\u8a2d\u8a08\u4f8b<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u30e6\u30fc\u30b6\u30fc\u7ba1\u7406\u306e\u57fa\u672c\u64cd\u4f5c\npublic interface IUserRepository\n{\n    Task&lt;User&gt; CreateAsync(User user);\n    Task&lt;User&gt; GetByIdAsync(int userId);\n    Task UpdateAsync(User user);\n    Task DeleteAsync(int userId);\n}\n\n\/\/ \u30e1\u30fc\u30eb\u9001\u4fe1\u6a5f\u80fd\npublic interface IEmailService\n{\n    Task SendEmailAsync(string email, string subject, string body);\n    Task SendTemplatedEmailAsync(string email, string templateName, object templateData);\n}\n\n\/\/ \u30e6\u30fc\u30b6\u30fc\u8a8d\u8a3c\npublic interface IAuthenticationService\n{\n    Task&lt;bool&gt; ValidateCredentialsAsync(string email, string password);\n    Task&lt;string&gt; GeneratePasswordResetTokenAsync(string email);\n    Task&lt;bool&gt; ValidatePasswordResetTokenAsync(string email, string token);\n}\n\n\/\/ \u30ec\u30dd\u30fc\u30c8\u751f\u6210\npublic interface IReportGenerator&lt;T&gt;\n{\n    Task&lt;T&gt; GenerateReportAsync(ReportParameters parameters);\n}\n\n\/\/ \u5b9f\u88c5\u4f8b\npublic class UserService : IUserRepository\n{\n    private readonly IEmailService _emailService;\n    private readonly ILogger&lt;UserService&gt; _logger;\n    private readonly DbContext _context;\n\n    public UserService(\n        IEmailService emailService,\n        ILogger&lt;UserService&gt; logger,\n        DbContext context)\n    {\n        _emailService = emailService;\n        _logger = logger;\n        _context = context;\n    }\n\n    public async Task&lt;User&gt; CreateAsync(User user)\n    {\n        try\n        {\n            var entry = await _context.Users.AddAsync(user);\n            await _context.SaveChangesAsync();\n\n            await _emailService.SendTemplatedEmailAsync(\n                user.Email,\n                \"WelcomeEmail\",\n                new { user.Name }\n            );\n\n            return entry.Entity;\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error creating user\");\n            throw;\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-24\">\u4f9d\u5b58\u6027\u9006\u8ee2\u306e\u539f\u5247(DIP)\u3068\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u4f9d\u5b58\u6027\u9006\u8ee2\u306e\u539f\u5247\u306f\u3001\u300c\u4e0a\u4f4d\u30e2\u30b8\u30e5\u30fc\u30eb\u306f\u4e0b\u4f4d\u30e2\u30b8\u30e5\u30fc\u30eb\u306b\u4f9d\u5b58\u3059\u3079\u304d\u3067\u306f\u306a\u3044\u3002\u4e21\u8005\u306f\u62bd\u8c61\u306b\u4f9d\u5b58\u3059\u3079\u304d\u300d\u3068\u3044\u3046\u8003\u3048\u65b9\u3067\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u30c9\u30e1\u30a4\u30f3\u30ec\u30a4\u30e4\u30fc\uff08\u4e2d\u5fc3\u90e8\uff09\npublic interface IOrderRepository\n{\n    Task&lt;Order&gt; GetByIdAsync(int id);\n    Task&lt;Order&gt; CreateAsync(Order order);\n    Task UpdateAsync(Order order);\n}\n\n\/\/ \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30ec\u30a4\u30e4\u30fc\uff08\u30e6\u30fc\u30b9\u30b1\u30fc\u30b9\uff09\npublic class OrderProcessingService\n{\n    private readonly IOrderRepository _orderRepository;\n    private readonly IPaymentProcessor _paymentProcessor;\n    private readonly INotificationService _notificationService;\n\n    public OrderProcessingService(\n        IOrderRepository orderRepository,\n        IPaymentProcessor paymentProcessor,\n        INotificationService notificationService)\n    {\n        _orderRepository = orderRepository;\n        _paymentProcessor = paymentProcessor;\n        _notificationService = notificationService;\n    }\n\n    public async Task&lt;ProcessOrderResult&gt; ProcessOrderAsync(Order order)\n    {\n        try\n        {\n            \/\/ \u6ce8\u6587\u306e\u4fdd\u5b58\n            var savedOrder = await _orderRepository.CreateAsync(order);\n\n            \/\/ \u652f\u6255\u3044\u51e6\u7406\n            var paymentResult = await _paymentProcessor.ProcessPaymentAsync(\n                new PaymentRequest\n                {\n                    OrderId = savedOrder.Id,\n                    Amount = savedOrder.TotalAmount,\n                    Currency = savedOrder.Currency\n                }\n            );\n\n            if (paymentResult.Success)\n            {\n                \/\/ \u6ce8\u6587\u30b9\u30c6\u30fc\u30bf\u30b9\u306e\u66f4\u65b0\n                savedOrder.Status = OrderStatus.Paid;\n                await _orderRepository.UpdateAsync(savedOrder);\n\n                \/\/ \u901a\u77e5\u306e\u9001\u4fe1\n                await _notificationService.SendOrderConfirmationAsync(savedOrder);\n\n                return new ProcessOrderResult\n                {\n                    Success = true,\n                    OrderId = savedOrder.Id\n                };\n            }\n            else\n            {\n                return new ProcessOrderResult\n                {\n                    Success = false,\n                    ErrorMessage = paymentResult.ErrorMessage\n                };\n            }\n        }\n        catch (Exception ex)\n        {\n            return new ProcessOrderResult\n            {\n                Success = false,\n                ErrorMessage = \"Order processing failed\"\n            };\n        }\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-25\">\u547d\u540d\u898f\u5247\u3068\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u898f\u7d04<\/h3>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-26\">1. <strong>\u547d\u540d\u898f\u5247\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u826f\u3044\u4f8b\uff1a\u660e\u78ba\u306a\u540d\u524d\u3068\u8cac\u52d9\npublic interface IOrderValidator\n{\n    Task&lt;ValidationResult&gt; ValidateAsync(Order order);\n}\n\npublic interface IProductCatalog\n{\n    Task&lt;Product&gt; GetProductAsync(int productId);\n    Task&lt;IEnumerable&lt;Product&gt;&gt; SearchProductsAsync(ProductSearchCriteria criteria);\n}\n\n\/\/ \u907f\u3051\u308b\u3079\u304d\u4f8b\uff1a\u66d6\u6627\u306a\u540d\u524d\u3068\u8cac\u52d9\npublic interface IProcessor  \/\/ \u66d6\u6627\u3059\u304e\u308b\n{\n    Task ProcessAsync(object data);  \/\/ \u6c4e\u7528\u7684\u3059\u304e\u308b\n}\n\npublic interface IHandler   \/\/ \u5177\u4f53\u6027\u306b\u6b20\u3051\u308b\n{\n    void Handle(string input);\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-27\">2. <strong>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u898f\u7d04<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u826f\u3044\u4f8b\uff1a\u4e00\u8cab\u6027\u306e\u3042\u308b\u62bd\u8c61\u5316\u30ec\u30d9\u30eb\npublic interface IDocumentProcessor\n{\n    Task&lt;ProcessingResult&gt; ProcessDocumentAsync(Document document);\n    Task&lt;ValidationResult&gt; ValidateDocumentAsync(Document document);\n    Task&lt;DocumentMetadata&gt; ExtractMetadataAsync(Document document);\n}\n\n\/\/ \u826f\u3044\u4f8b\uff1a\u30a4\u30d9\u30f3\u30c8\u3092\u542b\u3080\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\npublic interface IDocumentStorage\n{\n    Task&lt;Document&gt; SaveAsync(Document document);\n    Task&lt;Document&gt; GetByIdAsync(string documentId);\n\n    \/\/ \u30a4\u30d9\u30f3\u30c8\n    event EventHandler&lt;DocumentChangedEventArgs&gt; DocumentChanged;\n    event EventHandler&lt;DocumentDeletedEventArgs&gt; DocumentDeleted;\n}\n\n\/\/ \u907f\u3051\u308b\u3079\u304d\u4f8b\uff1a\u62bd\u8c61\u5316\u30ec\u30d9\u30eb\u304c\u4e0d\u7d71\u4e00\npublic interface IDocumentHandler\n{\n    Task&lt;Document&gt; ProcessDocumentAsync(Document document);\n    byte[] ConvertToPdf();  \/\/ \u5177\u4f53\u7684\u3059\u304e\u308b\n    void SaveToDatabase();  \/\/ \u30a4\u30f3\u30d5\u30e9\u30b9\u30c8\u30e9\u30af\u30c1\u30e3\u306e\u8cac\u52d9\u304c\u6df7\u5165\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-28\">\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30ac\u30a4\u30c9\u30e9\u30a4\u30f3<\/h3>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u8cac\u52d9<\/strong>\n<ul class=\"wp-block-list is-style-sango-list-yubi\">\n<li>\u5358\u4e00\u306e\u76ee\u7684\u306b\u7126\u70b9\u3092\u5f53\u3066\u308b<\/li>\n\n\n\n<li>\u30d3\u30b8\u30cd\u30b9\u30c9\u30e1\u30a4\u30f3\u306e\u7528\u8a9e\u3092\u4f7f\u7528<\/li>\n\n\n\n<li>\u5b9f\u88c5\u306e\u8a73\u7d30\u3092\u62bd\u8c61\u5316<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30e1\u30bd\u30c3\u30c9\u306e\u8a2d\u8a08<\/strong>\n<ul class=\"wp-block-list is-style-sango-list-yubi\">\n<li>\u975e\u540c\u671f\u30e1\u30bd\u30c3\u30c9\u306b\u306f\u5fc5\u305aAsync\u63a5\u5c3e\u8f9e\u3092\u4ed8\u3051\u308b<\/li>\n\n\n\n<li>\u30d1\u30e9\u30e1\u30fc\u30bf\u306f\u660e\u78ba\u3067\u578b\u5b89\u5168\u306a\u3082\u306e\u306b\u3059\u308b<\/li>\n\n\n\n<li>\u623b\u308a\u5024\u306e\u578b\u306f\u5177\u4f53\u7684\u306b\u6307\u5b9a<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0<\/strong>\n<ul class=\"wp-block-list is-style-sango-list-yubi\">\n<li>\u65e2\u5b58\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u5909\u66f4\u3057\u306a\u3044<\/li>\n\n\n\n<li>\u65b0\u6a5f\u80fd\u306f\u65b0\u3057\u3044\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3068\u3057\u3066\u8ffd\u52a0<\/li>\n\n\n\n<li>\u5f8c\u65b9\u4e92\u63db\u6027\u3092\u7dad\u6301<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u308c\u3089\u306e\u539f\u5247\u3068\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\u3092\u9069\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u4fdd\u5b88\u6027\u304c\u9ad8\u304f\u3001\u62e1\u5f35\u3057\u3084\u3059\u3044\u30b7\u30b9\u30c6\u30e0\u3092\u8a2d\u8a08\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u539f\u5247\u3092\u6d3b\u7528\u3057\u305f\u5b9f\u8df5\u7684\u306a\u5b9f\u88c5\u30c6\u30af\u30cb\u30c3\u30af\u306b\u3064\u3044\u3066\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-29\">\u5b9f\u8df5\u7684\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u6d3b\u7528\u30c6\u30af\u30cb\u30c3\u30af<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u5b9f\u52d9\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u6d3b\u7528\u306b\u3064\u3044\u3066\u3001\u5177\u4f53\u7684\u306a\u5b9f\u88c5\u4f8b\u3068\u3068\u3082\u306b\u89e3\u8aac\u3057\u307e\u3059\u3002<br>\u4f9d\u5b58\u6027\u6ce8\u5165\uff08DI\uff09\u3001\u30c6\u30b9\u30c8\u3001\u30d7\u30e9\u30b0\u30a4\u30f3\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306a\u3069\u3001\u5b9f\u8df5\u7684\u306a\u30c6\u30af\u30cb\u30c3\u30af\u3092\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-30\">\u4f9d\u5b58\u6027\u6ce8\u5165(DI)\u306b\u304a\u3051\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5f79\u5272<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u4f9d\u5b58\u6027\u6ce8\u5165\u306f\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u9593\u306e\u7d50\u5408\u5ea6\u3092\u4e0b\u3052\u3001\u30c6\u30b9\u30c8\u5bb9\u6613\u6027\u3092\u9ad8\u3081\u308b\u305f\u3081\u306e\u91cd\u8981\u306a\u624b\u6cd5\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-31\">1. <strong>DI\u30b3\u30f3\u30c6\u30ca\u306e\u8a2d\u5b9a\u3068\u767b\u9332<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">using Microsoft.Extensions.DependencyInjection;\nusing Microsoft.Extensions.Logging;\n\npublic class Startup\n{\n    public void ConfigureServices(IServiceCollection services)\n    {\n        \/\/ \u30c8\u30e9\u30f3\u30b8\u30a7\u30f3\u30c8\u30b5\u30fc\u30d3\u30b9\uff08\u90fd\u5ea6\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u751f\u6210\uff09\n        services.AddTransient&lt;IOrderValidator, OrderValidator&gt;();\n\n        \/\/ \u30b9\u30b3\u30fc\u30d7\u4ed8\u304d\u30b5\u30fc\u30d3\u30b9\uff08\u30ea\u30af\u30a8\u30b9\u30c8\u30b9\u30b3\u30fc\u30d7\u5185\u3067\u5171\u6709\uff09\n        services.AddScoped&lt;IOrderRepository, SqlOrderRepository&gt;();\n        services.AddScoped&lt;ICustomerRepository, SqlCustomerRepository&gt;();\n\n        \/\/ \u30b7\u30f3\u30b0\u30eb\u30c8\u30f3\u30b5\u30fc\u30d3\u30b9\uff08\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u5168\u4f53\u3067\u5171\u6709\uff09\n        services.AddSingleton&lt;ICacheService, RedisCacheService&gt;();\n\n        \/\/ \u6761\u4ef6\u4ed8\u304d\u767b\u9332\n        services.AddScoped&lt;IPaymentProcessor&gt;(sp =&gt;\n        {\n            var configuration = sp.GetRequiredService&lt;IConfiguration&gt;();\n            return configuration[\"PaymentProvider\"] switch\n            {\n                \"Stripe\" =&gt; new StripePaymentProcessor(configuration),\n                \"PayPal\" =&gt; new PayPalPaymentProcessor(configuration),\n                _ =&gt; throw new InvalidOperationException(\"Invalid payment provider\")\n            };\n        });\n\n        \/\/ \u30c7\u30b3\u30ec\u30fc\u30bf\u30fc\u30d1\u30bf\u30fc\u30f3\u306e\u767b\u9332\n        services.AddScoped&lt;IOrderProcessor, OrderProcessor&gt;();\n        services.Decorate&lt;IOrderProcessor, OrderProcessorWithLogging&gt;();\n        services.Decorate&lt;IOrderProcessor, OrderProcessorWithValidation&gt;();\n    }\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-32\">2. <strong>DI\u3092\u6d3b\u7528\u3057\u305f\u30b5\u30fc\u30d3\u30b9\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IOrderProcessor\n{\n    Task&lt;OrderResult&gt; ProcessOrderAsync(Order order);\n}\n\npublic class OrderProcessor : IOrderProcessor\n{\n    private readonly IOrderRepository _orderRepository;\n    private readonly IPaymentProcessor _paymentProcessor;\n    private readonly INotificationService _notificationService;\n    private readonly ILogger&lt;OrderProcessor&gt; _logger;\n\n    public OrderProcessor(\n        IOrderRepository orderRepository,\n        IPaymentProcessor paymentProcessor,\n        INotificationService notificationService,\n        ILogger&lt;OrderProcessor&gt; logger)\n    {\n        _orderRepository = orderRepository;\n        _paymentProcessor = paymentProcessor;\n        _notificationService = notificationService;\n        _logger = logger;\n    }\n\n    public async Task&lt;OrderResult&gt; ProcessOrderAsync(Order order)\n    {\n        try\n        {\n            _logger.LogInformation(\"Processing order {OrderId}\", order.Id);\n\n            \/\/ \u6ce8\u6587\u306e\u4fdd\u5b58\n            await _orderRepository.SaveAsync(order);\n\n            \/\/ \u652f\u6255\u3044\u51e6\u7406\n            var paymentResult = await _paymentProcessor.ProcessPaymentAsync(\n                new PaymentRequest(order));\n\n            if (paymentResult.Success)\n            {\n                order.Status = OrderStatus.Paid;\n                await _orderRepository.UpdateAsync(order);\n\n                \/\/ \u975e\u540c\u671f\u3067\u901a\u77e5\u3092\u9001\u4fe1\n                _ = _notificationService.SendOrderConfirmationAsync(order);\n\n                return OrderResult.Success(order.Id);\n            }\n\n            return OrderResult.Failure(paymentResult.ErrorMessage);\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Failed to process order {OrderId}\", order.Id);\n            return OrderResult.Failure(\"Order processing failed\");\n        }\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-33\">\u30e2\u30c3\u30af\u3092\u4f7f\u7528\u3057\u305f\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8\u306e\u5b9f\u88c5<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u4f9d\u5b58\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u30e2\u30c3\u30af\u5316\u304c\u5bb9\u6613\u306b\u306a\u308a\u3001\u52b9\u679c\u7684\u306a\u30e6\u30cb\u30c3\u30c8\u30c6\u30b9\u30c8\u304c\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-34\">1. <strong>xUnit \u3068 Moq \u3092\u4f7f\u7528\u3057\u305f\u30c6\u30b9\u30c8\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public class OrderProcessorTests\n{\n    private readonly Mock&lt;IOrderRepository&gt; _orderRepositoryMock;\n    private readonly Mock&lt;IPaymentProcessor&gt; _paymentProcessorMock;\n    private readonly Mock&lt;INotificationService&gt; _notificationServiceMock;\n    private readonly Mock&lt;ILogger&lt;OrderProcessor&gt;&gt; _loggerMock;\n    private readonly OrderProcessor _processor;\n\n    public OrderProcessorTests()\n    {\n        _orderRepositoryMock = new Mock&lt;IOrderRepository&gt;();\n        _paymentProcessorMock = new Mock&lt;IPaymentProcessor&gt;();\n        _notificationServiceMock = new Mock&lt;INotificationService&gt;();\n        _loggerMock = new Mock&lt;ILogger&lt;OrderProcessor&gt;&gt;();\n\n        _processor = new OrderProcessor(\n            _orderRepositoryMock.Object,\n            _paymentProcessorMock.Object,\n            _notificationServiceMock.Object,\n            _loggerMock.Object);\n    }\n\n    [Fact]\n    public async Task ProcessOrder_WhenPaymentSucceeds_UpdatesOrderAndSendsNotification()\n    {\n        \/\/ Arrange\n        var order = new Order { Id = 1, Status = OrderStatus.Created };\n        var paymentRequest = new PaymentRequest(order);\n        var paymentResult = PaymentResult.Success();\n\n        _paymentProcessorMock\n            .Setup(p =&gt; p.ProcessPaymentAsync(It.IsAny&lt;PaymentRequest&gt;()))\n            .ReturnsAsync(paymentResult);\n\n        \/\/ Act\n        var result = await _processor.ProcessOrderAsync(order);\n\n        \/\/ Assert\n        Assert.True(result.Success);\n        Assert.Equal(order.Id, result.OrderId);\n\n        _orderRepositoryMock.Verify(\n            r =&gt; r.UpdateAsync(It.Is&lt;Order&gt;(o =&gt; \n                o.Id == order.Id &amp;&amp; \n                o.Status == OrderStatus.Paid)),\n            Times.Once);\n\n        _notificationServiceMock.Verify(\n            n =&gt; n.SendOrderConfirmationAsync(order),\n            Times.Once);\n    }\n\n    [Fact]\n    public async Task ProcessOrder_WhenPaymentFails_DoesNotUpdateOrder()\n    {\n        \/\/ Arrange\n        var order = new Order { Id = 1, Status = OrderStatus.Created };\n        var errorMessage = \"Insufficient funds\";\n\n        _paymentProcessorMock\n            .Setup(p =&gt; p.ProcessPaymentAsync(It.IsAny&lt;PaymentRequest&gt;()))\n            .ReturnsAsync(PaymentResult.Failure(errorMessage));\n\n        \/\/ Act\n        var result = await _processor.ProcessOrderAsync(order);\n\n        \/\/ Assert\n        Assert.False(result.Success);\n        Assert.Equal(errorMessage, result.ErrorMessage);\n\n        _orderRepositoryMock.Verify(\n            r =&gt; r.UpdateAsync(It.IsAny&lt;Order&gt;()),\n            Times.Never);\n\n        _notificationServiceMock.Verify(\n            n =&gt; n.SendOrderConfirmationAsync(It.IsAny&lt;Order&gt;()),\n            Times.Never);\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-35\">\u30d7\u30e9\u30b0\u30a4\u30f3\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306e\u5b9f\u73fe\u65b9\u6cd5<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u6d3b\u7528\u3059\u308b\u3053\u3068\u3067\u3001\u67d4\u8edf\u306a\u30d7\u30e9\u30b0\u30a4\u30f3\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-36\">1. <strong>\u30d7\u30e9\u30b0\u30a4\u30f3\u30b7\u30b9\u30c6\u30e0\u306e\u57fa\u672c\u69cb\u9020<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IPlugin\n{\n    string Name { get; }\n    string Version { get; }\n    Task InitializeAsync();\n    Task ExecuteAsync();\n    Task ShutdownAsync();\n}\n\npublic interface IPluginMetadata\n{\n    string Name { get; }\n    string Version { get; }\n    string Description { get; }\n    IReadOnlyCollection&lt;string&gt; Dependencies { get; }\n}\n\npublic interface IPluginManager\n{\n    Task LoadPluginAsync(string pluginPath);\n    Task UnloadPluginAsync(string pluginName);\n    Task&lt;IPlugin&gt; GetPluginAsync(string name);\n    IReadOnlyCollection&lt;IPluginMetadata&gt; GetLoadedPlugins();\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-37\">2. <strong>\u30d7\u30e9\u30b0\u30a4\u30f3\u30de\u30cd\u30fc\u30b8\u30e3\u30fc\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public class PluginManager : IPluginManager\n{\n    private readonly Dictionary&lt;string, IPlugin&gt; _plugins = new();\n    private readonly ILogger&lt;PluginManager&gt; _logger;\n    private readonly IConfiguration _configuration;\n\n    public PluginManager(\n        ILogger&lt;PluginManager&gt; logger,\n        IConfiguration configuration)\n    {\n        _logger = logger;\n        _configuration = configuration;\n    }\n\n    public async Task LoadPluginAsync(string pluginPath)\n    {\n        try\n        {\n            \/\/ \u30a2\u30bb\u30f3\u30d6\u30ea\u306e\u30ed\u30fc\u30c9\n            var assembly = Assembly.LoadFrom(pluginPath);\n\n            \/\/ \u30d7\u30e9\u30b0\u30a4\u30f3\u578b\u306e\u691c\u7d22\n            var pluginTypes = assembly.GetTypes()\n                .Where(t =&gt; typeof(IPlugin).IsAssignableFrom(t) &amp;&amp; !t.IsInterface);\n\n            foreach (var pluginType in pluginTypes)\n            {\n                \/\/ \u30d7\u30e9\u30b0\u30a4\u30f3\u306e\u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u5316\n                if (Activator.CreateInstance(pluginType) is IPlugin plugin)\n                {\n                    await InitializePluginAsync(plugin);\n                    _plugins[plugin.Name] = plugin;\n\n                    _logger.LogInformation(\n                        \"Loaded plugin: {Name} v{Version}\",\n                        plugin.Name,\n                        plugin.Version);\n                }\n            }\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Failed to load plugin from {Path}\", pluginPath);\n            throw;\n        }\n    }\n\n    private async Task InitializePluginAsync(IPlugin plugin)\n    {\n        try\n        {\n            await plugin.InitializeAsync();\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Failed to initialize plugin {Name}\", plugin.Name);\n            throw;\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u308c\u3089\u306e\u30c6\u30af\u30cb\u30c3\u30af\u3092\u9069\u5207\u306b\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u4fdd\u5b88\u6027\u304c\u9ad8\u304f\u3001\u62e1\u5f35\u6027\u306e\u3042\u308b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u3092\u69cb\u7bc9\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3088\u304f\u4f7f\u7528\u3055\u308c\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30d1\u30bf\u30fc\u30f3\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-38\">\u3088\u304f\u3042\u308b\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5b9f\u88c5\u30d1\u30bf\u30fc\u30f3<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u5b9f\u52d9\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u6d3b\u7528\u3067\u306f\u3001\u78ba\u7acb\u3055\u308c\u305f\u30c7\u30b6\u30a4\u30f3\u30d1\u30bf\u30fc\u30f3\u3092\u9069\u5207\u306b\u9069\u7528\u3059\u308b\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002<br>\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u4e00\u822c\u7684\u306a\u30c7\u30b6\u30a4\u30f3\u30d1\u30bf\u30fc\u30f3\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u4f7f\u7528\u3057\u305f\u5b9f\u88c5\u65b9\u6cd5\u3092\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-39\">\u30ea\u30dd\u30b8\u30c8\u30ea\u30d1\u30bf\u30fc\u30f3\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u6d3b\u7528<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30ea\u30dd\u30b8\u30c8\u30ea\u30d1\u30bf\u30fc\u30f3\u306f\u3001\u30c7\u30fc\u30bf\u30a2\u30af\u30bb\u30b9\u5c64\u3092\u62bd\u8c61\u5316\u3057\u3001\u30d3\u30b8\u30cd\u30b9\u30ed\u30b8\u30c3\u30af\u3092\u5206\u96e2\u3059\u308b\u305f\u3081\u306b\u5e83\u304f\u4f7f\u7528\u3055\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-40\">1. <strong>\u30b8\u30a7\u30cd\u30ea\u30c3\u30af\u30ea\u30dd\u30b8\u30c8\u30ea\u30d1\u30bf\u30fc\u30f3\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IRepository&lt;TEntity, TKey&gt; where TEntity : class\n{\n    Task&lt;TEntity&gt; GetByIdAsync(TKey id);\n    Task&lt;IReadOnlyList&lt;TEntity&gt;&gt; GetAllAsync();\n    Task&lt;IReadOnlyList&lt;TEntity&gt;&gt; FindAsync(Expression&lt;Func&lt;TEntity, bool&gt;&gt; predicate);\n    Task&lt;TEntity&gt; AddAsync(TEntity entity);\n    Task UpdateAsync(TEntity entity);\n    Task DeleteAsync(TKey id);\n}\n\npublic interface IUnitOfWork : IDisposable\n{\n    Task&lt;int&gt; SaveChangesAsync();\n    Task BeginTransactionAsync();\n    Task CommitAsync();\n    Task RollbackAsync();\n}\n\n\/\/ \u5177\u4f53\u7684\u306a\u30ea\u30dd\u30b8\u30c8\u30ea\u306e\u5b9f\u88c5\npublic class EntityFrameworkRepository&lt;TEntity, TKey&gt; : IRepository&lt;TEntity, TKey&gt;\n    where TEntity : class\n{\n    protected readonly DbContext _context;\n    protected readonly DbSet&lt;TEntity&gt; _dbSet;\n    private readonly ILogger&lt;EntityFrameworkRepository&lt;TEntity, TKey&gt;&gt; _logger;\n\n    public EntityFrameworkRepository(\n        DbContext context,\n        ILogger&lt;EntityFrameworkRepository&lt;TEntity, TKey&gt;&gt; logger)\n    {\n        _context = context;\n        _dbSet = context.Set&lt;TEntity&gt;();\n        _logger = logger;\n    }\n\n    public virtual async Task&lt;TEntity&gt; GetByIdAsync(TKey id)\n    {\n        try\n        {\n            return await _dbSet.FindAsync(id);\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error getting entity with ID {Id}\", id);\n            throw;\n        }\n    }\n\n    public virtual async Task&lt;IReadOnlyList&lt;TEntity&gt;&gt; FindAsync(\n        Expression&lt;Func&lt;TEntity, bool&gt;&gt; predicate)\n    {\n        try\n        {\n            return await _dbSet.Where(predicate).ToListAsync();\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error finding entities with predicate\");\n            throw;\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}\n\n\/\/ Unit of Work\u306e\u5b9f\u88c5\npublic class EntityFrameworkUnitOfWork : IUnitOfWork\n{\n    private readonly DbContext _context;\n    private IDbContextTransaction _transaction;\n\n    public EntityFrameworkUnitOfWork(DbContext context)\n    {\n        _context = context;\n    }\n\n    public async Task BeginTransactionAsync()\n    {\n        _transaction = await _context.Database.BeginTransactionAsync();\n    }\n\n    public async Task CommitAsync()\n    {\n        try\n        {\n            await _context.SaveChangesAsync();\n            await _transaction?.CommitAsync();\n        }\n        catch\n        {\n            await RollbackAsync();\n            throw;\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-41\">Strategy\u30d1\u30bf\u30fc\u30f3\u306e\u5b9f\u88c5\u4f8b<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Strategy\u30d1\u30bf\u30fc\u30f3\u306f\u3001\u30a2\u30eb\u30b4\u30ea\u30ba\u30e0\u306e\u5207\u308a\u66ff\u3048\u3092\u5bb9\u6613\u306b\u3059\u308b\u8a2d\u8a08\u30d1\u30bf\u30fc\u30f3\u3067\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-42\">1. <strong>\u5272\u5f15\u8a08\u7b97\u306eStrategy\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IDiscountStrategy\n{\n    Task&lt;decimal&gt; CalculateDiscountAsync(Order order);\n    bool IsApplicable(Order order);\n}\n\npublic class PercentageDiscountStrategy : IDiscountStrategy\n{\n    private readonly decimal _percentage;\n    private readonly decimal _minimumOrderAmount;\n\n    public PercentageDiscountStrategy(decimal percentage, decimal minimumOrderAmount)\n    {\n        _percentage = percentage;\n        _minimumOrderAmount = minimumOrderAmount;\n    }\n\n    public Task&lt;decimal&gt; CalculateDiscountAsync(Order order)\n    {\n        return Task.FromResult(order.TotalAmount * (_percentage \/ 100));\n    }\n\n    public bool IsApplicable(Order order)\n    {\n        return order.TotalAmount &gt;= _minimumOrderAmount;\n    }\n}\n\npublic class BulkDiscountStrategy : IDiscountStrategy\n{\n    private readonly int _minimumItems;\n    private readonly decimal _discountPerItem;\n\n    public BulkDiscountStrategy(int minimumItems, decimal discountPerItem)\n    {\n        _minimumItems = minimumItems;\n        _discountPerItem = discountPerItem;\n    }\n\n    public Task&lt;decimal&gt; CalculateDiscountAsync(Order order)\n    {\n        return Task.FromResult(order.ItemCount * _discountPerItem);\n    }\n\n    public bool IsApplicable(Order order)\n    {\n        return order.ItemCount &gt;= _minimumItems;\n    }\n}\n\n\/\/ Strategy\u306e\u4f7f\u7528\npublic class OrderProcessor\n{\n    private readonly IEnumerable&lt;IDiscountStrategy&gt; _discountStrategies;\n    private readonly ILogger&lt;OrderProcessor&gt; _logger;\n\n    public OrderProcessor(\n        IEnumerable&lt;IDiscountStrategy&gt; discountStrategies,\n        ILogger&lt;OrderProcessor&gt; logger)\n    {\n        _discountStrategies = discountStrategies;\n        _logger = logger;\n    }\n\n    public async Task&lt;decimal&gt; CalculateFinalAmountAsync(Order order)\n    {\n        decimal totalDiscount = 0;\n\n        foreach (var strategy in _discountStrategies)\n        {\n            if (strategy.IsApplicable(order))\n            {\n                var discount = await strategy.CalculateDiscountAsync(order);\n                totalDiscount += discount;\n\n                _logger.LogInformation(\n                    \"Applied discount of {Discount} using {Strategy}\",\n                    discount,\n                    strategy.GetType().Name);\n            }\n        }\n\n        return order.TotalAmount - totalDiscount;\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-43\">Observer\u30d1\u30bf\u30fc\u30f3\u3067\u306e\u30a4\u30d9\u30f3\u30c8\u51e6\u7406<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">Observer\u30d1\u30bf\u30fc\u30f3\u306f\u3001\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u9593\u306e1\u5bfe\u591a\u306e\u4f9d\u5b58\u95a2\u4fc2\u3092\u5b9a\u7fa9\u3059\u308b\u306e\u306b\u9069\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-44\">1. <strong>\u30a4\u30d9\u30f3\u30c8\u30d9\u30fc\u30b9\u306e\u6ce8\u6587\u51e6\u7406\u30b7\u30b9\u30c6\u30e0<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IOrderEventObserver\n{\n    Task OnOrderCreatedAsync(OrderCreatedEvent @event);\n    Task OnOrderUpdatedAsync(OrderUpdatedEvent @event);\n    Task OnOrderCancelledAsync(OrderCancelledEvent @event);\n}\n\npublic class OrderEvent\n{\n    public int OrderId { get; }\n    public DateTime Timestamp { get; }\n\n    protected OrderEvent(int orderId)\n    {\n        OrderId = orderId;\n        Timestamp = DateTime.UtcNow;\n    }\n}\n\npublic class OrderCreatedEvent : OrderEvent\n{\n    public Order Order { get; }\n\n    public OrderCreatedEvent(int orderId, Order order) : base(orderId)\n    {\n        Order = order;\n    }\n}\n\npublic class EmailNotificationObserver : IOrderEventObserver\n{\n    private readonly IEmailService _emailService;\n    private readonly ILogger&lt;EmailNotificationObserver&gt; _logger;\n\n    public EmailNotificationObserver(\n        IEmailService emailService,\n        ILogger&lt;EmailNotificationObserver&gt; logger)\n    {\n        _emailService = emailService;\n        _logger = logger;\n    }\n\n    public async Task OnOrderCreatedAsync(OrderCreatedEvent @event)\n    {\n        try\n        {\n            await _emailService.SendEmailAsync(\n                @event.Order.CustomerEmail,\n                \"Order Confirmation\",\n                $\"Your order {@event.OrderId} has been received.\");\n\n            _logger.LogInformation(\n                \"Sent order confirmation email for order {@OrderId}\",\n                @event.OrderId);\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Failed to send order confirmation email\");\n            throw;\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u5b9f\u88c5\n}\n\n\/\/ \u30a4\u30d9\u30f3\u30c8\u30c7\u30a3\u30b9\u30d1\u30c3\u30c1\u30e3\u30fc\npublic class OrderEventDispatcher\n{\n    private readonly IList&lt;IOrderEventObserver&gt; _observers = new List&lt;IOrderEventObserver&gt;();\n    private readonly ILogger&lt;OrderEventDispatcher&gt; _logger;\n\n    public OrderEventDispatcher(ILogger&lt;OrderEventDispatcher&gt; logger)\n    {\n        _logger = logger;\n    }\n\n    public void RegisterObserver(IOrderEventObserver observer)\n    {\n        _observers.Add(observer);\n    }\n\n    public async Task DispatchOrderCreatedAsync(OrderCreatedEvent @event)\n    {\n        foreach (var observer in _observers)\n        {\n            try\n            {\n                await observer.OnOrderCreatedAsync(@event);\n            }\n            catch (Exception ex)\n            {\n                _logger.LogError(ex,\n                    \"Observer {ObserverType} failed to handle OrderCreatedEvent\",\n                    observer.GetType().Name);\n            }\n        }\n    }\n}<\/pre>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u308c\u3089\u306e\u30d1\u30bf\u30fc\u30f3\u3092\u9069\u5207\u306b\u7d44\u307f\u5408\u308f\u305b\u308b\u3053\u3068\u3067\u3001\u4fdd\u5b88\u6027\u304c\u9ad8\u304f\u3001\u62e1\u5f35\u6027\u306e\u3042\u308b\u30b7\u30b9\u30c6\u30e0\u3092\u69cb\u7bc9\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u6ce8\u610f\u70b9\u306b\u3064\u3044\u3066\u8a73\u3057\u304f\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-45\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u4f7f\u7528\u3059\u308b\u969b\u306e\u6ce8\u610f\u70b9<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u5f37\u529b\u306a\u8a2d\u8a08\u30c4\u30fc\u30eb\u3067\u3059\u304c\u3001\u9069\u5207\u306b\u4f7f\u7528\u3057\u306a\u3044\u3068\u69d8\u3005\u306a\u554f\u984c\u3092\u5f15\u304d\u8d77\u3053\u3059\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u5b9f\u52d9\u3067\u306e\u7d4c\u9a13\u306b\u57fa\u3065\u304f\u5177\u4f53\u7684\u306a\u6ce8\u610f\u70b9\u3068\u5bfe\u7b56\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-46\">\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3078\u306e\u5f71\u97ff\u3068\u6700\u9069\u5316<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u4f7f\u7528\u306f\u3001\u308f\u305a\u304b\u306a\u304c\u3089\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u30aa\u30fc\u30d0\u30fc\u30d8\u30c3\u30c9\u3092\u5f15\u304d\u8d77\u3053\u3059\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-47\">1. <strong>\u30e1\u30bd\u30c3\u30c9\u547c\u3073\u51fa\u3057\u306e\u30aa\u30fc\u30d0\u30fc\u30d8\u30c3\u30c9\u6e2c\u5b9a<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public class PerformanceTest\n{\n    private const int IterationCount = 10_000_000;\n    private readonly ILogger&lt;PerformanceTest&gt; _logger;\n\n    public PerformanceTest(ILogger&lt;PerformanceTest&gt; logger)\n    {\n        _logger = logger;\n    }\n\n    public void MeasureCallOverhead()\n    {\n        \/\/ \u76f4\u63a5\u547c\u3073\u51fa\u3057\n        var directImpl = new DataProcessor();\n        var sw1 = Stopwatch.StartNew();\n\n        for (int i = 0; i &lt; IterationCount; i++)\n        {\n            directImpl.ProcessData(\"test\");\n        }\n\n        sw1.Stop();\n\n        \/\/ \u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u7d4c\u7531\u306e\u547c\u3073\u51fa\u3057\n        IDataProcessor interfaceImpl = directImpl;\n        var sw2 = Stopwatch.StartNew();\n\n        for (int i = 0; i &lt; IterationCount; i++)\n        {\n            interfaceImpl.ProcessData(\"test\");\n        }\n\n        sw2.Stop();\n\n        _logger.LogInformation(\n            \"Performance comparison:\\n\" +\n            \"Direct calls: {DirectTime}ms\\n\" +\n            \"Interface calls: {InterfaceTime}ms\\n\" +\n            \"Overhead per call: {Overhead}ns\",\n            sw1.ElapsedMilliseconds,\n            sw2.ElapsedMilliseconds,\n            (sw2.ElapsedTicks - sw1.ElapsedTicks) * 1000.0 \/ IterationCount);\n    }\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-48\">2. <strong>\u30ad\u30e3\u30c3\u30b7\u30e5\u3092\u6d3b\u7528\u3057\u305f\u6700\u9069\u5316\u4f8b<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface ICacheableRepository&lt;TEntity, TKey&gt;\n    where TEntity : class\n{\n    Task&lt;TEntity&gt; GetByIdAsync(TKey id);\n    Task&lt;IReadOnlyList&lt;TEntity&gt;&gt; GetAllAsync();\n    Task UpdateAsync(TEntity entity);\n    Task InvalidateCacheAsync(TKey id);\n}\n\npublic class CachedRepository&lt;TEntity, TKey&gt; : ICacheableRepository&lt;TEntity, TKey&gt;\n    where TEntity : class\n{\n    private readonly IRepository&lt;TEntity, TKey&gt; _repository;\n    private readonly IDistributedCache _cache;\n    private readonly ILogger&lt;CachedRepository&lt;TEntity, TKey&gt;&gt; _logger;\n    private readonly string _cachePrefix;\n    private readonly TimeSpan _cacheExpiration;\n\n    public CachedRepository(\n        IRepository&lt;TEntity, TKey&gt; repository,\n        IDistributedCache cache,\n        ILogger&lt;CachedRepository&lt;TEntity, TKey&gt;&gt; logger,\n        string cachePrefix = \"\",\n        TimeSpan? cacheExpiration = null)\n    {\n        _repository = repository;\n        _cache = cache;\n        _logger = logger;\n        _cachePrefix = cachePrefix;\n        _cacheExpiration = cacheExpiration ?? TimeSpan.FromMinutes(10);\n    }\n\n    public async Task&lt;TEntity&gt; GetByIdAsync(TKey id)\n    {\n        var cacheKey = $\"{_cachePrefix}{typeof(TEntity).Name}_{id}\";\n\n        try\n        {\n            \/\/ \u30ad\u30e3\u30c3\u30b7\u30e5\u304b\u3089\u306e\u53d6\u5f97\u3092\u8a66\u307f\u308b\n            var cachedData = await _cache.GetAsync(cacheKey);\n            if (cachedData != null)\n            {\n                _logger.LogDebug(\"Cache hit for {Key}\", cacheKey);\n                return JsonSerializer.Deserialize&lt;TEntity&gt;(cachedData);\n            }\n\n            \/\/ \u30c7\u30fc\u30bf\u30d9\u30fc\u30b9\u304b\u3089\u53d6\u5f97\n            var entity = await _repository.GetByIdAsync(id);\n            if (entity != null)\n            {\n                \/\/ \u30ad\u30e3\u30c3\u30b7\u30e5\u306b\u4fdd\u5b58\n                var options = new DistributedCacheEntryOptions\n                {\n                    AbsoluteExpirationRelativeToNow = _cacheExpiration,\n                    SlidingExpiration = TimeSpan.FromMinutes(2)\n                };\n\n                await _cache.SetAsync(\n                    cacheKey,\n                    JsonSerializer.SerializeToUtf8Bytes(entity),\n                    options);\n            }\n\n            return entity;\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error accessing cache for {Key}\", cacheKey);\n            \/\/ \u30ad\u30e3\u30c3\u30b7\u30e5\u30a8\u30e9\u30fc\u6642\u306f\u30ea\u30dd\u30b8\u30c8\u30ea\u304b\u3089\u76f4\u63a5\u53d6\u5f97\n            return await _repository.GetByIdAsync(id);\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-49\">\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\u3068\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u9032\u5316<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u5909\u66f4\u306f\u65e2\u5b58\u306e\u30b3\u30fc\u30c9\u306b\u91cd\u5927\u306a\u5f71\u97ff\u3092\u4e0e\u3048\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-50\">1. <strong>\u30d0\u30fc\u30b8\u30e7\u30cb\u30f3\u30b0\u306e\u6226\u7565\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u57fa\u672c\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\uff08V1\uff09\npublic interface IUserService\n{\n    Task&lt;User&gt; GetUserAsync(int id);\n    Task&lt;User&gt; CreateUserAsync(UserCreateRequest request);\n    Task UpdateUserAsync(User user);\n}\n\n\/\/ \u62e1\u5f35\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\uff08V2\uff09\npublic interface IUserServiceV2 : IUserService\n{\n    Task&lt;UserDetails&gt; GetUserDetailsAsync(int id);\n    Task&lt;IReadOnlyList&lt;User&gt;&gt; SearchUsersAsync(UserSearchCriteria criteria);\n}\n\n\/\/ \u3055\u3089\u306a\u308b\u62e1\u5f35\uff08V3\uff09\npublic interface IUserServiceV3 : IUserServiceV2\n{\n    Task&lt;User&gt; CreateUserWithRolesAsync(UserCreateRequest request, IEnumerable&lt;string&gt; roles);\n    Task&lt;bool&gt; ValidateUserAsync(int id);\n}\n\n\/\/ \u6700\u65b0\u6a5f\u80fd\u3092\u5168\u3066\u5b9f\u88c5\u3057\u305f\u30b5\u30fc\u30d3\u30b9\npublic class ModernUserService : IUserServiceV3\n{\n    private readonly IUserRepository _repository;\n    private readonly ILogger&lt;ModernUserService&gt; _logger;\n\n    public ModernUserService(\n        IUserRepository repository,\n        ILogger&lt;ModernUserService&gt; logger)\n    {\n        _repository = repository;\n        _logger = logger;\n    }\n\n    \/\/ V1\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n    public async Task&lt;User&gt; GetUserAsync(int id)\n    {\n        try\n        {\n            return await _repository.GetByIdAsync(id);\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error getting user {Id}\", id);\n            throw;\n        }\n    }\n\n    \/\/ V2\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n    public async Task&lt;UserDetails&gt; GetUserDetailsAsync(int id)\n    {\n        var user = await GetUserAsync(id);\n        if (user == null) return null;\n\n        return await _repository.GetUserDetailsAsync(id);\n    }\n\n    \/\/ V3\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n    public async Task&lt;User&gt; CreateUserWithRolesAsync(\n        UserCreateRequest request,\n        IEnumerable&lt;string&gt; roles)\n    {\n        var user = await CreateUserAsync(request);\n        await _repository.AssignRolesAsync(user.Id, roles);\n        return user;\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-51\">\u904e\u5270\u306a\u62bd\u8c61\u5316\u3092\u907f\u3051\u308b\u305f\u3081\u306e\u6307\u91dd<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u904e\u5270\u306a\u62bd\u8c61\u5316\u306f\u3001\u30b3\u30fc\u30c9\u306e\u8907\u96d1\u6027\u3092\u4e0d\u5fc5\u8981\u306b\u5897\u52a0\u3055\u305b\u308b\u53ef\u80fd\u6027\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-52\">1. <strong>\u907f\u3051\u308b\u3079\u304d\u5b9f\u88c5\u30d1\u30bf\u30fc\u30f3<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u904e\u5270\u306a\u62bd\u8c61\u5316\u306e\u4f8b\npublic interface IStringManipulator\n{\n    string Manipulate(string input);\n}\n\npublic interface IStringValidator\n{\n    bool Validate(string input);\n}\n\npublic interface IStringFormatter\n{\n    string Format(string input);\n}\n\npublic class StringProcessor : IStringManipulator, IStringValidator, IStringFormatter\n{\n    public string Manipulate(string input) =&gt; input.Trim();\n    public bool Validate(string input) =&gt; !string.IsNullOrEmpty(input);\n    public string Format(string input) =&gt; input.ToUpper();\n}\n\n\/\/ \u6539\u5584\u3055\u308c\u305f\u5b9f\u88c5\npublic interface ITextProcessor\n{\n    string Process(string text);\n    bool IsValid(string text);\n}\n\npublic class TextProcessor : ITextProcessor\n{\n    public string Process(string text)\n    {\n        if (!IsValid(text)) throw new ArgumentException(\"Invalid text\");\n        return text.Trim().ToUpper();\n    }\n\n    public bool IsValid(string text) =&gt; !string.IsNullOrEmpty(text);\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-53\">2. <strong>\u9069\u5207\u306a\u62bd\u8c61\u5316\u30ec\u30d9\u30eb\u306e\u4f8b<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">\/\/ \u660e\u78ba\u306a\u8cac\u52d9\u3092\u6301\u3064\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\npublic interface IOrderValidator\n{\n    Task&lt;ValidationResult&gt; ValidateOrderAsync(Order order);\n    Task&lt;ValidationResult&gt; ValidateShippingDetailsAsync(ShippingDetails details);\n}\n\npublic interface IOrderProcessor\n{\n    Task&lt;OrderResult&gt; ProcessOrderAsync(Order order);\n    Task&lt;OrderStatus&gt; GetOrderStatusAsync(int orderId);\n}\n\n\/\/ \u5b9f\u88c5\u30af\u30e9\u30b9\npublic class OrderValidator : IOrderValidator\n{\n    private readonly IEnumerable&lt;IValidationRule&lt;Order&gt;&gt; _orderRules;\n    private readonly IEnumerable&lt;IValidationRule&lt;ShippingDetails&gt;&gt; _shippingRules;\n    private readonly ILogger&lt;OrderValidator&gt; _logger;\n\n    public OrderValidator(\n        IEnumerable&lt;IValidationRule&lt;Order&gt;&gt; orderRules,\n        IEnumerable&lt;IValidationRule&lt;ShippingDetails&gt;&gt; shippingRules,\n        ILogger&lt;OrderValidator&gt; logger)\n    {\n        _orderRules = orderRules;\n        _shippingRules = shippingRules;\n        _logger = logger;\n    }\n\n    public async Task&lt;ValidationResult&gt; ValidateOrderAsync(Order order)\n    {\n        try\n        {\n            var failures = new List&lt;string&gt;();\n\n            foreach (var rule in _orderRules)\n            {\n                if (!await rule.ValidateAsync(order))\n                {\n                    failures.Add(rule.ErrorMessage);\n                }\n            }\n\n            return new ValidationResult\n            {\n                IsValid = !failures.Any(),\n                Errors = failures\n            };\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error validating order\");\n            throw;\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-54\">\u5b9f\u88c5\u6642\u306e\u91cd\u8981\u306a\u30dd\u30a4\u30f3\u30c8<\/h3>\n\n\n\n<ol class=\"wp-block-list is-style-sango-list-stitch-blue\">\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u306e\u6700\u9069\u5316\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u983b\u7e41\u306b\u547c\u3073\u51fa\u3055\u308c\u308b\u30e1\u30bd\u30c3\u30c9\u3067\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u4f7f\u7528\u3092\u6700\u5c0f\u9650\u306b<\/li>\n\n\n\n<li>\u30ad\u30e3\u30c3\u30b7\u30e5\u306e\u6226\u7565\u7684\u306a\u6d3b\u7528<\/li>\n\n\n\n<li>\u975e\u540c\u671f\u51e6\u7406\u306e\u9069\u5207\u306a\u4f7f\u7528<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u65e2\u5b58\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u5909\u66f4\u3057\u306a\u3044<\/li>\n\n\n\n<li>\u65b0\u6a5f\u80fd\u306f\u7d99\u627f\u3092\u901a\u3058\u3066\u8ffd\u52a0<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u30c7\u30d5\u30a9\u30eb\u30c8\u5b9f\u88c5\u306e\u63d0\u4f9b<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>\u62bd\u8c61\u5316\u30ec\u30d9\u30eb\u306e\u8a2d\u8a08\u6307\u91dd\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u30d3\u30b8\u30cd\u30b9\u30c9\u30e1\u30a4\u30f3\u306b\u57fa\u3065\u3044\u305f\u62bd\u8c61\u5316<\/li>\n\n\n\n<li>\u5358\u4e00\u8cac\u4efb\u306e\u539f\u5247\u306e\u9075\u5b88<\/li>\n\n\n\n<li>\u5b9f\u88c5\u306e\u8a73\u7d30\u306e\u9069\u5207\u306a\u96a0\u853d<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u308c\u3089\u306e\u6ce8\u610f\u70b9\u3092\u8003\u616e\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u52b9\u679c\u7684\u3067\u30e1\u30f3\u30c6\u30ca\u30f3\u30b9\u53ef\u80fd\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u3092\u5b9f\u73fe\u3067\u304d\u307e\u3059\u3002<br>\u6b21\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u3053\u308c\u3089\u306e\u77e5\u8b58\u3092\u6d3b\u7528\u3057\u305f\u5b9f\u8df5\u7684\u306a\u8a2d\u8a08\u6f14\u7fd2\u3092\u884c\u3063\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-55\">\u5b9f\u8df5\u7684\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u6f14\u7fd2<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u306e\u30bb\u30af\u30b7\u30e7\u30f3\u3067\u306f\u3001\u5b9f\u52d9\u3067\u906d\u9047\u3059\u308b\u5177\u4f53\u7684\u306a\u30b7\u30ca\u30ea\u30aa\u306b\u57fa\u3065\u3044\u3066\u3001\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u5b9f\u8df5\u7684\u306a\u6f14\u7fd2\u3092\u884c\u3044\u307e\u3059\u3002<br>\u3053\u308c\u307e\u3067\u306b\u5b66\u3093\u3060\u8a2d\u8a08\u539f\u5247\u3068\u30d1\u30bf\u30fc\u30f3\u3092\u5b9f\u969b\u306e\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306b\u9069\u7528\u3059\u308b\u65b9\u6cd5\u3092\u898b\u3066\u3044\u304d\u307e\u3057\u3087\u3046\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-56\">EC\u30b5\u30a4\u30c8\u306e\u652f\u6255\u3044\u51e6\u7406\u30b7\u30b9\u30c6\u30e0\u306e\u8a2d\u8a08<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u8907\u6570\u306e\u6c7a\u6e08\u65b9\u6cd5\u306b\u5bfe\u5fdc\u3059\u308b\u67d4\u8edf\u306a\u652f\u6255\u3044\u51e6\u7406\u30b7\u30b9\u30c6\u30e0\u3092\u8a2d\u8a08\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-57\">1. <strong>\u30c9\u30e1\u30a4\u30f3\u30e2\u30c7\u30eb\u3068\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IPaymentGateway\n{\n    Task&lt;PaymentResult&gt; ProcessPaymentAsync(PaymentRequest request);\n    Task&lt;PaymentStatus&gt; CheckPaymentStatusAsync(string transactionId);\n    Task&lt;RefundResult&gt; ProcessRefundAsync(RefundRequest request);\n}\n\npublic interface IPaymentValidator\n{\n    Task&lt;ValidationResult&gt; ValidatePaymentRequestAsync(PaymentRequest request);\n    Task&lt;ValidationResult&gt; ValidateRefundRequestAsync(RefundRequest request);\n}\n\npublic interface IPaymentNotificationHandler\n{\n    Task HandlePaymentCompletedAsync(PaymentCompletedEvent @event);\n    Task HandlePaymentFailedAsync(PaymentFailedEvent @event);\n    Task HandleRefundCompletedAsync(RefundCompletedEvent @event);\n}\n\n\/\/ \u30a4\u30d9\u30f3\u30c8\u30e2\u30c7\u30eb\npublic record PaymentCompletedEvent(\n    string TransactionId,\n    decimal Amount,\n    string Currency,\n    DateTime CompletedAt);\n\n\/\/ \u652f\u6255\u3044\u30ea\u30af\u30a8\u30b9\u30c8\u30e2\u30c7\u30eb\npublic record PaymentRequest(\n    string OrderId,\n    decimal Amount,\n    string Currency,\n    PaymentMethod Method,\n    Dictionary&lt;string, string&gt; PaymentDetails);\n\n\/\/ \u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u7d50\u679c\npublic record ValidationResult(\n    bool IsValid,\n    IReadOnlyList&lt;string&gt; Errors)\n{\n    public static ValidationResult Success() =&gt; new(true, Array.Empty&lt;string&gt;());\n    public static ValidationResult Failure(IEnumerable&lt;string&gt; errors) \n        =&gt; new(false, errors.ToList());\n}<\/pre>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-58\">2. <strong>Stripe\u30da\u30a4\u30e1\u30f3\u30c8\u30b2\u30fc\u30c8\u30a6\u30a7\u30a4\u306e\u5b9f\u88c5<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public class StripePaymentGateway : IPaymentGateway\n{\n    private readonly IStripeClient _stripeClient;\n    private readonly ILogger&lt;StripePaymentGateway&gt; _logger;\n    private readonly IPaymentNotificationHandler _notificationHandler;\n\n    public StripePaymentGateway(\n        IStripeClient stripeClient,\n        ILogger&lt;StripePaymentGateway&gt; logger,\n        IPaymentNotificationHandler notificationHandler)\n    {\n        _stripeClient = stripeClient;\n        _logger = logger;\n        _notificationHandler = notificationHandler;\n    }\n\n    public async Task&lt;PaymentResult&gt; ProcessPaymentAsync(PaymentRequest request)\n    {\n        try\n        {\n            var paymentIntentCreateOptions = new PaymentIntentCreateOptions\n            {\n                Amount = (long)(request.Amount * 100), \/\/ Convert to cents\n                Currency = request.Currency.ToLower(),\n                PaymentMethod = request.PaymentDetails[\"paymentMethodId\"],\n                Confirm = true,\n                ReturnUrl = request.PaymentDetails.GetValueOrDefault(\"returnUrl\")\n            };\n\n            var paymentIntent = await _stripeClient.PaymentIntents\n                .CreateAsync(paymentIntentCreateOptions);\n\n            if (paymentIntent.Status == \"succeeded\")\n            {\n                await _notificationHandler.HandlePaymentCompletedAsync(\n                    new PaymentCompletedEvent(\n                        paymentIntent.Id,\n                        request.Amount,\n                        request.Currency,\n                        DateTime.UtcNow));\n\n                return PaymentResult.Success(\n                    paymentIntent.Id,\n                    \"Payment processed successfully\");\n            }\n\n            return PaymentResult.RequiresAction(\n                paymentIntent.Id,\n                paymentIntent.NextAction?.RedirectToUrl?.Url);\n        }\n        catch (StripeException ex)\n        {\n            _logger.LogError(ex, \"Stripe payment processing failed\");\n            return PaymentResult.Failure(ex.Message);\n        }\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-59\">\u30ed\u30b0\u6a5f\u80fd\u306e\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u7570\u306a\u308b\u51fa\u529b\u5148\u306b\u5bfe\u5fdc\u3059\u308b\u67d4\u8edf\u306a\u30ed\u30b0\u30b7\u30b9\u30c6\u30e0\u3092\u8a2d\u8a08\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface ILogEntry\n{\n    string Message { get; }\n    LogLevel Level { get; }\n    DateTime Timestamp { get; }\n    IDictionary&lt;string, object&gt; Properties { get; }\n    Exception Exception { get; }\n}\n\npublic interface ILogFormatter\n{\n    string FormatLog(ILogEntry entry);\n}\n\npublic interface ILogDestination\n{\n    Task WriteAsync(ILogEntry entry);\n    Task FlushAsync();\n}\n\npublic interface ILogRouter\n{\n    Task RouteLogAsync(ILogEntry entry);\n    void AddDestination(ILogDestination destination, LogLevel minimumLevel);\n}\n\n\/\/ \u69cb\u9020\u5316\u30ed\u30b0\u30a8\u30f3\u30c8\u30ea\u306e\u5b9f\u88c5\npublic class StructuredLogEntry : ILogEntry\n{\n    public string Message { get; }\n    public LogLevel Level { get; }\n    public DateTime Timestamp { get; }\n    public IDictionary&lt;string, object&gt; Properties { get; }\n    public Exception Exception { get; }\n\n    public StructuredLogEntry(\n        string message,\n        LogLevel level,\n        Exception exception = null,\n        IDictionary&lt;string, object&gt; properties = null)\n    {\n        Message = message;\n        Level = level;\n        Timestamp = DateTime.UtcNow;\n        Exception = exception;\n        Properties = properties ?? new Dictionary&lt;string, object&gt;();\n    }\n}\n\n\/\/ JSON\u30d5\u30a9\u30fc\u30de\u30c3\u30bf\u306e\u5b9f\u88c5\npublic class JsonLogFormatter : ILogFormatter\n{\n    public string FormatLog(ILogEntry entry)\n    {\n        var logObject = new\n        {\n            Message = entry.Message,\n            Level = entry.Level.ToString(),\n            Timestamp = entry.Timestamp.ToString(\"O\"),\n            Properties = entry.Properties,\n            Exception = entry.Exception?.ToString()\n        };\n\n        return JsonSerializer.Serialize(logObject, new JsonSerializerOptions\n        {\n            WriteIndented = true\n        });\n    }\n}\n\n\/\/ \u30d5\u30a1\u30a4\u30eb\u51fa\u529b\u5148\u306e\u5b9f\u88c5\npublic class FileLogDestination : ILogDestination, IDisposable\n{\n    private readonly string _filePath;\n    private readonly ILogFormatter _formatter;\n    private readonly StreamWriter _writer;\n    private readonly SemaphoreSlim _lock = new(1, 1);\n\n    public FileLogDestination(string filePath, ILogFormatter formatter)\n    {\n        _filePath = filePath;\n        _formatter = formatter;\n        _writer = new StreamWriter(filePath, true);\n    }\n\n    public async Task WriteAsync(ILogEntry entry)\n    {\n        await _lock.WaitAsync();\n        try\n        {\n            var formattedLog = _formatter.FormatLog(entry);\n            await _writer.WriteLineAsync(formattedLog);\n        }\n        finally\n        {\n            _lock.Release();\n        }\n    }\n\n    public async Task FlushAsync()\n    {\n        await _writer.FlushAsync();\n    }\n\n    public void Dispose()\n    {\n        _writer.Dispose();\n        _lock.Dispose();\n    }\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-60\">\u30de\u30eb\u30c1\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u5bfe\u5fdc\u306e\u5b9f\u88c5\u4f8b<\/h3>\n\n\n\n<p class=\"wp-block-paragraph\">\u30af\u30ed\u30b9\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u3067\u52d5\u4f5c\u3059\u308b\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u5171\u901a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u8a2d\u8a08\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h4 class=\"wp-block-heading\" id=\"i-61\">1. <strong>\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u62bd\u8c61\u5316\u30ec\u30a4\u30e4\u30fc<\/strong><\/h4>\n\n\n\n<pre class=\"EnlighterJSRAW\" data-enlighter-language=\"csharp\" data-enlighter-theme=\"\" data-enlighter-highlight=\"\" data-enlighter-linenumbers=\"\" data-enlighter-lineoffset=\"\" data-enlighter-title=\"\" data-enlighter-group=\"\">public interface IPlatformService\n{\n    string GetPlatformName();\n    Task&lt;bool&gt; RequestPermissionAsync(Permission permission);\n    Task&lt;string&gt; GetStoragePathAsync();\n    Task&lt;bool&gt; IsNetworkAvailableAsync();\n}\n\npublic interface IFileSystemService\n{\n    Task&lt;Stream&gt; OpenFileAsync(string path, FileMode mode);\n    Task&lt;bool&gt; FileExistsAsync(string path);\n    Task&lt;IEnumerable&lt;string&gt;&gt; ListFilesAsync(string directory);\n    Task&lt;string&gt; GetTempPathAsync();\n}\n\npublic enum Permission\n{\n    Camera,\n    Location,\n    Storage,\n    Notifications\n}\n\n\/\/ Windows\u5b9f\u88c5\npublic class WindowsPlatformService : IPlatformService\n{\n    private readonly ILogger&lt;WindowsPlatformService&gt; _logger;\n\n    public WindowsPlatformService(ILogger&lt;WindowsPlatformService&gt; logger)\n    {\n        _logger = logger;\n    }\n\n    public string GetPlatformName() =&gt; \"Windows\";\n\n    public async Task&lt;bool&gt; RequestPermissionAsync(Permission permission)\n    {\n        try\n        {\n            \/\/ Windows\u3067\u306e\u6a29\u9650\u30ea\u30af\u30a8\u30b9\u30c8\u51e6\u7406\n            switch (permission)\n            {\n                case Permission.Camera:\n                    return await RequestCameraPermissionAsync();\n                case Permission.Location:\n                    return await RequestLocationPermissionAsync();\n                default:\n                    return true; \/\/ Windows \u3067\u306f\u4e00\u90e8\u306e\u6a29\u9650\u306f\u4e0d\u8981\n            }\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error requesting permission: {Permission}\", permission);\n            return false;\n        }\n    }\n\n    private async Task&lt;bool&gt; RequestCameraPermissionAsync()\n    {\n        \/\/ Windows Media Capture API\u3092\u4f7f\u7528\u3057\u305f\u5b9f\u88c5\n        await Task.CompletedTask;\n        return true;\n    }\n\n    private async Task&lt;bool&gt; RequestLocationPermissionAsync()\n    {\n        \/\/ Windows Location API\u3092\u4f7f\u7528\u3057\u305f\u5b9f\u88c5\n        await Task.CompletedTask;\n        return true;\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}\n\n\/\/ \u30af\u30ed\u30b9\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u30d5\u30a1\u30a4\u30eb\u30b7\u30b9\u30c6\u30e0\u5b9f\u88c5\npublic class CrossPlatformFileSystem : IFileSystemService\n{\n    private readonly IPlatformService _platformService;\n    private readonly ILogger&lt;CrossPlatformFileSystem&gt; _logger;\n\n    public CrossPlatformFileSystem(\n        IPlatformService platformService,\n        ILogger&lt;CrossPlatformFileSystem&gt; logger)\n    {\n        _platformService = platformService;\n        _logger = logger;\n    }\n\n    public async Task&lt;Stream&gt; OpenFileAsync(string path, FileMode mode)\n    {\n        try\n        {\n            var fullPath = await GetFullPathAsync(path);\n            return new FileStream(fullPath, mode);\n        }\n        catch (Exception ex)\n        {\n            _logger.LogError(ex, \"Error opening file: {Path}\", path);\n            throw;\n        }\n    }\n\n    private async Task&lt;string&gt; GetFullPathAsync(string path)\n    {\n        var basePath = await _platformService.GetStoragePathAsync();\n        return Path.Combine(basePath, path);\n    }\n\n    \/\/ \u305d\u306e\u4ed6\u306e\u30e1\u30bd\u30c3\u30c9\u5b9f\u88c5\n}<\/pre>\n\n\n\n<h3 class=\"wp-block-heading\" id=\"i-62\">\u3053\u308c\u3089\u306e\u5b9f\u88c5\u4f8b\u306f\u3001\u4ee5\u4e0b\u306e\u8a2d\u8a08\u539f\u5247\u3068\u5b9f\u8df5\u3092\u793a\u3057\u3066\u3044\u307e\u3059\u3002<\/h3>\n\n\n\n<ol class=\"wp-block-list is-style-sango-list-stitch-blue\">\n<li>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u30dd\u30a4\u30f3\u30c8\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u5358\u4e00\u8cac\u4efb\u306e\u539f\u5247\u306e\u9075\u5b88<\/li>\n\n\n\n<li>\u30d7\u30e9\u30c3\u30c8\u30d5\u30a9\u30fc\u30e0\u56fa\u6709\u306e\u5b9f\u88c5\u306e\u5206\u96e2<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u62bd\u8c61\u5316\u30ec\u30d9\u30eb\u306e\u7dad\u6301<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3068\u30ed\u30ae\u30f3\u30b0\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>\u4e00\u8cab\u3057\u305f\u30ed\u30b0\u8a18\u9332<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u4f8b\u5916\u51e6\u7406<\/li>\n\n\n\n<li>\u30a8\u30e9\u30fc\u60c5\u5831\u306e\u4f1d\u64ad<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li>\u975e\u540c\u671f\u51e6\u7406\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9\n<ul class=\"wp-block-list is-style-sango-list-chevron\">\n<li>Async\/Await\u306e\u4e00\u8cab\u3057\u305f\u4f7f\u7528<\/li>\n\n\n\n<li>\u30ad\u30e3\u30f3\u30bb\u30ec\u30fc\u30b7\u30e7\u30f3\u5bfe\u5fdc<\/li>\n\n\n\n<li>\u30ea\u30bd\u30fc\u30b9\u306e\u9069\u5207\u306a\u89e3\u653e<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n\n\n\n<p class=\"wp-block-paragraph\">\u3053\u308c\u3089\u306e\u5b9f\u8df5\u7684\u306a\u4f8b\u3092\u901a\u3058\u3066\u3001\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092\u6d3b\u7528\u3057\u305f\u67d4\u8edf\u3067\u62e1\u5f35\u6027\u306e\u9ad8\u3044\u30b7\u30b9\u30c6\u30e0\u8a2d\u8a08\u306e\u65b9\u6cd5\u3092\u5b66\u3076\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"i-63\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u307e\u3068\u3081<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306f\u3001\u9069\u5207\u306b\u4f7f\u7528\u3059\u308b\u3053\u3068\u3067\u67d4\u8edf\u3067\u4fdd\u5b88\u6027\u306e\u9ad8\u3044\u30b7\u30b9\u30c6\u30e0\u3092\u5b9f\u73fe\u3067\u304d\u308b\u5f37\u529b\u306a\u30c4\u30fc\u30eb\u3067\u3059\u3002<br>\u672c\u8a18\u4e8b\u3067\u89e3\u8aac\u3057\u305f\u8a2d\u8a08\u539f\u5247\u3068\u30d1\u30bf\u30fc\u30f3\u3092\u5b9f\u8df5\u3059\u308b\u3053\u3068\u3067\u3001\u3088\u308a\u5805\u7262\u306a\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u958b\u767a\u304c\u53ef\u80fd\u306b\u306a\u308a\u307e\u3059\u3002\u7279\u306b\u3001\u5358\u4e00\u8cac\u4efb\u306e\u539f\u5247\u3001\u4f9d\u5b58\u6027\u306e\u9069\u5207\u306a\u7ba1\u7406\u3001\u305d\u3057\u3066\u5b9f\u88c5\u306e\u8a73\u7d30\u306e\u62bd\u8c61\u5316\u3092\u610f\u8b58\u3059\u308b\u3053\u3068\u304c\u3001\u826f\u8cea\u306a\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08\u306e\u9375\u3068\u306a\u308a\u307e\u3059\u3002<\/p>\n\n\n\n<div class=\"wp-block-sgb-block-simple sgb-box-simple sgb-box-simple--title-normal sgb-box-simple--with-border\"><div style=\"background-color:var(--wp--preset--color--sango-main);color:#FFF\" class=\"sgb-box-simple__title\">\u3053\u306e\u8a18\u4e8b\u306e\u4e3b\u306a\u30dd\u30a4\u30f3\u30c8<\/div><div class=\"sgb-box-simple__body\" style=\"border-color:var(--wp--preset--color--sango-main);background-color:#FFF\">\n<ul class=\"wp-block-list\">\n<li><strong>\u8a2d\u8a08\u539f\u5247\u306e\u91cd\u8996<\/strong>\n<ul class=\"wp-block-list\">\n<li>\u5358\u4e00\u8cac\u4efb\u306e\u539f\u5247\u306b\u57fa\u3065\u304f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u8a2d\u8a08<\/li>\n\n\n\n<li>\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u5206\u96e2\u306e\u539f\u5247\u306b\u3088\u308b\u9069\u5207\u306a\u7c92\u5ea6\u306e\u7dad\u6301<\/li>\n\n\n\n<li>\u4f9d\u5b58\u6027\u9006\u8ee2\u306e\u539f\u5247\u3092\u6d3b\u7528\u3057\u305f\u758e\u7d50\u5408\u306e\u5b9f\u73fe<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u5b9f\u88c5\u306e\u30d9\u30b9\u30c8\u30d7\u30e9\u30af\u30c6\u30a3\u30b9<\/strong>\n<ul class=\"wp-block-list\">\n<li>\u975e\u540c\u671f\u51e6\u7406\u306e\u4e00\u8cab\u3057\u305f\u4f7f\u7528<\/li>\n\n\n\n<li>\u9069\u5207\u306a\u30a8\u30e9\u30fc\u30cf\u30f3\u30c9\u30ea\u30f3\u30b0\u3068\u30ed\u30ae\u30f3\u30b0<\/li>\n\n\n\n<li>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3092\u8003\u616e\u3057\u305f\u30ad\u30e3\u30c3\u30b7\u30e5\u6226\u7565<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u5b9f\u7528\u7684\u306a\u6d3b\u7528\u65b9\u6cd5<\/strong>\n<ul class=\"wp-block-list\">\n<li>\u4f9d\u5b58\u6027\u6ce8\u5165\u3092\u6d3b\u7528\u3057\u305f\u30c6\u30b9\u30c8\u5bb9\u6613\u6027\u306e\u5411\u4e0a<\/li>\n\n\n\n<li>\u30c7\u30b6\u30a4\u30f3\u30d1\u30bf\u30fc\u30f3\u3092\u7528\u3044\u305f\u67d4\u8edf\u306a\u5b9f\u88c5<\/li>\n\n\n\n<li>\u30d7\u30e9\u30b0\u30a4\u30f3\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306b\u3088\u308b\u62e1\u5f35\u6027\u306e\u78ba\u4fdd<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u4fdd\u5b88\u6027\u3078\u306e\u914d\u616e<\/strong>\n<ul class=\"wp-block-list\">\n<li>\u30d0\u30fc\u30b8\u30e7\u30f3\u7ba1\u7406\u3092\u8003\u616e\u3057\u305f\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u306e\u9032\u5316<\/li>\n\n\n\n<li>\u904e\u5270\u306a\u62bd\u8c61\u5316\u3092\u907f\u3051\u308b\u305f\u3081\u306e\u6307\u91dd<\/li>\n\n\n\n<li>\u30af\u30ea\u30fc\u30f3\u30a2\u30fc\u30ad\u30c6\u30af\u30c1\u30e3\u306e\u5b9f\u8df5<\/li>\n<\/ul>\n<\/li>\n<\/ul>\n<\/div><\/div>\n","protected":false},"excerpt":{"rendered":"<p>Warning: Undefined array key &#8220;is_admin&#8221; in \/home\/xs392991\/dexall.co.jp\/public_html\/articles\/wp-content\/themes\/ &#8230; <\/p>\n","protected":false},"author":1,"featured_media":2815,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4,69],"tags":[],"class_list":["post-1998","post","type-post","status-publish","format-standard","has-post-thumbnail","category-csharp","category-csharp-best-practice"],"_links":{"self":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/1998","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1998"}],"version-history":[{"count":13,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/1998\/revisions"}],"predecessor-version":[{"id":2011,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/posts\/1998\/revisions\/2011"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=\/wp\/v2\/media\/2815"}],"wp:attachment":[{"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1998"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1998"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/dexall.co.jp\/articles\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1998"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}