ホームページ >バックエンド開発 >C++ >App.config から接続文字列を取得するときに「オブジェクト参照がオブジェクトのインスタンスに設定されていません」を回避するにはどうすればよいですか?

App.config から接続文字列を取得するときに「オブジェクト参照がオブジェクトのインスタンスに設定されていません」を回避するにはどうすればよいですか?

Susan Sarandon
Susan Sarandonオリジナル
2025-01-14 22:56:48345ブラウズ

How to Avoid

App.config からの接続文字列へのアクセス: NullReferenceExceptions の回避

App.config ファイルから接続文字列を取得するには、NullReferenceException エラーを防ぐために慎重な処理が必要です。 次のコード例を考えてみましょう:

<code class="language-csharp">var connection = ConnectionFactory.GetConnection(
    ConfigurationManager.ConnectionStrings["Test"]
    .ConnectionString, DataBaseProvider);</code>

このコード スニペットは、次のように標準 App.config ファイルで使用される場合:

<code class="language-xml"><?xml version="1.0" encoding="utf-8" ?>
<configuration>
  <connectionStrings>
    <add connectionString="Data Source=.;Initial Catalog=OmidPayamak;Integrated Security=True" 
         name="Test" providerName="System.Data.SqlClient" />
  </connectionStrings>
</configuration></code>

は、接続文字列「Test」が見つからない場合に NullReferenceException をスローできます。 問題は、null をチェックせずに .ConnectionString に直接アクセスすることにあります。

堅牢なソリューションには、プロパティにアクセスする前に接続文字列の存在を確認することが含まれます。

<code class="language-csharp">var connectionString = ConfigurationManager.ConnectionStrings["Test"];
if (connectionString != null)
{
    var connection = ConnectionFactory.GetConnection(connectionString.ConnectionString, DataBaseProvider);
    // ... use the connection ...
}
else
{
    // Handle the case where the connection string is not found.  
    // Log an error, throw an exception, or use a default connection.
}</code>

代わりに、NULL 条件演算子 (?.) を使用したより簡潔なアプローチを使用することもできます。

<code class="language-csharp">var connection = ConnectionFactory.GetConnection(
    ConfigurationManager.ConnectionStrings["Test"]?.ConnectionString, DataBaseProvider);</code>

これは、「Test」が欠落している場合に connection を null に設定することで、null の場合を適切に処理します。 このシナリオでは、必ず適切なエラー処理を追加してください。

最後に、プロジェクトに System.Configuration.dll への参照を忘れずに含めてください。このアセンブリは、構成設定にアクセスするために必要なクラスを提供します。 この参照がないとコンパイルは失敗します。

以上がApp.config から接続文字列を取得するときに「オブジェクト参照がオブジェクトのインスタンスに設定されていません」を回避するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。