It seems like there are about 22 27 46 219 320 493 1840 active subscribers here. I have a few questions for you all.

  • Which programming languages do you regularly use?
  • Which are your favorite to work with and why?
  • Which do you have interest in trying and why?
  • Gaywallet (they/it)@beehaw.org
    link
    fedilink
    arrow-up
    7
    ·
    2 years ago

    It’s not really a coding language but I use SQL a lot for work. Occasionally Python and R. As you can probably imagine with this list, I’m a data scientist.

    My favorite to work with is actually autohotkey, which I use to automate stuff, because it can be a fun little challenge to figure out how to automate based on the system it’s running on and what I’m trying to do.

    • ericjmorey@beehaw.orgOP
      link
      fedilink
      arrow-up
      3
      ·
      2 years ago

      Funny how you said SQL Python and R, my mind immediately said data analysis.

      I’m not sure what autohotkey is or does. Is it Windows only?

      • YuzuDrink@beehaw.org
        link
        fedilink
        arrow-up
        2
        ·
        2 years ago

        AHK is a powerful scripting runtime for Windows, yeah. I use it to create custom media hotkeys when using a keyboard that doesn’t have actual media keys built in. But that probably the smallest tip-of-the-iceberg of what it can do.

        I had to convince IT to let me keep it installed because it CAN be used by bad actors with how powerful it is. But it’s not too different from what any program on Windows could do; just makes a lot of basic things VERY easy.

  • Neuromancer
    link
    fedilink
    arrow-up
    6
    ·
    edit-2
    2 years ago
    • Prehistoric C++: Core language for my main project at work. Unfortunately we’re stuck with C++98, but it’s still a massive improvement on C.
    • C: For some of the older parts of the aforementioned project
    • Python: For test automation for the aforementioned project, also rapidly becoming the main language within the community that covers my secondary work project. I used to really not care for Python, but to the extent it displaces MATLAB I’m 100% in favor of it. I’ve also grown to really like it in the test automation role. The only thing I could wish for is that it had a mode that required type hints across the board.
    • Modern C++: Used for my other work project. While I do think that C++11 is a huge step up from C++98, I think the later standards have added a lot of cruft and very little value. Given the choice I would definitely take modern C++ over C++98, but I’d really rather be writing something like Rust
    • Java: This was a mistake I made years ago when I started a project as a very junior developer. Unfortunately I work in a research context where even as the junior developer I was still the most experienced developer on the team when it came to some things. We needed a REST API for this project and doing it in C++ didn’t seem feasible at the time (no idea if it’s better now). Some other teams in my org where using Spring so I jumped on that bandwagon. In hindsight, I wish I had written the API in Python since we’re slowly moving a lot of our C++ code into Python on that project now.
    • Shell: For automation that’s just a little too easy to bother with Python
    • Rust: Only used on hobby projects for now, but it scratches the same itch as C++ a thousand times better. The language itself is wonderful once you get used to the borrow checker and cargo is an incredibly valuable part of the ecosystem as well.
  • Mistress Remilia@beehaw.org
    link
    fedilink
    arrow-up
    6
    ·
    edit-2
    2 years ago

    Regularly use: Common Lisp (SBCL mainly) and Crystal.

    Favorite to work with: same as above. They seem to match how I think well, so it’s easy to solve problems in them. Their speed is also a nice bonus, as is Common Lisp’s debugging and image-based development. I also really like how Crystal feels like a dynamic language (it’s very reminiscent of Ruby), yet is still statically typed and compiled.

    Interest in trying: m68k assembly for some ungodly reason lol

    • ericjmorey@beehaw.orgOP
      link
      fedilink
      arrow-up
      3
      ·
      2 years ago

      You’re in the lead for the most unexpected reply. I didn’t know that Crystal had any industry use. I didn’t know mIuch about it though. I simply knew it existed.

      I prefer to keep assembly behind the compilers it might as well be flipping individual bits to me.

  • HalJor@beehaw.org
    link
    fedilink
    arrow-up
    6
    ·
    2 years ago

    Favorite: Ruby, because everything makes sense. Once you get that “everything is an object”, the rest just falls naturally into place. No other language has been so intuitive from that point.

    Regularly use: JavaScript. I hate it because absolutely nothing makes sense. I don’t even understand enough to explain more than that, yet somehow I’m able to copy/paste things that do work and tweak them enough until they do what I want. At least some of the time.

  • AbelianGrape@beehaw.org
    link
    fedilink
    arrow-up
    5
    ·
    edit-2
    2 years ago

    I teach a class taught in OCaml. Despite that, I don’t really like OCaml. It’s good for education but IMO not that great for actually using it. My brother works at Jane Street and even he agrees… Like, it’s fine, but not great.

    Beyond that I make regular use of Haskell and Python for my graduate research and personal projects. I recently took a course in Java, but unless I don’t have a choice, I’d rather use Kotlin. I’m also involved in the hardware simulator Turing Complete, so a lot of my side projects lately have been ETCa assembly programs.

    I want to learn Rust and Scala, probably in that order.

    • ericjmorey@beehaw.orgOP
      link
      fedilink
      arrow-up
      2
      ·
      2 years ago

      I don’t really like OCaml. It’s good for education but IMO not that great for actually using it. My brother works at Jane Street and even he agrees… Like, it’s fine, but not great.

      I don’t get to converse with a lot of OCaml users. What makes it “not great”? Is it the tooling?

      What is your graduate work on?

      • AbelianGrape@beehaw.org
        link
        fedilink
        arrow-up
        2
        ·
        2 years ago

        The tooling is actually OK, provided you work on Linux. If you work on windows, the tooling is basically telling you to go get Linux.

        It doesn’t capture a lot of what many functional programmers consider the essence of FP: the language, and the people who use it, actively encourage mutable state in programs, and the type system is not powerful enough to capture useful abstractions like functors (generalized containers) or monads (generalized patterns of computation).

        There are also some specific language design decisions that I don’t like. For example, this code typechecks:

        let id : 'a -> 'b = fun x -> x;;
        

        The 'a -> 'b is a type annotation that says “you give me anything of type 'a (a type variable), and I’ll give you back something of type 'b.” That’s complete bogus - that’s not possible. It typechecks because OCaml goes “OK, this is fine as long as 'a and 'b are the same variable,” and then for the rest of the typechecking process, that’s what happens. id actually gets assigned the type 'a -> 'a. In the best case, this is confusing and occasionally useful to do what other languages do with “type holes.” In the worst case, it’s actively wrong. Using different type variables in a type can provide static guarantees that some things cannot mix, and with OCaml that is simply not possible for a declaration like this one. You can do it, but with a lot more boilerplate. Compare that to Haskell, where the right behavior is the default, and you can obtain a type hole just by using a variable name that starts with _.

        My graduate work is currently on type error provenance. You know some piece of code has a type error, but where is the actual problem? This is a hard problem that compilers are notoriously bad at answering.

  • YuzuDrink@beehaw.org
    link
    fedilink
    arrow-up
    4
    ·
    2 years ago

    At work, I use both Python and C++. At home I also try to use Rust where I can; but mostly C++, Python, and C# (largely for game engines)

  • xan@lemmy.one
    link
    fedilink
    English
    arrow-up
    4
    ·
    2 years ago

    For work: PHP, Ruby, JavaScript (Svelte, Vue), CSS (debatable on if it’s a prog lang) For fun: Swift.

  • Hexorg@beehaw.orgM
    link
    fedilink
    arrow-up
    4
    ·
    2 years ago

    I regularly use Python, C++, and Java. My favorite are Rust, C, and assembly I want to try Haskell because it looks like pythoned rust. Yes I know Haskell is OG complex typing system, but I learned Rust and Python first.

    • ericjmorey@beehaw.orgOP
      link
      fedilink
      arrow-up
      2
      ·
      2 years ago

      If you don’t need manual memory management, Haskell seems like a strong option for wrangle complexity.

  • climufat@beehaw.org
    link
    fedilink
    arrow-up
    4
    ·
    2 years ago

    At work it’s mostly python, .net core and javascript (regrettably).

    Personally, I used to write a lot in C and C++ for embedded, but recently diving more into other areas. Developing quite the love for Golang (GO) and it’s simplicity.

  • 1rre@lemmy.org.uk
    link
    fedilink
    arrow-up
    4
    ·
    2 years ago

    I work with C# & TypeScript, which frankly I don’t find too bad

    I love to work with Scala though, I find there’s a really nice way to do almost everything, and C is nice because it allows so much control over what your program is actually doing - same with OCaml really, however the ability to use Java libraries in Scala makes it that bit better

    I’d quite like to try Spatial for hardware in the future

  • greysemanticist@lemmy.one
    link
    fedilink
    English
    arrow-up
    3
    ·
    edit-2
    2 years ago

    Regularly Use

    • bash
    • python
    • golang
    • rust

    Favorite

    • rust because it provides a pretty good expressive type system for letting the compiler keep you honest.

    Interested

    • zig because of its promise of “compile it for anything” and small language philosophy.
  • Towerism@beehaw.org
    link
    fedilink
    arrow-up
    3
    ·
    2 years ago

    Mainly JavaScript, typescript, html, and scss. Occasionally bash and groovy. My favorite to work with is typescript. It’s a superset of JavaScript so naturally JavaScript is a very close second. I am interested in ruby and rust. Just because those are the two languages that I have been enamored with in the past so they are the ones that I have spent more free time than any other learning about them and using them for side projects.

  • r3d5un
    link
    fedilink
    arrow-up
    3
    ·
    2 years ago

    Python and C# for the most part. I’m also putting serious effort towards learning Rust, but I likely won’t be able to use it at work. It’s a good learning experience, and I can tell that my code after learning basic Rust in C# and Python is better than before.

      • r3d5un
        link
        fedilink
        arrow-up
        1
        ·
        2 years ago

        The “correctness” of my code would probably the greatest single difference I’ve noticed in my own habits.

        For example, I’ve become very strict with myself about using type hints and relying on appeasing type checkers and such. The way I structure my projects has changed, where I separate functionality from data to a larger degree, mimicking struct and impl where it makes sense to do so. I’ve pretty much stopped using dict, and rely on dataclasses instead when writing Python. I’ve given up on forcing everything to be OOP (even C#), which has made my code easier to read and maintain. There are probably other things as well, though I can’t list them at the top of my head.

        Some of it is probably just good practice, a result of having matured after being exposed to new languages. Some of it probably wouldn’t be considered pythonic or idiomatic, but I’m not sure I care anymore. My code is more reliable (and often faster), and that’s what matter in the end.

  • neosheo@beehaw.org
    link
    fedilink
    arrow-up
    3
    ·
    2 years ago

    I use python mainly because thats what i learned programming with. I like the bracketless design, no need to track down unclosed bracks/parenthesis plus its versatile and can do most anything.

    Other the python the other one i mainly use is bash. I know JS and C but don’t really use them much.

    I want to learn more C just because Im interested in diving deeper into how memory is managed but just havent found a suitable project to start using it for.

    Ive been learning a lot of web design and want to get back into JS because i wanna start doing frontend, since i mostly know backend.

    That being said i’m also interested in php because i think it’s cool that i could run a script directly on the backend without an api

  • PM_ME_VINTAGE_30S@vlemmy.net
    link
    fedilink
    arrow-up
    3
    ·
    2 years ago

    I most regularly use Python, followed by MATLAB C++. Python has been practically mandatory for writing code for my undergrad research. My classmates usually know “a little” Python, and it’s pretty easy to pick up on the fly. I’m trying to phase out MATLAB for Python seeing as I’ll be graduating soon and my student license will run out. I know about Octave, but work done in Python is probably easier to integrate.

    My favorite is C++. It’s the first language I learned and it feels like home. It gives me enough abstractions to get actual work done, but it also has the low-level tools I need to shoot myself in the foot for working with Arduino or other microcontrollers.

    I’m looking into Rust for audio programming. Although audio programming is done almost exclusively in C++ these days, Rust’s safety features without performance penalties look like a promising language to write fast and reliable code suitable for real-time operation. Joining Lemmy and seeing how it compared to Kbin has cemented my interest in the language because so far, despite the bugs I’ve run into, Lemmy and Jerboa has been fast above all.