Discussions
Categories
- 196.7K All Categories
- 2.2K Data
- 235 Big Data Appliance
- 1.9K Data Science
- 449.8K Databases
- 221.5K General Database Discussions
- 3.8K Java and JavaScript in the Database
- 31 Multilingual Engine
- 549 MySQL Community Space
- 477 NoSQL Database
- 7.9K Oracle Database Express Edition (XE)
- 3K ORDS, SODA & JSON in the Database
- 532 SQLcl
- 4K SQL Developer Data Modeler
- 186.8K SQL & PL/SQL
- 21.3K SQL Developer
- 295.4K Development
- 17 Developer Projects
- 138 Programming Languages
- 292.1K Development Tools
- 104 DevOps
- 3.1K QA/Testing
- 645.9K Java
- 28 Java Learning Subscription
- 37K Database Connectivity
- 153 Java Community Process
- 105 Java 25
- 22.1K Java APIs
- 138.1K Java Development Tools
- 165.3K Java EE (Java Enterprise Edition)
- 17 Java Essentials
- 158 Java 8 Questions
- 85.9K Java Programming
- 79 Java Puzzle Ball
- 65.1K New To Java
- 1.7K Training / Learning / Certification
- 13.8K Java HotSpot Virtual Machine
- 94.2K Java SE
- 13.8K Java Security
- 203 Java User Groups
- 24 JavaScript - Nashorn
- Programs
- 394 LiveLabs
- 37 Workshops
- 10.2K Software
- 6.7K Berkeley DB Family
- 3.5K JHeadstart
- 5.6K Other Languages
- 2.3K Chinese
- 170 Deutsche Oracle Community
- 1.1K Español
- 1.9K Japanese
- 230 Portuguese
Why does DoubleProperty implement Property<Number> and not Property<Double>?

I am asking because it seems to be a bit inconvenient when implementing ChangeListeners.
For example,
slider.valueProperty().addListener((property, oldValue, newValue) -> message.setFont(new Font(newValue)));
does not work. I invite you find out the reason from the error message:
error: no suitable method found for addListener((property,[...]lue)))
slider.valueProperty().addListener((property, oldValue, newValue)
^
method Observable.addListener(InvalidationListener) is not applicable
(argument mismatch; incompatible parameter types in lambda expression)
method ObservableValue.addListener(ChangeListener<? super Number>) is not applicable
(argument mismatch; cannot type-check lambda expression with inferred parameter types
inferred types: ObservableValue<? extends Number>,Number,Number)
That's actually bogus. newValue is inferred to be Number, and Number doesn't auto-unbox. This works:
slider.valueProperty().addListener((property, oldValue, newValue) -> message.setFont(new Font(newValue.doubleValue())));
So, that's all rather obscure. What was gained by having DoubleProperty implement Property<Number> and not Property<Double>?
Thanks,
Cay
Answers
-
This is the way it was done in previous version of FX to simplify the FX code and avoid tons of duplicated code. We've tried to fix this, but it was too late, as the cost of backward incompatibility was too hight.
You can however use conversion methods to achieve this. Like this:
slider.valueProperty().asObject().addListener(...)