I’m currently working on a project in C where I have a choice between using a library for hash tables or simply creating my own hash table from scratch.

What would look better on a Github portfolio from an employability perspective?

  • kersplomp@programming.dev
    link
    fedilink
    arrow-up
    1
    ·
    edit-2
    50 minutes ago

    I disagree with most people here. The interview is the most important thing, so build it from scratch and make your own libraries. You will learn how to design good APIs which will make you infinitely more likely to get hired and promoted too.

  • Feyd@programming.dev
    link
    fedilink
    arrow-up
    4
    ·
    edit-2
    6 hours ago

    I’ve only ever given a cursory look at personal repos when they’re volunteered. I’m most likely to just look at a readme and maybe look at a small section just to see what the style looks like and if any characteristics stand out, then maybe use discussion of the project (with standard topics I ask everyone unless I happened to see something interesting) as a discussion starter.

    In summary, at least from my perspective, I would recommend just doing whatever interests you and being ready to discuss, if you volunteer a project. I also generally think the impact of presenting a portfolio of personal projects tends to be overestimated.

    • Lemminary@lemmy.world
      link
      fedilink
      arrow-up
      1
      ·
      5 hours ago

      I’ve been applying and rarely anyone looks at my stuff. It feels like a huge waste of time but at least I learned a few things along the way.

  • JackbyDev@programming.dev
    link
    fedilink
    English
    arrow-up
    3
    arrow-down
    1
    ·
    6 hours ago

    Think of your projects as a black box. I think it’s rare people look at how they do things. Only what they can do. From that perspective, I think using libraries.

      • morbidcactus@lemmy.ca
        link
        fedilink
        arrow-up
        3
        ·
        5 hours ago

        Unironically yeah, sitting on the other side of the table it’s painfully obvious when people do resume projects. I’d rather talk to you about something you’re passionate about.

        • JackbyDev@programming.dev
          link
          fedilink
          English
          arrow-up
          1
          ·
          edit-2
          3 hours ago

          I mean, the more I think about it, the more I think it might be relevant. They’ve got this very bizarre format (instead of something like JSON) and I wrote a thing to parse it and format it back out.

          The joke being “Prison Architect” (especially as a game) sounds very bizarre to be on a resume.

  • OsrsNeedsF2P@lemmy.ml
    link
    fedilink
    arrow-up
    43
    ·
    edit-2
    2 days ago

    Bad advice in this thread. As someone who spent half a decade building what (was) a quite impressive GitHub (github.com/dginovker), no interviewer or recruiter ever looked at it. This was after ~600 applications.

    I also volunteered to be part of resume screening at two major companies. Not a single person in either company looked at GitHub repos.

    To answer your initial question, use a library. Make cool things, learn good tech that is useful in the real world. You will never have a job where you have to reimplement a hashmap.

    • Vincent@feddit.nl
      link
      fedilink
      arrow-up
      15
      ·
      edit-2
      2 days ago

      Almost my entire career I’ve worked in open source, so it’s very easy to see what my technical work looks like. No one has ever looked at it.

      When I have been on the other side, I have looked at the GitHub “portfolio” of junior applicants, but TBH, it didn’t bring me much. There will always be lots of opportunities for improvements in those examples, but that’s the point - I expect them to improve on the job.

      More experienced developers will almost never have significant work on GitHub, and if they do, it’s not a “portfolio”, but just their past work.

    • Boomkop3@reddthat.com
      link
      fedilink
      arrow-up
      5
      ·
      2 days ago

      Hmm, they’ve looked at mine. But it’s not intended to be impressive, and I’ve switched to self hosting my version control anyways

  • e0qdk@reddthat.com
    link
    fedilink
    arrow-up
    20
    ·
    2 days ago

    I’ve had to review resumes when we were trying to find someone else to bring on the team. My boss dumped hundreds of resumes on me and asked if any of them looked promising – that’s after going through whatever HR bullshit filters were in place – on top of all the other work I was already behind on since we didn’t have enough staff. That is the state of mind you should expect someone to be in while looking at your project.

    If anyone looks at your repo, they’re going to check briefly to see if you have any clue at all what you’re doing and whether your code likes like it’s written by the kind of person they can stand working with. Don’t make any major blunders that someone would notice with a quick glance at the repository. Be prepared to talk about your project in detail and be able to explain why you made the choices you did – you might not get asked, but if you are you should be able to justify your choices. If it gets to the point of an interview and your project looks like something that could’ve been done easily in 100 lines of Python you’d better believe I’m going to ask why the hell you wrote it in C in 2025… and I say that as someone who has written a significant amount of C professionally.

    If you say you have multiple years of professional programming experience and send me a link to a repo that has .DS_Store in it… your resume is going straight into the trash.

  • xtr0n@sh.itjust.works
    link
    fedilink
    arrow-up
    12
    ·
    2 days ago

    If you’re trying to demonstrate real world programming skills then selecting and using an appropriate library is the best move (unless this is an unlikely case where there is some really compelling reason why a custom implementation would be preferable).

    But if you want to make your own hash table for funsies or for educational purposes or whatever, you could add a note or comment stating that, if you’re concerned that prospective employers might get the impression that you will write everything from scratch even when it’s a bad idea.

  • Ephera@lemmy.ml
    link
    fedilink
    English
    arrow-up
    8
    ·
    2 days ago

    Personally (as a dev), I wouldn’t particularly care that you know a specific library (the chance of us using the exact same library is pretty slim and will probably change when the project changes). But I would care to see that you are using a library when it makes sense.

    So, if you implemented a hashtable yourself and I spotted that, I’d remember that as you either not knowing that that’s called a “hashtable”, so you didn’t find a library for it. Or I might think that you’re potentially stuck-up, thinking you can do a better job implementing it yourself.

    The aspects I’d look for, starting with the most important:

    1. Does it seem like you have fun when programming?
      I don’t need you to be writing humorous commit messages, but if it looks like you just specifically coded some portfolio applications three years ago and then never touched them again, that wouldn’t leave a good impression on me.
    2. Do your projects fulfill an actual need and look like they’ve seen real-world use?
      Writing out some example applications is a whole different shtick than actually making it work in the real-world.
    3. Do you have unit tests? Is your commit log clean? Is your project reasonably documented?
      I can teach technologies and architecture, but it’s much harder to teach a drive for good code quality.
    • Feyd@programming.dev
      link
      fedilink
      arrow-up
      1
      ·
      7 hours ago

      I’d think it’s just as likely they reinvented a wheel for fun/learning if I’m looking at a personal project… I also don’t judge hobby projects for absence of unit tests.

      I have used those topics as discussion points after looking at code someone volunteered as it can be very enlightening, but to hold hobby code to a professional standard is kind of nuts tbh.

      • Ephera@lemmy.ml
        link
        fedilink
        English
        arrow-up
        1
        ·
        6 hours ago

        I’m not expecting insane test coverage. What I’m looking for, is that they’ve understood that writing tests makes their (future) life easier, too. A hobby project can benefit from that just as well. I’d argue almost even more so, because you might be working on a feature over the course of several weekends, where you’ll benefit from having written down the intended behavior at the start.

  • Boomkop3@reddthat.com
    link
    fedilink
    arrow-up
    4
    ·
    2 days ago

    Use a library if it fits your use case. Build your own if you enjoy it, or require some specialty features

  • Kissaki@programming.dev
    link
    fedilink
    English
    arrow-up
    2
    ·
    edit-2
    2 days ago

    How do you intend to present your GitHub portfolio to your potential employers? Nobody’s going to do a full, in-depth, or even basic analysis of your repos unless maybe with automated tools or what GitHub itself provides.

    Your CV and interview are much more important. Solutions [and projects] matter much more than details. Experience and that you can talk about your work or experience is much more important than technical details.

    A hash table library doesn’t sound like particularly noteworthy expertise. Adding a dependency and calling simple documented methods on it in a simple, standard behavior manner isn’t noteworthy.

    If you’re implementing your own, I wonder if “simply” implies a non-noteworthy implementation, or in-depth exploration of hashing and storage indexing. The latter would be a different project though, putting your other on hold.

    I don’t see it making a difference for employers what you pick here specifically.

    If you’re interested in implementing one or learning about the technicalities of it go ahead. Otherwise use a library and continue with your project or other interests.


    Disclaimer: I’m not in the recruiting space nor do I have that much or recent experience being interviewed/the broader companies hiring processes.

  • solrize@lemmy.world
    link
    fedilink
    arrow-up
    2
    ·
    2 days ago

    Ermph, this is C specific and shouldn’t be extrapolated to other languages. Since you’re writing in C you are trying to show your chops as a low level programmer. Therefore, showing that you know how to implement a hash table is worthwhile, so you should do it yourself. You could add a comment to the code saying something to that effect. Again that’s just for C. Implementing your own hash table in Python instead of using the built-in one would be crazy. Implementing one in C++ instead of using the stdlib or some other one would have to be carefully justified.

    I do have to wonder what you are up to in this day and age, pursuing what sounds like junior level C projects. I would say that whole approach is something of a dead end. You’re more employable with higher level languages than with C these days, I would have to say. Or if you write something in Python that incorporates some C functions that you write using Python’s C API, that shows you can operate at multiple levels at the same time, which is even better.

    • gwilikers@lemmy.mlOP
      link
      fedilink
      arrow-up
      2
      ·
      2 days ago

      Ah the project was just an excuse to familiarise myself with low-level network code. It’s basically just a simple TUI app that takes a list from a popular comics podcast website and allows the user to locally track the comics they’ve read then update the list when the a new podcast comes out adding additional comics to the list.

      I could have done the project in a quarter of the time in Python. But I wanted to get a strong foundation in low-level socket programming, network protocols, TLS and HTML parsing. I suppose on some level I’m just interested in those things.

      That said, you probably have a point. Maybe I should just look into Rust and Go. I’ve had some fun with the latter.