次の方法で共有


コンパイラの警告 (レベル 2) CS1701

更新 : 2007 年 11 月

エラー メッセージ

参照 "アセンブリ名 #1" は "アセンブリ名 #2" と一致していると仮定して、実行時ポリシーを指定する必要がある可能性があります。

2 つのアセンブリ間で、リリース番号またはバージョン番号が異なります。正しく統合するためには、以下に示す例に従って、アプリケーションの .config ファイルでディレクティブを指定し、アセンブリの厳密名を正しく指定する必要があります。

使用例

次のマルチファイルの例では、2 つの異なる外部エイリアスを使ってアセンブリを参照しています。この最初の例では、CS1701_d アセンブリを生成する古いバージョンのコードを作成します。

// CS1701_a.cs
// compile with: /target:library /out:cs1701_d.dll /keyfile:mykey.snk
using System.Reflection;
[assembly:AssemblyVersion("1.0")]
public class A {
   public void M1() {}
}

public class C1 {}

これは、CS1701_d アセンブリの新しいバージョンを生成するコードです。古いバージョンとは異なるディレクトリにコンパイルされることに注意してください。これは、出力ファイルが同じ名前であるために必要な処理です。

// CS1701_b.cs
// compile with: /target:library /out:c:\\cs1701_d.dll /keyfile:mykey.snk
using System.Reflection;
[assembly:AssemblyVersion("2.0")]
public class A {
   public void M2() {}
   public void M1() {}
}

public class C2 {}
public class C1 {}

この例では、外部エイリアス A1 および A2 が設定されます。

// CS1701_c.cs
// compile with: /target:library /reference:A2=c:\\cs1701_d.dll /reference:A1=cs1701_d.dll

extern alias A1;
extern alias A2;
// using System;
using a1 = A1::A;
using a2 = A2::A;

public class Ref {
   public static a1 A1() { return new a1(); }
   public static a2 A2() { return new a2(); }

   public static A1::C1 M1() { return new A1::C1(); }
   public static A2::C2 M2() { return new A2::C2(); }
}

この例では、A の 2 つの異なるエイリアスを使用してメソッドが呼び出されます。次の例では C1701 警告が生成されます。

// CS1701_d.cs
// compile with: /reference:c:\\CS1701_d.dll /reference:CS1701_c.dll
// CS1701 expected
class Tester {
   public static void Main() {
      Ref.A1().M1();
      Ref.A2().M2();
   }
}