Kotlin Class Cast Exception
data:image/s3,"s3://crabby-images/01be7/01be78e10f87fdffd5b8a9d53f13158d8d90e79b" alt="Multi tool use Multi tool use"
Multi tool use
I am new to Android development and I saw this piece of code in a tutorial
class MainActivity : AppCompatActivity() {
private val newNumber by lazy(LazyThreadSafetyMode.NONE) {
findViewById<EditText>(R.id.newNumber) }
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val listener = View.OnClickListener {v ->
val b = v as Button
newNumber.append(v.text)
}
}
}
I tried to understand the "as" operator so i made this code:
fun main(args: Array<String>) {
open class View {
fun a() {
println("This is the View method")
}
}
open class TextView: View() {
fun b() {
println("This is the TextView method")
}
}
open class Button: TextView() {
fun c() {
println("This is the Button method")
}
}
var v = View()
var b = v as Button
b.c()
}
But I get this error:
Exception in thread "main" java.lang.ClassCastException: Simplest_versionKt$main$View cannot be cast to Simplest_versionKt$main$Button
at Simplest_versionKt.main(Simplest version.kt:28)"
Why is this happening?
data:image/s3,"s3://crabby-images/de96b/de96bbd556fc859e2d32e461375a3c3563011f3d" alt=""
add a comment |
I am new to Android development and I saw this piece of code in a tutorial
class MainActivity : AppCompatActivity() {
private val newNumber by lazy(LazyThreadSafetyMode.NONE) {
findViewById<EditText>(R.id.newNumber) }
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val listener = View.OnClickListener {v ->
val b = v as Button
newNumber.append(v.text)
}
}
}
I tried to understand the "as" operator so i made this code:
fun main(args: Array<String>) {
open class View {
fun a() {
println("This is the View method")
}
}
open class TextView: View() {
fun b() {
println("This is the TextView method")
}
}
open class Button: TextView() {
fun c() {
println("This is the Button method")
}
}
var v = View()
var b = v as Button
b.c()
}
But I get this error:
Exception in thread "main" java.lang.ClassCastException: Simplest_versionKt$main$View cannot be cast to Simplest_versionKt$main$Button
at Simplest_versionKt.main(Simplest version.kt:28)"
Why is this happening?
data:image/s3,"s3://crabby-images/de96b/de96bbd556fc859e2d32e461375a3c3563011f3d" alt=""
add a comment |
I am new to Android development and I saw this piece of code in a tutorial
class MainActivity : AppCompatActivity() {
private val newNumber by lazy(LazyThreadSafetyMode.NONE) {
findViewById<EditText>(R.id.newNumber) }
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val listener = View.OnClickListener {v ->
val b = v as Button
newNumber.append(v.text)
}
}
}
I tried to understand the "as" operator so i made this code:
fun main(args: Array<String>) {
open class View {
fun a() {
println("This is the View method")
}
}
open class TextView: View() {
fun b() {
println("This is the TextView method")
}
}
open class Button: TextView() {
fun c() {
println("This is the Button method")
}
}
var v = View()
var b = v as Button
b.c()
}
But I get this error:
Exception in thread "main" java.lang.ClassCastException: Simplest_versionKt$main$View cannot be cast to Simplest_versionKt$main$Button
at Simplest_versionKt.main(Simplest version.kt:28)"
Why is this happening?
data:image/s3,"s3://crabby-images/de96b/de96bbd556fc859e2d32e461375a3c3563011f3d" alt=""
I am new to Android development and I saw this piece of code in a tutorial
class MainActivity : AppCompatActivity() {
private val newNumber by lazy(LazyThreadSafetyMode.NONE) {
findViewById<EditText>(R.id.newNumber) }
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val listener = View.OnClickListener {v ->
val b = v as Button
newNumber.append(v.text)
}
}
}
I tried to understand the "as" operator so i made this code:
fun main(args: Array<String>) {
open class View {
fun a() {
println("This is the View method")
}
}
open class TextView: View() {
fun b() {
println("This is the TextView method")
}
}
open class Button: TextView() {
fun c() {
println("This is the Button method")
}
}
var v = View()
var b = v as Button
b.c()
}
But I get this error:
Exception in thread "main" java.lang.ClassCastException: Simplest_versionKt$main$View cannot be cast to Simplest_versionKt$main$Button
at Simplest_versionKt.main(Simplest version.kt:28)"
Why is this happening?
data:image/s3,"s3://crabby-images/de96b/de96bbd556fc859e2d32e461375a3c3563011f3d" alt=""
data:image/s3,"s3://crabby-images/de96b/de96bbd556fc859e2d32e461375a3c3563011f3d" alt=""
edited Dec 27 '18 at 15:41
data:image/s3,"s3://crabby-images/a1a9a/a1a9a7c16ebbf1e88f27c7bd5adee868faf9b67d" alt=""
data:image/s3,"s3://crabby-images/a1a9a/a1a9a7c16ebbf1e88f27c7bd5adee868faf9b67d" alt=""
Zoe
11.1k73675
11.1k73675
asked Dec 27 '18 at 15:12
Diego Perdomo
102
102
add a comment |
add a comment |
4 Answers
4
active
oldest
votes
as
is the keyword for casting in Kotlin. Example: someInstance as CastTarget
. The Java equivalent is (CastTarget) someInstance
. These are usually language-specific, but some languages have the same syntax for it. C++ has the same syntax as Java (although it has an extra one as well, but that's beside the point).
Buttons extend View. Which means, a button is a View. However, this does not imply a View is a button. A View can also be a TextView, ListView, RecyclerView, etc. There's a long list of Views, and there's also libraries that add more.
This means this is valid:
val view: View = Button(...)
val btn = view as Button
This works because the view is, in this case, a Button. However, if you have:
val view: View = RecyclerView(...)
val btn = view as Button
it will fail. This is because, for pretty obvious reasons in this case, a RecyclerView isn't a button. The reason View(...) as Button
fails is because a View isn't a button either. When you cast, you can only cast an instance as itself, or a parent, but not a child class. Here's an actual example:
interface Base
class Parent : Base
class Child1 : Parent()
class Child11 : Child1()
class Child2 : Parent()
Now, in this case, the classes are useless. They don't do anything, but they can still be used to demonstrate inheritance and casting.
Now, say you have this:
val base = getRandomBaseChild()
Does that imply you have a Child2
? The inferred type here would be Base
, which means it can be any class (or interface, since Base is an interface) that extends/implements Base. It doesn't have to be a Child2, but it can be. Since the method in this case would be random, this would fail some times, but not always:
val child2 = base as Child2
This is because the base will in some cases actually be a Child2. But for any of the other instances, it isn't Child2.
Say we took Child1 instead:
val child1 = base as Child1
This actually has two valid targets: Child1 and Child11. You can always downcast, but never upcast unless the type matches. With that, you now know this will always succeed:
val obj = base as Any
Because everything is Any
(/Object
in Java). But upcasting won't necessarily succeed unless the type is right.
Now, if you're in a case like this where the type actually varies, the easiest way is using is
:
if(base is Child2) // cast and do something
Alternatively, there's a slightly heavier approach using as?
. Note that this will add a nullable type; if the cast fails, you get null:
val child2 = base as? Child2 ?: TODO("Cast failed");
You also added some code; in your examples, you will always be able to cast a Button as a TextView or View, and the TextView can be cast as a View. However, if you cast a View as a TextView or a Button, it will fail because the type isn't the same.
TL;DR:
A View isn't a Button. For your code to work, use val v: View = Button()
, and then cast. v
can only be cast as a child if the instance that's declared as a parent type actually is the specified child. You can also use is
to check if the type is a match before you cast, or use as?
to get null if it fails.
You can also take a look at this article from Oracle on types and inheritance.
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
add a comment |
In Kotlin, as
is a type cast operator.
val b = v as Button
's equivalent in Java (ignore the null check) is
Button b = (Button) v;
Besides, listener
in the first piece of code is not used.
For your second piece of code, Button
is surely a View
, but something that is a View
may not a Button
. If you try to cast a View
which is not actually a Button
, you will get that cast exception.
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
add a comment |
This is basic java concept. If you carefully read the exception documentation.
Thrown to indicate that the code has attempted to cast an object to a subclass of which it is not an instance.
In simple words, parent class object(v) can only be typecast to child class type(Button) if it holds the child class object instance.
so Correct code would be
val v: View = Button()
val b = v as Button
b.c()
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
add a comment |
Since this problem is not Android-specific, let's create a minimal example.
Consider the following inheritance hierarchy, where we have a Fruit with two subclasses Apple
and Banana
:
open class Fruit
class Apple: Fruit()
class Banana: Fruit()
Let's do some testing with the safe cast operator as? which returns null
if the cast fails:
val fruit = Fruit()
fruit as? Apple // returns null - fruit is not of type Apple
val apple = Apple()
apple as? Fruit // apple is a Fruit
apple as? Banana // returns null - apple is not a Banana
If you create a Fruit
it is neither an Apple
nor a Banana
. Just a fruit in general.
If you create an Apple
, it is a Fruit
because Fruit
is its super class, but an Apple
is not related to Banana
.
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53947167%2fkotlin-class-cast-exception%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
4 Answers
4
active
oldest
votes
4 Answers
4
active
oldest
votes
active
oldest
votes
active
oldest
votes
as
is the keyword for casting in Kotlin. Example: someInstance as CastTarget
. The Java equivalent is (CastTarget) someInstance
. These are usually language-specific, but some languages have the same syntax for it. C++ has the same syntax as Java (although it has an extra one as well, but that's beside the point).
Buttons extend View. Which means, a button is a View. However, this does not imply a View is a button. A View can also be a TextView, ListView, RecyclerView, etc. There's a long list of Views, and there's also libraries that add more.
This means this is valid:
val view: View = Button(...)
val btn = view as Button
This works because the view is, in this case, a Button. However, if you have:
val view: View = RecyclerView(...)
val btn = view as Button
it will fail. This is because, for pretty obvious reasons in this case, a RecyclerView isn't a button. The reason View(...) as Button
fails is because a View isn't a button either. When you cast, you can only cast an instance as itself, or a parent, but not a child class. Here's an actual example:
interface Base
class Parent : Base
class Child1 : Parent()
class Child11 : Child1()
class Child2 : Parent()
Now, in this case, the classes are useless. They don't do anything, but they can still be used to demonstrate inheritance and casting.
Now, say you have this:
val base = getRandomBaseChild()
Does that imply you have a Child2
? The inferred type here would be Base
, which means it can be any class (or interface, since Base is an interface) that extends/implements Base. It doesn't have to be a Child2, but it can be. Since the method in this case would be random, this would fail some times, but not always:
val child2 = base as Child2
This is because the base will in some cases actually be a Child2. But for any of the other instances, it isn't Child2.
Say we took Child1 instead:
val child1 = base as Child1
This actually has two valid targets: Child1 and Child11. You can always downcast, but never upcast unless the type matches. With that, you now know this will always succeed:
val obj = base as Any
Because everything is Any
(/Object
in Java). But upcasting won't necessarily succeed unless the type is right.
Now, if you're in a case like this where the type actually varies, the easiest way is using is
:
if(base is Child2) // cast and do something
Alternatively, there's a slightly heavier approach using as?
. Note that this will add a nullable type; if the cast fails, you get null:
val child2 = base as? Child2 ?: TODO("Cast failed");
You also added some code; in your examples, you will always be able to cast a Button as a TextView or View, and the TextView can be cast as a View. However, if you cast a View as a TextView or a Button, it will fail because the type isn't the same.
TL;DR:
A View isn't a Button. For your code to work, use val v: View = Button()
, and then cast. v
can only be cast as a child if the instance that's declared as a parent type actually is the specified child. You can also use is
to check if the type is a match before you cast, or use as?
to get null if it fails.
You can also take a look at this article from Oracle on types and inheritance.
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
add a comment |
as
is the keyword for casting in Kotlin. Example: someInstance as CastTarget
. The Java equivalent is (CastTarget) someInstance
. These are usually language-specific, but some languages have the same syntax for it. C++ has the same syntax as Java (although it has an extra one as well, but that's beside the point).
Buttons extend View. Which means, a button is a View. However, this does not imply a View is a button. A View can also be a TextView, ListView, RecyclerView, etc. There's a long list of Views, and there's also libraries that add more.
This means this is valid:
val view: View = Button(...)
val btn = view as Button
This works because the view is, in this case, a Button. However, if you have:
val view: View = RecyclerView(...)
val btn = view as Button
it will fail. This is because, for pretty obvious reasons in this case, a RecyclerView isn't a button. The reason View(...) as Button
fails is because a View isn't a button either. When you cast, you can only cast an instance as itself, or a parent, but not a child class. Here's an actual example:
interface Base
class Parent : Base
class Child1 : Parent()
class Child11 : Child1()
class Child2 : Parent()
Now, in this case, the classes are useless. They don't do anything, but they can still be used to demonstrate inheritance and casting.
Now, say you have this:
val base = getRandomBaseChild()
Does that imply you have a Child2
? The inferred type here would be Base
, which means it can be any class (or interface, since Base is an interface) that extends/implements Base. It doesn't have to be a Child2, but it can be. Since the method in this case would be random, this would fail some times, but not always:
val child2 = base as Child2
This is because the base will in some cases actually be a Child2. But for any of the other instances, it isn't Child2.
Say we took Child1 instead:
val child1 = base as Child1
This actually has two valid targets: Child1 and Child11. You can always downcast, but never upcast unless the type matches. With that, you now know this will always succeed:
val obj = base as Any
Because everything is Any
(/Object
in Java). But upcasting won't necessarily succeed unless the type is right.
Now, if you're in a case like this where the type actually varies, the easiest way is using is
:
if(base is Child2) // cast and do something
Alternatively, there's a slightly heavier approach using as?
. Note that this will add a nullable type; if the cast fails, you get null:
val child2 = base as? Child2 ?: TODO("Cast failed");
You also added some code; in your examples, you will always be able to cast a Button as a TextView or View, and the TextView can be cast as a View. However, if you cast a View as a TextView or a Button, it will fail because the type isn't the same.
TL;DR:
A View isn't a Button. For your code to work, use val v: View = Button()
, and then cast. v
can only be cast as a child if the instance that's declared as a parent type actually is the specified child. You can also use is
to check if the type is a match before you cast, or use as?
to get null if it fails.
You can also take a look at this article from Oracle on types and inheritance.
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
add a comment |
as
is the keyword for casting in Kotlin. Example: someInstance as CastTarget
. The Java equivalent is (CastTarget) someInstance
. These are usually language-specific, but some languages have the same syntax for it. C++ has the same syntax as Java (although it has an extra one as well, but that's beside the point).
Buttons extend View. Which means, a button is a View. However, this does not imply a View is a button. A View can also be a TextView, ListView, RecyclerView, etc. There's a long list of Views, and there's also libraries that add more.
This means this is valid:
val view: View = Button(...)
val btn = view as Button
This works because the view is, in this case, a Button. However, if you have:
val view: View = RecyclerView(...)
val btn = view as Button
it will fail. This is because, for pretty obvious reasons in this case, a RecyclerView isn't a button. The reason View(...) as Button
fails is because a View isn't a button either. When you cast, you can only cast an instance as itself, or a parent, but not a child class. Here's an actual example:
interface Base
class Parent : Base
class Child1 : Parent()
class Child11 : Child1()
class Child2 : Parent()
Now, in this case, the classes are useless. They don't do anything, but they can still be used to demonstrate inheritance and casting.
Now, say you have this:
val base = getRandomBaseChild()
Does that imply you have a Child2
? The inferred type here would be Base
, which means it can be any class (or interface, since Base is an interface) that extends/implements Base. It doesn't have to be a Child2, but it can be. Since the method in this case would be random, this would fail some times, but not always:
val child2 = base as Child2
This is because the base will in some cases actually be a Child2. But for any of the other instances, it isn't Child2.
Say we took Child1 instead:
val child1 = base as Child1
This actually has two valid targets: Child1 and Child11. You can always downcast, but never upcast unless the type matches. With that, you now know this will always succeed:
val obj = base as Any
Because everything is Any
(/Object
in Java). But upcasting won't necessarily succeed unless the type is right.
Now, if you're in a case like this where the type actually varies, the easiest way is using is
:
if(base is Child2) // cast and do something
Alternatively, there's a slightly heavier approach using as?
. Note that this will add a nullable type; if the cast fails, you get null:
val child2 = base as? Child2 ?: TODO("Cast failed");
You also added some code; in your examples, you will always be able to cast a Button as a TextView or View, and the TextView can be cast as a View. However, if you cast a View as a TextView or a Button, it will fail because the type isn't the same.
TL;DR:
A View isn't a Button. For your code to work, use val v: View = Button()
, and then cast. v
can only be cast as a child if the instance that's declared as a parent type actually is the specified child. You can also use is
to check if the type is a match before you cast, or use as?
to get null if it fails.
You can also take a look at this article from Oracle on types and inheritance.
as
is the keyword for casting in Kotlin. Example: someInstance as CastTarget
. The Java equivalent is (CastTarget) someInstance
. These are usually language-specific, but some languages have the same syntax for it. C++ has the same syntax as Java (although it has an extra one as well, but that's beside the point).
Buttons extend View. Which means, a button is a View. However, this does not imply a View is a button. A View can also be a TextView, ListView, RecyclerView, etc. There's a long list of Views, and there's also libraries that add more.
This means this is valid:
val view: View = Button(...)
val btn = view as Button
This works because the view is, in this case, a Button. However, if you have:
val view: View = RecyclerView(...)
val btn = view as Button
it will fail. This is because, for pretty obvious reasons in this case, a RecyclerView isn't a button. The reason View(...) as Button
fails is because a View isn't a button either. When you cast, you can only cast an instance as itself, or a parent, but not a child class. Here's an actual example:
interface Base
class Parent : Base
class Child1 : Parent()
class Child11 : Child1()
class Child2 : Parent()
Now, in this case, the classes are useless. They don't do anything, but they can still be used to demonstrate inheritance and casting.
Now, say you have this:
val base = getRandomBaseChild()
Does that imply you have a Child2
? The inferred type here would be Base
, which means it can be any class (or interface, since Base is an interface) that extends/implements Base. It doesn't have to be a Child2, but it can be. Since the method in this case would be random, this would fail some times, but not always:
val child2 = base as Child2
This is because the base will in some cases actually be a Child2. But for any of the other instances, it isn't Child2.
Say we took Child1 instead:
val child1 = base as Child1
This actually has two valid targets: Child1 and Child11. You can always downcast, but never upcast unless the type matches. With that, you now know this will always succeed:
val obj = base as Any
Because everything is Any
(/Object
in Java). But upcasting won't necessarily succeed unless the type is right.
Now, if you're in a case like this where the type actually varies, the easiest way is using is
:
if(base is Child2) // cast and do something
Alternatively, there's a slightly heavier approach using as?
. Note that this will add a nullable type; if the cast fails, you get null:
val child2 = base as? Child2 ?: TODO("Cast failed");
You also added some code; in your examples, you will always be able to cast a Button as a TextView or View, and the TextView can be cast as a View. However, if you cast a View as a TextView or a Button, it will fail because the type isn't the same.
TL;DR:
A View isn't a Button. For your code to work, use val v: View = Button()
, and then cast. v
can only be cast as a child if the instance that's declared as a parent type actually is the specified child. You can also use is
to check if the type is a match before you cast, or use as?
to get null if it fails.
You can also take a look at this article from Oracle on types and inheritance.
edited Dec 27 '18 at 15:52
answered Dec 27 '18 at 15:38
data:image/s3,"s3://crabby-images/a1a9a/a1a9a7c16ebbf1e88f27c7bd5adee868faf9b67d" alt=""
data:image/s3,"s3://crabby-images/a1a9a/a1a9a7c16ebbf1e88f27c7bd5adee868faf9b67d" alt=""
Zoe
11.1k73675
11.1k73675
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
add a comment |
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
Thank You very much for this very detailed answer. I appreciate it.
– Diego Perdomo
Dec 27 '18 at 17:21
add a comment |
In Kotlin, as
is a type cast operator.
val b = v as Button
's equivalent in Java (ignore the null check) is
Button b = (Button) v;
Besides, listener
in the first piece of code is not used.
For your second piece of code, Button
is surely a View
, but something that is a View
may not a Button
. If you try to cast a View
which is not actually a Button
, you will get that cast exception.
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
add a comment |
In Kotlin, as
is a type cast operator.
val b = v as Button
's equivalent in Java (ignore the null check) is
Button b = (Button) v;
Besides, listener
in the first piece of code is not used.
For your second piece of code, Button
is surely a View
, but something that is a View
may not a Button
. If you try to cast a View
which is not actually a Button
, you will get that cast exception.
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
add a comment |
In Kotlin, as
is a type cast operator.
val b = v as Button
's equivalent in Java (ignore the null check) is
Button b = (Button) v;
Besides, listener
in the first piece of code is not used.
For your second piece of code, Button
is surely a View
, but something that is a View
may not a Button
. If you try to cast a View
which is not actually a Button
, you will get that cast exception.
In Kotlin, as
is a type cast operator.
val b = v as Button
's equivalent in Java (ignore the null check) is
Button b = (Button) v;
Besides, listener
in the first piece of code is not used.
For your second piece of code, Button
is surely a View
, but something that is a View
may not a Button
. If you try to cast a View
which is not actually a Button
, you will get that cast exception.
answered Dec 27 '18 at 15:24
Geno Chen
1,1782719
1,1782719
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
add a comment |
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
Thank You very much!
– Diego Perdomo
Dec 27 '18 at 17:22
add a comment |
This is basic java concept. If you carefully read the exception documentation.
Thrown to indicate that the code has attempted to cast an object to a subclass of which it is not an instance.
In simple words, parent class object(v) can only be typecast to child class type(Button) if it holds the child class object instance.
so Correct code would be
val v: View = Button()
val b = v as Button
b.c()
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
add a comment |
This is basic java concept. If you carefully read the exception documentation.
Thrown to indicate that the code has attempted to cast an object to a subclass of which it is not an instance.
In simple words, parent class object(v) can only be typecast to child class type(Button) if it holds the child class object instance.
so Correct code would be
val v: View = Button()
val b = v as Button
b.c()
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
add a comment |
This is basic java concept. If you carefully read the exception documentation.
Thrown to indicate that the code has attempted to cast an object to a subclass of which it is not an instance.
In simple words, parent class object(v) can only be typecast to child class type(Button) if it holds the child class object instance.
so Correct code would be
val v: View = Button()
val b = v as Button
b.c()
This is basic java concept. If you carefully read the exception documentation.
Thrown to indicate that the code has attempted to cast an object to a subclass of which it is not an instance.
In simple words, parent class object(v) can only be typecast to child class type(Button) if it holds the child class object instance.
so Correct code would be
val v: View = Button()
val b = v as Button
b.c()
answered Dec 27 '18 at 15:30
data:image/s3,"s3://crabby-images/64d0b/64d0bd8e4b63cf6e87efe4b1253fecdaa362f3c2" alt=""
data:image/s3,"s3://crabby-images/64d0b/64d0bd8e4b63cf6e87efe4b1253fecdaa362f3c2" alt=""
Vipul Shah
27.1k65779
27.1k65779
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
add a comment |
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
Thank You very much! I am a complete noob with Kotlin and typed languages in general because i came from the javascript world. I finally understand well! :)
– Diego Perdomo
Dec 27 '18 at 16:50
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
That's great! Make sure to close questions by accepting any answer that you find helpful.
– Vipul Shah
Dec 27 '18 at 17:20
add a comment |
Since this problem is not Android-specific, let's create a minimal example.
Consider the following inheritance hierarchy, where we have a Fruit with two subclasses Apple
and Banana
:
open class Fruit
class Apple: Fruit()
class Banana: Fruit()
Let's do some testing with the safe cast operator as? which returns null
if the cast fails:
val fruit = Fruit()
fruit as? Apple // returns null - fruit is not of type Apple
val apple = Apple()
apple as? Fruit // apple is a Fruit
apple as? Banana // returns null - apple is not a Banana
If you create a Fruit
it is neither an Apple
nor a Banana
. Just a fruit in general.
If you create an Apple
, it is a Fruit
because Fruit
is its super class, but an Apple
is not related to Banana
.
add a comment |
Since this problem is not Android-specific, let's create a minimal example.
Consider the following inheritance hierarchy, where we have a Fruit with two subclasses Apple
and Banana
:
open class Fruit
class Apple: Fruit()
class Banana: Fruit()
Let's do some testing with the safe cast operator as? which returns null
if the cast fails:
val fruit = Fruit()
fruit as? Apple // returns null - fruit is not of type Apple
val apple = Apple()
apple as? Fruit // apple is a Fruit
apple as? Banana // returns null - apple is not a Banana
If you create a Fruit
it is neither an Apple
nor a Banana
. Just a fruit in general.
If you create an Apple
, it is a Fruit
because Fruit
is its super class, but an Apple
is not related to Banana
.
add a comment |
Since this problem is not Android-specific, let's create a minimal example.
Consider the following inheritance hierarchy, where we have a Fruit with two subclasses Apple
and Banana
:
open class Fruit
class Apple: Fruit()
class Banana: Fruit()
Let's do some testing with the safe cast operator as? which returns null
if the cast fails:
val fruit = Fruit()
fruit as? Apple // returns null - fruit is not of type Apple
val apple = Apple()
apple as? Fruit // apple is a Fruit
apple as? Banana // returns null - apple is not a Banana
If you create a Fruit
it is neither an Apple
nor a Banana
. Just a fruit in general.
If you create an Apple
, it is a Fruit
because Fruit
is its super class, but an Apple
is not related to Banana
.
Since this problem is not Android-specific, let's create a minimal example.
Consider the following inheritance hierarchy, where we have a Fruit with two subclasses Apple
and Banana
:
open class Fruit
class Apple: Fruit()
class Banana: Fruit()
Let's do some testing with the safe cast operator as? which returns null
if the cast fails:
val fruit = Fruit()
fruit as? Apple // returns null - fruit is not of type Apple
val apple = Apple()
apple as? Fruit // apple is a Fruit
apple as? Banana // returns null - apple is not a Banana
If you create a Fruit
it is neither an Apple
nor a Banana
. Just a fruit in general.
If you create an Apple
, it is a Fruit
because Fruit
is its super class, but an Apple
is not related to Banana
.
answered 16 hours ago
Willi Mentzel
8,371114468
8,371114468
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53947167%2fkotlin-class-cast-exception%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
K,bH JZ8ye,kaHThX,BxR,xc djASRRpHIqAPEyt7CrZ CBn0,ihF BYgzTIv7mZAr jNuT,bJ 6n1zPF3hi utuqHs0dh6,Vl,ytgLDjIM K7IO1I4