Aracılığıyla paylaş


System.InvalidCastException sınıfı

Bu makale, bu API'nin başvuru belgelerine ek açıklamalar sağlar.

.NET, türetilmiş türlerden kendi temel türlerine ve tekrar türetilmiş türlere, ayrıca arabirim sunan türlerden arabirim nesnelerine ve geri dönüşümlerini otomatik dönüştürmeyi destekler. Ayrıca özel dönüştürmeleri destekleyen çeşitli mekanizmalar içerir. Daha fazla bilgi için bkz . .NET'te Tür Dönüştürme.

Bir InvalidCastException tür örneğinin başka bir türe dönüştürülmesi desteklenmediğinde bir özel durum oluşturulur. Örneğin, bir Char değeri DateTime değerine dönüştürmeye çalışmak bir InvalidCastException istisnası fırlatır. Bir türün OverflowException diğerine dönüştürülmesi desteklendiğinde oluşan bir özel durumdan farklıdır, ancak kaynak türün değeri hedef türün aralığının dışındadır. İstisna InvalidCastException geliştirici hatası nedeniyle oluşur ve bir try/catch blokta yakalanmamalıdır. Bunun yerine, özel durumun nedeni ortadan kaldırılmalıdır.

Sistem tarafından desteklenen dönüştürmeler hakkında bilgi için sınıfına Convert bakın. Hedef tür kaynak türü değerlerini depoladığında ancak belirli bir kaynak değeri depolayabilecek kadar büyük olmadığında oluşan hatalar için özel duruma bakın OverflowException .

Uyarı

Çoğu durumda, dil derleyiciniz kaynak türü ile hedef tür arasında dönüştürme olmadığını algılar ve derleyici hatası verir.

Dönüştürme denemesi InvalidCastException istisnası attığında, karşılaşılabilecek bazı koşullar aşağıdaki bölümlerde açıklanmıştır.

Açık başvuru dönüştürme işleminin başarılı olması için kaynak değeri nullolmalıdır veya kaynak bağımsız değişkeni tarafından başvurulan nesne türü örtük başvuru dönüştürmesi ile hedef türe dönüştürülebilir olmalıdır.

Aşağıdaki ara dil (IL) yönergeleri bir InvalidCastException özel durum oluşturur:

  • castclass
  • refanyval
  • unbox

InvalidCastException , 0x80004002 değerine sahip HRESULT COR_E_INVALIDCASTkullanır.

InvalidCastExceptionörneğinin ilk özellik değerlerinin listesi için bkz. InvalidCastException oluşturucuları.

Temel türler ve IConvertible

Belirli bir dönüştürmeyi desteklemeyen bir ilkel türün IConvertible uygulamasını doğrudan veya dolaylı olarak çağırırsınız. Örneğin, bir Boolean değerini Char veya bir DateTime değerini Int32 değerine dönüştürmeye çalışmak bir InvalidCastException istisnası atar. Aşağıdaki örnek, bir Boolean.IConvertible.ToChar değeri Convert.ToChar(Boolean)değerine dönüştürmek için hem Boolean ve Char yöntemlerini çağırır. Her iki durumda da yöntem çağrısı bir InvalidCastException özel durum oluşturur.

using System;

public class IConvertibleEx
{
    public static void Main()
    {
        bool flag = true;
        try
        {
            IConvertible conv = flag;
            Char ch = conv.ToChar(null);
            Console.WriteLine("Conversion succeeded.");
        }
        catch (InvalidCastException)
        {
            Console.WriteLine("Cannot convert a Boolean to a Char.");
        }

        try
        {
            Char ch = Convert.ToChar(flag);
            Console.WriteLine("Conversion succeeded.");
        }
        catch (InvalidCastException)
        {
            Console.WriteLine("Cannot convert a Boolean to a Char.");
        }
    }
}
// The example displays the following output:
//       Cannot convert a Boolean to a Char.
//       Cannot convert a Boolean to a Char.
open System

let flag = true
try
    let conv: IConvertible = flag
    let ch = conv.ToChar null
    printfn "Conversion succeeded."
with :? InvalidCastException ->
    printfn "Cannot convert a Boolean to a Char."

try
    let ch = Convert.ToChar flag
    printfn "Conversion succeeded."
with :? InvalidCastException ->
    printfn "Cannot convert a Boolean to a Char."

// The example displays the following output:
//       Cannot convert a Boolean to a Char.
//       Cannot convert a Boolean to a Char.
Module Example2
    Public Sub Main()
        Dim flag As Boolean = True
        Try
            Dim conv As IConvertible = flag
            Dim ch As Char = conv.ToChar(Nothing)
            Console.WriteLine("Conversion succeeded.")
        Catch e As InvalidCastException
            Console.WriteLine("Cannot convert a Boolean to a Char.")
        End Try

        Try
            Dim ch As Char = Convert.ToChar(flag)
            Console.WriteLine("Conversion succeeded.")
        Catch e As InvalidCastException
            Console.WriteLine("Cannot convert a Boolean to a Char.")
        End Try
    End Sub
End Module
' The example displays the following output:
'       Cannot convert a Boolean to a Char.
'       Cannot convert a Boolean to a Char.

Dönüştürme desteklenmediği için herhangi bir geçici çözüm yoktur.

Convert.ChangeType yöntemi

Convert.ChangeType yöntemini kullanarak bir nesneyi bir türden diğerine dönüştürdünüz, ancak bir veya her iki tür de IConvertible arabirimini uygulamıyor.

Çoğu durumda, dönüşüm desteklenmediği için bir geçici çözüm yoktur. Bazı durumlarda olası bir geçici çözüm, kaynak türdeki özellik değerlerini hedef türün benzer özelliklerine el ile atamaktır.

Dönüştürmeleri ve IConvertible uygulamalarını daraltma

Daraltma işleçleri, bir tür tarafından desteklenen açık dönüştürmeleri tanımlar. Dönüştürmeyi CType gerçekleştirmek için C# dilinde bir atama işleci veya Visual Basic'teki dönüştürme yöntemi (açıksa Option Strict ) gerekir.

Bununla birlikte, kaynak türü veya hedef türü iki tür arasında açık veya daraltma dönüştürmesi tanımlamıyorsa ve IConvertible bir veya her iki türün uygulanması kaynak türden hedef türe dönüştürmeyi desteklemiyorsa, bir InvalidCastException özel durum oluşturulur.

Çoğu durumda, dönüşüm desteklenmediği için bir geçici çözüm yoktur.

Aşağı Yayın

Temel bir türün örneğini türetilmiş bir türüne dönüştürmeye çalıştığınızda aşağı dönüştürme yapıyorsunuz. Aşağıdaki örnekte, bir Person nesneyi nesneye PersonWithID dönüştürme denemesi başarısız olur.

using System;

public class Person
{
   String _name;

   public String Name
   {
      get { return _name; }
      set { _name = value; }
   }
}

public class PersonWithId : Person
{
   String _id;

   public string Id
   {
      get { return _id; }
      set { _id = value; }
   }
}

public class Example
{
   public static void Main()
   {
      Person p = new Person();
      p.Name = "John";
      try {
         PersonWithId pid = (PersonWithId) p;
         Console.WriteLine("Conversion succeeded.");
      }
      catch (InvalidCastException) {
         Console.WriteLine("Conversion failed.");
      }

      PersonWithId pid1 = new PersonWithId();
      pid1.Name = "John";
      pid1.Id = "246";
      Person p1 = pid1;
      try {
         PersonWithId pid1a = (PersonWithId) p1;
         Console.WriteLine("Conversion succeeded.");
      }
      catch (InvalidCastException) {
         Console.WriteLine("Conversion failed.");
      }

      Person p2 = null;
      try {
         PersonWithId pid2 = (PersonWithId) p2;
         Console.WriteLine("Conversion succeeded.");
      }
      catch (InvalidCastException) {
         Console.WriteLine("Conversion failed.");
      }
   }
}
// The example displays the following output:
//       Conversion failed.
//       Conversion succeeded.
//       Conversion succeeded.
open System

type Person() =
    member val Name = String.Empty with get, set

type PersonWithId() =
    inherit Person()
    member val Id = String.Empty with get, set


let p = Person()
p.Name <- "John"
try
    let pid = p :?> PersonWithId
    printfn "Conversion succeeded."
with :? InvalidCastException ->
    printfn "Conversion failed."

let pid1 = PersonWithId()
pid1.Name <- "John"
pid1.Id <- "246"
let p1: Person = pid1
try
    let pid1a = p1 :?> PersonWithId
    printfn "Conversion succeeded."
with :? InvalidCastException ->
    printfn "Conversion failed."

// The example displays the following output:
//       Conversion failed.
//       Conversion succeeded.
Public Class Person
   Dim _name As String
   
   Public Property Name As String
      Get
         Return _name
      End Get
      Set
         _name = value
      End Set
   End Property
End Class

Public Class PersonWithID : Inherits Person
   Dim _id As String
   
   Public Property Id As String
      Get
         Return _id
      End Get
      Set
         _id = value
      End Set
   End Property
End Class

Module Example1
    Public Sub Main()
        Dim p As New Person()
        p.Name = "John"
        Try
            Dim pid As PersonWithID = CType(p, PersonWithID)
            Console.WriteLine("Conversion succeeded.")
        Catch e As InvalidCastException
            Console.WriteLine("Conversion failed.")
        End Try

        Dim pid1 As New PersonWithID()
        pid1.Name = "John"
        pid1.Id = "246"
        Dim p1 As Person = pid1

        Try
            Dim pid1a As PersonWithID = CType(p1, PersonWithID)
            Console.WriteLine("Conversion succeeded.")
        Catch e As InvalidCastException
            Console.WriteLine("Conversion failed.")
        End Try

        Dim p2 As Person = Nothing
        Try
            Dim pid2 As PersonWithID = CType(p2, PersonWithID)
            Console.WriteLine("Conversion succeeded.")
        Catch e As InvalidCastException
            Console.WriteLine("Conversion failed.")
        End Try
    End Sub
End Module
' The example displays the following output:
'       Conversion failed.
'       Conversion succeeded.
'       Conversion succeeded.

Örnekte gösterildiği gibi, aşağı yayın ancak Person nesnesi, PersonWithId nesnesinden Person nesnesine bir yukarı yayınla oluşturulduysa veya Person nesnesi null olabilir.

Arabirim nesnesinden dönüştürme

Bir arabirim nesnesini bu arabirimi uygulayan bir türe dönüştürmeye çalışıyorsunuz, ancak hedef tür, arabirim nesnesinin ilk türetildiği türün aynı türü veya temel sınıfı değil. Aşağıdaki örnek, bir InvalidCastException nesnesini IFormatProvider nesnesine dönüştürmeye çalıştığında bir DateTimeFormatInfo özel durum fırlatır. Dönüştürme başarısız olur çünkü DateTimeFormatInfo sınıfı IFormatProvider arabirimini uygulasa da, DateTimeFormatInfo nesnesi arabirim nesnesinin türetildiği CultureInfo sınıfla ilgili değildir.

using System;
using System.Globalization;

public class InterfaceEx
{
    public static void Main()
    {
        var culture = CultureInfo.InvariantCulture;
        IFormatProvider provider = culture;

        DateTimeFormatInfo dt = (DateTimeFormatInfo)provider;
    }
}
// The example displays the following output:
//    Unhandled Exception: System.InvalidCastException:
//       Unable to cast object of type //System.Globalization.CultureInfo// to
//           type //System.Globalization.DateTimeFormatInfo//.
//       at Example.Main()
open System
open System.Globalization

let culture = CultureInfo.InvariantCulture
let provider: IFormatProvider = culture

let dt = provider :?> DateTimeFormatInfo

// The example displays the following output:
//    Unhandled Exception: System.InvalidCastException:
//       Unable to cast object of type //System.Globalization.CultureInfo// to
//           type //System.Globalization.DateTimeFormatInfo//.
//       at Example.main()
Imports System.Globalization

Module Example3
    Public Sub Main()
        Dim culture As CultureInfo = CultureInfo.InvariantCulture
        Dim provider As IFormatProvider = culture

        Dim dt As DateTimeFormatInfo = CType(provider, DateTimeFormatInfo)
    End Sub
End Module
' The example displays the following output:
'    Unhandled Exception: System.InvalidCastException: 
'       Unable to cast object of type 'System.Globalization.CultureInfo' to 
'           type 'System.Globalization.DateTimeFormatInfo'.
'       at Example.Main()

Özel durum iletisinde de belirtildiği gibi, dönüştürmenin başarılı olması için arabirim nesnesinin özgün türün bir örneğine ( bu örnekte bir CultureInfo) geri dönüştürülmesi gerekir. Arabirim nesnesi özgün türün temel türünün bir örneğine dönüştürülürse dönüştürme de başarılı olur.

Dize dönüştürmeleri

C# dilinde bir atama işleci kullanarak bir değeri veya nesneyi dize gösterimine dönüştürmeye çalışıyorsunuz. Aşağıdaki örnekte, hem bir dizeye değer Char atama girişimi hem de dizeye tamsayı atama girişimi bir InvalidCastException özel durum oluşturur.

public class StringEx
{
    public static void Main()
    {
        object value = 12;
        // Cast throws an InvalidCastException exception.
        string s = (string)value;
    }
}
let value: obj = 12
// Cast throws an InvalidCastException exception.
let s = value :?> string

Uyarı

İlkel türdeki bir değeri dizeye dönüştürmek için Visual Basic CStr işlecini kullanmak başarılı olur. İşlem bir InvalidCastException istisnası fırlatmaz.

Herhangi bir türün örneğini başarılı bir şekilde dize gösterimine dönüştürmek için aşağıdaki örnekte olduğu gibi yöntemini çağırın ToString . ToString yöntemi her zaman mevcuttur, çünkü ToString yöntemi Object sınıfı tarafından tanımlandığından, tüm yönetilen türler tarafından ya devralınır ya da geçersiz kılınır.

using System;

public class ToStringEx2
{
    public static void Main()
    {
        object value = 12;
        string s = value.ToString();
        Console.WriteLine(s);
    }
}
// The example displays the following output:
//      12
let value: obj = 12
let s = value.ToString()
printfn $"{s}"
// The example displays the following output:
//      12

Visual Basic 6.0 geçişi

Bir Visual Basic 6.0 uygulamasını, kullanıcı kontrolündeki özel bir olaya yönelik bir çağrıyla Visual Basic .NET'e yükseltirken "Belirtilen dönüştürme geçerli değil" mesajıyla bir InvalidCastException hata fırlatıldı. Bu hatayı ortadan kaldırmak için, formunuzda kod satırını değiştirin (örneğin Form1)

Call UserControl11_MyCustomEvent(UserControl11, New UserControl1.MyCustomEventEventArgs(5))

ve aşağıdaki kod satırıyla değiştirin:

Call UserControl11_MyCustomEvent(UserControl11(0), New UserControl1.MyCustomEventEventArgs(5))