105 points

Makes sense, cause double can represent way bigger numbers than integers.

permalink
report
reply
33 points

Also, double can and does in fact represent integers exactly.

permalink
report
parent
reply
19 points

Only to 2^54. The amount of integers representable by a long is more. But it can and does represent every int value correctly

permalink
report
parent
reply
-1 points

*long long, if we’re gonna be taking about C types. A long is commonly limited to 32 bits.

permalink
report
parent
reply
27 points

Also because if you are dealing with a double, then you’re probably dealing with multiple, or doing math that may produce a double. So returning a double just saves some effort.

permalink
report
parent
reply
9 points

Yeah it makes sense to me. You can always cast it if you want an int that bad. Hell just wrap the whole function with your own if it means that much to you

(Not you, but like a hypothetical person)

permalink
report
parent
reply
5 points
*
Deleted by creator
permalink
report
parent
reply
2 points

A double could also be NaN and any operations with NaN should return NaN afaik

permalink
report
parent
reply
2 points

A double can represent numbers up to ± 1.79769313486231570x10^308, or roughly 18 with 307 zeroes behind it. You can’t fit that into a long, or even 128 bits. Even though rounding huge doubles is pointless, since only the first dozen digits or so are saved, using any kind of Integer would lead to inconsistencies, and thus potentially bugs.

permalink
report
parent
reply
2 points

doubles can hold numbers way larger than even 64-bit ints

permalink
report
parent
reply
1 point

How does that work? Is it just because double uses more bits? I’d imagine for the same number of bits, you can store more ints than doubles (assuming you want the ints to be exact values).

permalink
report
parent
reply
3 points
5 points
*

No, I get that. I’m sure the programming language design people know what they are doing. I just can’t grasp how a double (which has to use at least 1 bit to represent whether or not there is a fractional component) can possibly store more exact integer vales than an integer type of the same length (same number of bits).

It just seems to violate some law of information theory to my novice mind.

permalink
report
parent
reply
67 points

It’s the same in the the standard c library, so Java is being consistent with a real programming language…

permalink
report
reply
24 points

Implying java isn’t a real programming language. Smh my head.

permalink
report
parent
reply
6 points

Java has many abstractions that can be beneficial in certain circumstances. However, it forces a design principle that may not work best in every situation.

I.e. inheritance can be both unnatural for the programmer to think in, and is not representative of how data is stored and manipulated on a computer.

permalink
report
parent
reply
10 points

You don’t have to use inheritance with Java. In fact, in most cases it’s better that you don’t. Practically all of the Java standard library doesn’t require the use of inheritance, same with most modern libraries.

On the contrary, I think inheritance is a very natural way to think. However, that doesn’t translate into readable and easy to maintain code in the vast majority of the cases.

I am not sure what you mean by how it’s stored or manipulated on a computer. A garbage collected language like Java manages the memory for you. It doesn’t really care if your code is using inheritance or not. And unless you’re trying to squeeze the last drops of performance out of your code, the memory layout shouldn’t be on your mind.

permalink
report
parent
reply
4 points

We’re gate-keeping the most mainstream programming language now? Next you’ll say English isn’t a real language because it doesn’t have a native verb tense to express hearsay.

permalink
report
parent
reply
1 point

And it is not forced at all. Noone holds a gun to your head to write extends. “Favor composition over inheritance” has been said as a mantra for at least a decade

permalink
report
parent
reply
5 points

Java is, of course, Turing Complete™️ but when you have to hide all the guns and knives in jdk.internal.misc.Unsafe something is clearly wrong.

permalink
report
parent
reply
1 point

I do not like Java but this is a strange argument. The people that invented Java felt that most of the C language should be wrapped in unsafe.

Opinions can vary but saying Java is not a real language is evidence free name calling. One could just as easily say that any language that does not allow you to differentiate between safe and unsafe baheviour is incomplete and not a “real” language. It is not just the Java and C# people that may say this. As a C fan, I am sure you have heard Rust people scoff at C as a legacy language that was fine for its day but clearly outclassed now that the “real” languages have arrived. Are you any more correct than they are?

permalink
report
parent
reply
1 point

Memory is an implementation detail. You are interested in solving problems, not pushing bytes around, unless that is the problem itself. In 99% of the cases though, you don’t need guns and knives, it’s not a US. school (sorry)

permalink
report
parent
reply
1 point

Nice ATM machine.

permalink
report
parent
reply
4 points

Smhmh my head

permalink
report
parent
reply
1 point
*
Deleted by creator
permalink
report
parent
reply
50 points

Doubles have a much higher max value than ints, so if the method were to convert all doubles to ints they would not work for double values above 2^31-1.

(It would work, but any value over 2^31-1 passed to such a function would get clamped to 2^31-1)

permalink
report
reply
8 points

So why not return a long or whatever the 64 bit int equivalent is?

permalink
report
parent
reply
5 points

To avoid a type conversion that might not be expected. Integer math in Java differs from floating point math.

Math.floor(10.6) / Math.floor(4.6) = 2.5 (double)

If floor returned a long, then

Math.floor(10.6) / Math.floor(4.6) = 2 (long)

If your entire code section is working with doubles, you might not like finding Math.floor() unexpectedly creating a condition for integer division and messing up your calculation. (Have fun debugging this if you’re not actively aware of this behavior).

permalink
report
parent
reply
4 points

Because even a long (64-bit int) is too small :)
A long can hold 2^64-1 = 1.84E19
A double can hold 1.79E308

Double does some black magic with an exponent, and can hold absolutely massive numbers!

Double also has some situations that it defines as “infinity”, a concept that does not exist in long as far as I know (?)

permalink
report
parent
reply
4 points

But there’s really no point in flooring a double outside of the range where integers can be represented accurately, is there.

permalink
report
parent
reply
2 points

what about using two ints

permalink
report
parent
reply
6 points

What about two int64_t

permalink
report
parent
reply
3 points

yeah that would be pretty effective. could also go to three just to be safe

permalink
report
parent
reply
2 points

A BigDecimal?

permalink
report
parent
reply
37 points

Makes sense, how would you represent floor(1e42) or ceil(1e120) as integer? It would not fit into 32bit (unsigned) or 31bit (signed) integer. Not even into 64bit integer.

permalink
report
reply
7 points

BigInt (yeah, not native everywhere)

permalink
report
parent
reply
3 points

I feel this is worse than double though because it’s a library type rather than a basic type but I guess ceil and floor are also library functions unlike toInt

permalink
report
parent
reply
31 points

It would be kinda dumb to force everyone to keep casting back to a double, no? If the output were positive, should it have returned an unsigned integer as well?

permalink
report
reply
15 points

int coerces to double automatically, without explicit casting

permalink
report
parent
reply
18 points

The CPU has to do real work to convert between float and int types. Returning an int type would just be giving the CPU extra work to do for no reason

permalink
report
parent
reply
3 points

I’m learning so much from this thread and I don’t even use Java

permalink
report
parent
reply
2 points

I think one of the main reason to use floor/ceilling is to predictably cast a double into int. This type signature kind of defeats this important purpose.

I don’t know this historical context of java, but possibly at that time, people see type more of a burden than a way to garentee correctness? (which is kind of still the case for many programmers, unfortunately.

permalink
report
parent
reply
14 points
*

You wouldn’t need floor/ceil for that. Casting a double to an int is already predictable as the java language spec explicitly says how to do it, so any JVM will do this the exact same way.

The floor/ceil functions are simply primitive math operations and they are meant to be used when doing floating point math.

All math functions return the same type as their input parameters, which makes sense. The only exception are those that are explicitly meant for converting between types.

permalink
report
parent
reply
2 points
*

“predictable” in the sense that people know how it works regardless what language they know.

I guess I mean “no surprise for the reader”, which is more “readability” than “predictability”

permalink
report
parent
reply

Programmer Humor

!programmer_humor@programming.dev

Create post

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

  • Keep content in english
  • No advertisements
  • Posts must be related to programming or programmer topics

Community stats

  • 7.1K

    Monthly active users

  • 952

    Posts

  • 36K

    Comments