• jayrhacker@kbin.social
    link
    fedilink
    arrow-up
    52
    arrow-down
    3
    ·
    11 months ago

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

      • Glome@feddit.nl
        link
        fedilink
        arrow-up
        2
        ·
        11 months ago

        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.

        • kaba0@programming.dev
          link
          fedilink
          arrow-up
          1
          ·
          11 months ago

          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

        • LeFantome@programming.dev
          link
          fedilink
          arrow-up
          1
          ·
          11 months ago

          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?

        • kaba0@programming.dev
          link
          fedilink
          arrow-up
          1
          ·
          11 months ago

          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)

  • korstmos@kbin.social
    link
    fedilink
    arrow-up
    41
    arrow-down
    1
    ·
    11 months ago

    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)

      • whats_a_refoogee@sh.itjust.works
        link
        fedilink
        arrow-up
        3
        ·
        11 months ago

        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).

      • korstmos@kbin.social
        link
        fedilink
        arrow-up
        3
        ·
        11 months ago

        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 (?)

    • parlaptie@feddit.de
      link
      fedilink
      arrow-up
      1
      arrow-down
      1
      ·
      11 months ago

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

  • maniacal_gaff@lemmy.world
    link
    fedilink
    arrow-up
    29
    arrow-down
    1
    ·
    11 months ago

    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?

      • snake_baitman@lemmy.sdf.org
        link
        fedilink
        arrow-up
        10
        ·
        11 months ago

        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

    • baseless_discourse@mander.xyz
      link
      fedilink
      arrow-up
      2
      arrow-down
      2
      ·
      11 months ago

      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.

  • Rev@ihax0r.com
    cake
    link
    fedilink
    English
    arrow-up
    25
    ·
    11 months ago

    python is like this also. I don’t remember a language that returned ints

  • Marek Knápek@programming.dev
    link
    fedilink
    arrow-up
    7
    ·
    11 months ago

    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.

      • 1rre@discuss.tchncs.de
        link
        fedilink
        arrow-up
        3
        arrow-down
        1
        ·
        11 months ago

        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

  • MrGeekman@lemmy.world
    link
    fedilink
    English
    arrow-up
    2
    ·
    11 months ago

    Try Math.round. It’s been like ten years since I used Java, but I’m pretty sure it’s in there.

  • Aelorius@jlai.lu
    link
    fedilink
    arrow-up
    2
    ·
    11 months ago

    Logic, in math, if you have a real and you round it, it’s always a real not an integer. If we follow your mind with abs(-1) of an integer it should return a unsigned and that makes no sense.

    • Kogasa@programming.dev
      link
      fedilink
      arrow-up
      2
      ·
      11 months ago

      in math, if you have a real and you round it, it’s always a real not an integer.

      No, that’s made up. Outside of very specific niche contexts the concept of a number having a single well-defined type isn’t relevant in math like it is in programming. The number 1 is almost always considered both an integer and a real number.

      If we follow your mind with abs(-1) of an integer it should return a unsigned and that makes no sense.

      How does that not make sense? abs is always a nonnegative integer value, why couldn’t it be an unsigned int?

  • Bappity@lemmy.world
    link
    fedilink
    English
    arrow-up
    5
    arrow-down
    20
    ·
    11 months ago

    the programming language Java meaning coffee is perfect because, like coffee, it tastes like shit but gets the job done

    • MrGeekman@lemmy.world
      link
      fedilink
      English
      arrow-up
      11
      ·
      11 months ago

      I think you need to try some lighter-roasted, higher-quality beans which were roasted fairly recently and only grind them a day or so before you use them. There are also different brewing methods and coffee/water ratios that you can try.

      • mestari@lemmy.world
        link
        fedilink
        arrow-up
        2
        ·
        11 months ago

        I love and consume lots of coffee but I sincerely believe it only tastes good because I associate the taste with the boost it gives. Exactly like cigarettes taste tolerable, good even, when you smoke them regularly.