2025-10-13
:: Jimmy Hartzell
#programming
#computers
#rust
#traits
I stumbled across a … bug(?) … a limitation(?) … an
issue(!) with the Rust
compiler. Fortunately, I was able to find out what was going on in the
Rust programming language forum.
I thought this issue was interesting enough and subtle enough to try
to explain to my blog audience.
To be clear, this is an issue. This is a limitation in the Rust trait solver.
The maintainers of the Rust compiler didn’t make Rust work this way for a
principled reason. There’s no particularly strong theoretical reason Rust has to
have this limitation.
2025-08-10
:: Jimmy Hartzell
#programming
#computers
#nontechnical
#AI
Recently, at work, we’ve been encouraged to try out a bunch of new “AI”
tools. So, I’ve been using the Claude “AI” app, an “AI assistant” developed
by Anthropic, to help with some
Rust programming tasks. I’ve been trying (as requested) to learn its
strengths and weaknesses, and how I might be able to use it to make my work
more efficient. But mostly I’ve just been building an intuition of what it
is.
2025-07-21
:: Jimmy Hartzell
#programming
#computers
#Rust Features
In my previous post, I talked about programming
language design, and try to discern some heuristics for what features
should be added to a programming language, on my way to explaining
why Rust should not include inheritance as a feature.
I’d like to expand more on that blog post now (so I guess it’s become a
series?). Do I think Rust is perfect how it is?
(No.) Are there features that I want in Rust that Rust currently does not
have? (Absolutely yes.) In this post, I’d like to talk about some proposed
additions to Rust, some recent, some very stale, and discuss my perspective
on them.
2025-07-19
:: Jimmy Hartzell
#programming
#computers
#Rust
#OOP
#Beyond OOP
#Rust Features
Programming language design, like API design, and computer UX design
(especially for technical tools like build systems and admin systems) is a
difficult form of engineering, bridging computer science and cognitive
science. Sometimes, it’s more art than science, because building systems
that other technical workers will use comes with nearly infinite trade-offs
and judgment calls.
The effort and quality matter too. Different programming languages have
different strengths and weaknesses. Some programming languages are hard to
use correctly, like C++. Some are easy to write, but hard to then read and
maintain, like Perl. Some programming languages are great for one-off
scripts where you’re the only user, like Python, and others enforce that you
follow reliable engineering principles, like Rust.
2024-09-04
:: Jimmy Hartzell
#programming
#computers
I was recently working on a (company-internal) GitHub pull
request I’d written. A colleague left a few comments in a review
and “requested changes” from me, effectively giving me a TODO
list of items that needed to be done before the PR could be merged.
Because he’d specified that he was “requesting changes,” GitHub
knew to prevent someone from merging the PR before those requests
had specifically been addressed.
Once I’d finished addressing these TODO items, I had a conversation
with this same colleague about something else. He indicated he’d
like that to be changed as well, and I put in the comment on my
own PR. But then, I found I could not request changes on my own
PR.
2024-07-29
:: Jimmy Hartzell
#computers
#politics
#nontechnical
#AI
I just read an
article
in The
Atlantic
that AI is failing to justify itself economically. This is pretty
dire for AI, especially given that this is such an overly expensive
technology even with tons of brazen stealing
from content creators. I feel like it should go without saying that if
your business isn’t profitable even with a ton of stealing, maybe it’s
not that great a business.
But of course, who doesn’t want a confident confabulator incapable
of critical thinking? A bullshit artist designed to do what many of us
learned to do in high school and college, and write pages of content that
sounded “educated” without actually paying attention to the actual ideas,
or even understanding them at all?
2024-06-30
:: Jimmy Hartzell
#politics
#nontechnical
#computers
#AI
AI, particularly this new round of large language models, scares me
on behalf of society and the future.
I don’t just say that because it’s transformative. I don’t say that as a
generic warning that we haven’t considered the consequences (as in this
XKCD comic). No, I have specific consequences
in mind, consequences that I have considered, and I am rather worried
about them! They are not so much problems about the technology itself,
but about how we use it, and specifically how we use it on a societal,
economy-wide scale.
2024-06-25
:: Jimmy Hartzell
#programming
#computers
#C++
#Rust vs C++
C++, like all things, has numerous
problems. Pointing out how Rust addresses many of them is a major
topic of my blog, but some of the problems are bigger
than others. The biggest, most famous, loudest problem, the problem that
got the federal government’s attention and resulted in a surreal flame
war between Dr. Bjarne Stroustrup and the NSA (which I also commented
on/contributed to), is C++’s lack of
memory safety.
This is C++’s biggest problem, its memory safety problem. That’s the
one everyone’s talking about. Can it be fixed?
2024-05-18
:: Jimmy Hartzell
#computers
#reviews
#asahi linux
Since my previous post,
I haven’t posted about Asahi Linux. This is for a simple reason:
I wasn’t using it. I never took the time to set up a tiling window
manager, get dropbox working, and all the things I felt I needed,
and I slipped back to using my trusty Dell Ubuntu laptop for Linux,
and using my MacBook M1 just for macOS.
But then I tried again! And wow, has Asahi Linux changed! It’s Fedora,
not Arch now, and installation was much easier! So I wanted to share
how my experience has gone. I’m not particularly stoked to spend too
much time on sysadmin tasks for my personal computing, so this is
more a narrative about what actually has happened in my adjustment to
it, rather than a reflection of Asahi at its best, but I thought I’d
share where I was at.
2024-04-23
:: Jimmy Hartzell
#programming
#computers
#what bits mean
#programming basics
This is part of my new series on what the 0’s
and 1’s in computers mean, how computers use them to store various
kinds of information, and why all of this works the way it does.
When I was a boy, my schoolmates, knowing that I was interested in
computers, would sometimes ask me if I could read binary. They
imagined I would see some binary, and be able to read it out
loud like they could read letters, perhaps some binary that
looked like this:
2024-04-15
:: Jimmy Hartzell
#programming
#computers
#technical
#what bits mean
#programming basics
I was explaining two’s complement recently to a friend, and I thought
my explanation was decent, so I decided to write it up and share it
with you, my general blog audience, as well! If you already know about
two’s complement, this will pretty much just be a review. If not, you
may learn something, and you may not understand all of it. Try to get
what you can without getting too anxious, there will not be a test!
2024-02-05
:: Jimmy Hartzell
#programming
#computers
#Rust
#C++
#Java
#Haskell
Polymorphism is a powerful programming language feature. In polymorphism,
we have generic functions that don’t know exactly what type of data
they will be operating on. Often, the data types won’t even all have been
designed yet when the generic function is written. The generic function
provides the general outline of the work, but the details of some parts of
the work, some specific operations, must be tailored to the specific
types being used. The generic code needs some way of accessing these
specific operations, and the users of the generic code need some way
of specifying them.
2024-01-21
:: Jimmy Hartzell
#programming
#computers
So, there are now two additional repos of my code on GitHub that recently
got published, both under the MIT license. Neither is any show-stopping
major project, but I figured I’d let everyone know nevertheless, and
write up a few notes about it. Both have been added to my
programming portfolio garden.
Repo #1: Crate Version of Prefix Ranges
Arvid Norlander (blog,
GitHub) reached out to me to ask if
I wanted to publish my little Rust module from my post on
prefix ranges as a crate, or, failing that,
if I could license it as open source so he could publish it. I had
thought of most of my code on this blog up until this point as example
code not worth licensing, but his prompting changed my mind. If it’s
just trivial example code, it’s not worth not open sourcing, so
I might as well release the website’s example code under an MIT
license.
2023-12-07
:: Jimmy Hartzell
#programming
#computers
#Rust
#OOP
#Beyond OOP
In this next post of my series explaining how Rust is better
off without Object-Oriented Programming, I discuss
the last and (in my opinion) the weirdest of OOP’s 3 traditional pillars.
It’s not encapsulation, a great idea which
exists in some form in every modern programming language, just OOP does
it oddly. It’s not polymorphism, also a
great idea that OOP puts too many restrictions on, and that Rust
borrows a better design for from Haskell (with syntax from C++).
2023-10-19
:: Jimmy Hartzell
#programming
#computers
#endianness
#C
#C++
#Rust
Endianness is a long-standing headache for many a computer science
student, and a thorn in the side of practitioners. I have already
written some about it in a different
context. Today, I’d like to talk more about how to deal with endianness
in programming languages and APIs, especially how to deal with it
in a principled, type-safe way.
Before we get to that, I want to make some preliminary clarifications
about endianness, which will help inform our API design.
2023-10-08
:: Jimmy Hartzell
#computers
#user interfaces
#operating systems
#nontechnical
This is my newest post in my series about operating
systems. Yes, it was last updated in 2019 –
I’m a hobbyist blogger. This is a post about the command line, a computer
topic, but it is for educating a non-technical (but tech-curious)
audience. Most of the programmers in my audience will already know
everything I have to say, and may be bored by some explanation of things
they already know, though I intend to discuss some technical details of
how computers work.
2023-09-30
:: Jimmy Hartzell
#essay
#nontechnical
#philosophy
#computers
This blog post isn’t about ChatGPT. It
isn’t about machine learning, neural nets, or any
mysterious or border-line
spiritual form of
computing. That’s a whole ’nother set of philosophical and metaphysical
conundrums (conundra?).
This is about a way people sometimes speak, informally, about bog-standard
boring non-AI computers and computer programs. You’ve probably
heard people speak this way. You’ve probably spoken this way sometimes
yourself:
- “The server thinks your password is wrong.”
- “The computer thinks you’ve lost the connection.”
- “The phone thinks you want to use your headphones. It’s wrong though.”
We normally interpret this as a metaphor, but I’m not sure it is.
Is the phone “thinking” you want to use your headphones rather than
your car speaker substantially different from us “thinking”
our friend would rather get a phone call than a text message?
2023-08-30
:: Jimmy Hartzell
#programming
#computers
#C++
UPDATE: I have updated this post to address C++ features that
address these issues or have been purported to.
I have long day-dreamed about useful improvements to C++. Some of these
are inspired by Rust, but some of these are ideas I already had before
I learned Rust. Each of these would make programming C++ a better experience,
usually in a minor way.
Explicit self
reference instead of implicit this
pointer
UPDATE: This is coming out in C++23, and they did it right!
I’m excited! Good job C++!
2023-08-28
:: Jimmy Hartzell
#programming
#computers
#C
#C/C++
#C++
One of the minor points I discussed in my
response to Dr. Bjarne Stroustrup’s memory safety
comments
was the controversial, apparently deeply upsetting term C/C++. It is
controversial and interesting enough that I decided to say a little more
about it here.
A little background: Many people, especially outside the C and C++
communities (which, to be clear, don’t always like each other that
much) use the term C/C++ to talk about the two programming languages
together, as an informal short-hand for “C and C++” or “C or C++.”
Within the C/C++ C and C++ communities, it is widely hated.
2023-08-26
:: Jimmy Hartzell
#programming
#computers
#C++
UPDATE: Wow, this post has gotten popular! I’ve written
a new post that adds new papercuts combined
with concrete suggestions for how C++ could improve, if you are
interested. Also, if you want to read more about C++’s
deeper-than-papercut issues, I recommend specifically
my post on its move semantics. Thank you for reading!
My current day job is now again a C++ role. And so, I find myself again
focusing in this blog post on the downsides of C++.
2023-08-06
:: Jimmy Hartzell
#meta
#computers
#nontechnical
TLDR: I am adding a new link for RSS subscribers who just want
to subscribe to technical posts. The RSS feed has always been available,
but it is now explicitly one of the links across the top, for those
who want their RSS feed to only give them my new technical posts.
I am writing this post primarily to let people know about this new
link, but I also want to muse on it a little.
2023-06-24
:: Jimmy Hartzell
#programming
#computers
#Rust
#walkthrough
Update: Arvid Norlander has
gone through the trouble of refactoring this code into a
crate and publishing it. Thank
you, Arvid!
Rust’s BTreeMap
and corresponding BTreeSet
are excellent,
B-tree-based sorted map and key types. The map implements
the ergonomic entry API, more flexible
than other map APIs, made possible by the borrow checker.
They are implemented with the more performant but more gnarly
B-Tree data structure, rather than
the more common AVL trees or
red-black trees.
All in all, they are an excellent piece of engineering, and an excellent
standard library feature.
2023-05-24
:: Jimmy Hartzell
#programming
#computers
#Rust vs C++
#Rust
I am no stranger to programming language controversy. I have a whole
category on my blog dedicated to explaining why Rust
is better than C++, and I’ve taken the extra step of organizing it into
an MDBook for everyone’s convenience. Most of them have
been argued about on Reddit, and a few even on Hacker News. Every single
one of them have been subject to critique, and in the process, I’ve been
exposed to every corner, every trope and tone and approach of programming
language debate religious war, from the polite and well-considered
to the tiresome and repetitive all the way to the rude and non-sensical.
2023-05-23
:: Jimmy Hartzell
#computers
#hardware
Intel has just released a new white
paper,
where they discuss removing a lot of the legacy cruft of the Intel/AMD
architecture they call Intel64. Only 64-bit operating systems – and
a narrow set of 32-bit legacy apps that don’t use segmentation (a
small subset in theory but basically all of them in practice) – will
be supported. I am surprised at how excited I am, although after all
this time perhaps the better word is “relieved.”
2023-04-24
:: Jimmy Hartzell
#programming
#computers
#Rust
#Rust vs C++
Here it is, the Rust vs C++ mdbook.
I’ve wanted for a while to re-organize some of the
content on my blog into gardens. I got
the idea from the blog post “The Garden and the Stream: A
Technopastoral”.
Basically, some content is ill-suited to date-based, time-organized
systems like blogs. In fact, most of my content remains valid over a
long period of time, rather than participating in conversation (with
some exceptions), but
rapidly becomes less discoverable after I’ve written it, as it is
buried by newer posts.
2023-04-06
:: Jimmy Hartzell
#programming
#computers
#Rust vs C++
#Rust
#C++
I know I set the goal for myself of doing less
polemics and more education, but here I return for another Rust vs
C++ post. I did say I doubted I would be able to
get fully away from polemics, however, and I genuinely think this post
will help contextualize the general Rust vs. C++ debate and contribute
to the conversation. Besides, most of the outlining and thinking for
this post – which is the majority of the work of writing – was already
done when I set that goal. It also serves as a bit of conceptual glue,
structuring and contextualizing many of my existing posts. So please
bear with me as I say more on the topic of Rust and C++.
2023-03-28
:: John Ericson & Jimmy Hartzell
#programming
#Rust
#computers
#Beyond OOP
Does the choice of programming language matter?
For years, many programmers would answer “no”. There was an “OOP
consensus” across languages as different as C++ and Python. Choice
of programming language was just a matter of which syntax to use to
express the same OOP patterns, or what libraries were needed for the
application. Language features like type checking or closures were seen
as incidental, mere curiosities or distractions.
To the extent there was a spectrum of opinions, it was between OOP
denizens and those that didn’t really think software architecture mattered
at all — an feeble attempt of corporatization against true programmers
and their free-spirited ways. The office park versus the squatters. That’s
how we got the wave of so-called “scripting languages”.
2023-03-24
:: Jimmy Hartzell
#programming
#computers
#Rust
#Rust Tidbits
This is a collection of little Rust thoughts that weren’t complicated
enough for a full post. I saved them up until I had a few, and now I’m
posting the collection. I plan on continuing to do this again for
such little thoughts, thus the #1 in the title.
serde
flattening
What if you want to read a JSON file, process some of the fields, and
write it back out, without changing the other fields? Can you still use
serde
? Won’t it only keep fields that you know about in your data
structure?
2023-03-21
:: Jimmy Hartzell
#programming
#logging
#Rust
#computers
Intro programming classes will nag you to do all sorts of
programming chores: make sure your code actually compiles,
write unit tests, write comments, split the code into functions
(though sometimes the commenting and factoring advice is
bad). Today, however,
I want to talk about one little chore, one particular little habit, that
is just as essential as all of those things, but rarely covered in the
CS100 lectures or grading rubrics: logging.
2023-02-28
:: Jimmy Hartzell
#essay
#nontechnical
#linux
#computers
#organization
#ADHD
#write-everything-down
I’d like to share with you how I use my computer, in a way that is
(for me) ADHD friendly and well-suited for implementing
my organization system. Tools are
important to any organizational and productivity system, and optimizing
your tools for your brain and your workflow are important. My computer
is my most important productivity tool, where my work happens, and where
my life/chore/errand/calendar organization happens, so it should be an
interesting example of an optimized key tool.
2023-02-07
:: Jimmy Hartzell
#programming
#Rust
#OOP
#Beyond OOP
#computers
In this post, I continue my series on how Rust
differs from the traditional object-oriented programming paradigm by
discussing the second of the three traditional pillars of OOP:
polymorphism.
Polymorphism is an especially big topic in object-oriented programming,
perhaps the most important of its three pillars. Several books could be
(and have been) written on what polymorphism is, how various programming
languages have implemented it (both within the OOP world and outside of it
– yes, polymorphism exists outside of OOP), how to use it effectively,
and when not to use it. Books could be written on how to use the Rust
version of it alone.
2023-01-30
:: Jimmy Hartzell
#programming
#C++
#Rust
#Rust vs C++
#essays
#computers
The NSA recently published a Cybersecurity Information
Sheet
about the importance of memory safety, where they recommended
moving from memory-unsafe programming languages (like C and
C++) to memory-safe ones (like Rust). Dr. Bjarne Stroustrup, the
original creator of C++, has made some
waves
with his
response.
To be honest, I was disappointed. As a current die-hard Rustacean
and former die-hard C++ programmer, I have thought (and
blogged) quite a bit about the topic of Rust vs
C++. Unfortunately, I feel that in spite of the exhortation in his title
to “think seriously about safety,” Dr. Stroustrup was not in fact thinking
seriously himself. Instead of engaging conceptually with the article,
he seems to have reflexively thrown together some talking points –
some of them very stale – not realizing that they mostly are not even
relevant to the NSA’s Cybersecurity Information Sheet, let alone a
thoughtful rebuttal of it.
2023-01-11
:: Jimmy Hartzell
#programming
#Rust
#OOP
#Beyond OOP
#computers
Rust doesn’t support default parameters in function signatures.
And unlike in many languages, there’s no way to simulate them
with function overloading. This is frustrating for many new Rustaceans
coming from other programming languages, so I want to explain
why this is actually a good thing, and how to use the Default
trait
and struct update
syntax
to achieve similar results.
Default parameters (and function overloading) are not part of
object-oriented programming, but they are a common feature of a lot
of the programming languages new Rustaceans are coming from. This
post therefore fits in some ways with my on-going series on how Rust
is not object-oriented, and so it is tagged with
that series. It was also inspired by Reddit responses to my first OOP
post.
2022-12-12
:: Jimmy Hartzell
#programming
#Rust
#OOP
#Beyond OOP
#computers
Rust is not an object oriented programming language.
Rust may look like an object-oriented programming language: Types can be
associated with “methods,” either “intrinsic” or through “traits.” Methods
can often be invoked with C++ or Java-style OOP syntax: map.insert(key, value)
or foo.clone()
. Just like in an OOP language, this syntax
involves a “receiver” argument placed before a .
in the caller,
called self
in the callee.
But make no mistake: Though it may borrow some of the trappings, some of
the terminology and syntax, Rust is not an object-oriented programming
language. There are three pillars of object-oriented programming:
encapsulation, polymorphism, and inheritance. Of these, Rust nixes
inheritance entirely, so it can never be a “true” object-oriented
programming language. But even for encapsulation and polymorphism,
Rust implements them differently than OOP languages do – which we
will go into in more detail later.
2022-10-31
:: Jimmy Hartzell
#programming
#ADHD
#organization
#computers
2022-10-24
:: Jimmy Hartzell
#computers
#reviews
#asahi linux
I bought my M1 Mac over a year ago with the intention of installing Asahi
Linux on it, but I never got around to it until now. I am still thrilled
to be using an ARM workstation made by a major computer manufacturer,
and it’s good to be able to run the operating system of my choice on it
(though macOS is acceptable for entertainment and video calls, Linux
is what I work and do my organization in). And I
don’t particularly do GPU-intensive things in my day to day computing –
I run XMonad, of all things! – so I don’t really feel like I’m missing
out by not having a “proper” graphics driver.
2022-10-11
:: Jimmy Hartzell
#programming
#Rust
#Rust vs C++
#C++
#computers
I don’t want you to think of me as a hater of C++. In spite of the fact
that I’ve been writing a Rust vs C++ blog series
in Rust’s favor (in which this post is the latest installment), I am very
aware that Rust as it exists would never have been possible without C++.
Like all new technology and science, Rust stands on the shoulders of
giants, and many of those giants contributed to C++.
2022-09-15
:: Jimmy Hartzell
#rust
#programming
#computers
I’m a Rust programmer and in general a fan of strong typing over dynamic
or duck typing. But a lot of advocacy for strong typing doesn’t actually
give examples of the bugs it can prevent, or it gives overly simplistic
examples that don’t really ring true to actual experience.
Today, I have a longer-form example of where static typing can help
prevent bugs before they happen.
The Problem
Imagine you have a process that receives messages and must respond
to them. In fact, imagine you have potentially many such processes,
and want to write a framework to handle it.
2022-08-08
:: Jimmy Hartzell
#programming
#rust
#async
#computers
Using async
in Rust can lead to bad surprises. I recently came across
a particularly gnarly one, and I thought it was interesting enough to
share a little discussion. I think that we are too used to the burden
of separating async
from blocking being on the programmer, and
Rust can and should do better, and so can operating system APIs,
especially in subtle situations like the one I describe here.
2022-07-14
:: Jimmy Hartzell
#programming
#Rust
#computers
UPDATE 2: I have made the title longer because people seem to be
insisting on misunderstanding me, giving examples where the only
reasonable thing to do is to escalate an Err
into a panic. Indeed,
such situations exist. I am not advocating for panic-free code.
I am advocating that expect
should be used for those functions,
and if a function is particularly prone to being called like that
(e.g. Mutex::lock
or regex compilation), there should be a panicking
version.
2022-06-17
:: Jimmy Hartzell
#programming
#Haskell
#computers
The Error Message
I’ve written before about just how befuddling
Haskell error messages can be, especially for beginners. And now, even
though I have some professional Haskell development under my belt, I
ran across a Haskell error message that confused me for a bit, where I
had to get help. It’s clear to me now when I look at the error message
what it’s trying to say, but I legitimately was stumped by it, and so,
even though it’s embarrassing for me now, I feel the need to write about
how this error message could have been easier to understand:
2022-06-16
:: Jimmy Hartzell
#programming
#computers
#Rust
It took me a long time to admit to myself that the venerable Unix
command line interface is stuck in the past and in need of a refresh,
but it was a formative moment in my development as a programmer when I
finally did. Coming from that perspective, I am very glad that there is a new
wave of enthusiasm (coming especially from the Rust community) to build
new tools that are fixing some of the problems with this very old and
established user-interface.
2022-06-06
:: Jon Gjengset
#Rust
#programming
#computers
Preface (by Jimmy Hartzell)
I am a huge fan of Jon Gjengset’s Rust for
Rustaceans,
an excellent book to bridge the gap between beginner
Rust programming skills and becoming a fully-functional
member of the Rust community. He’s famous for his YouTube
channel
as well; I’ve heard good things about it (watching video
instruction isn’t really my thing personally). I have also
greatly enjoyed his Twitter feed,
and especially have enjoyed the thread surrounding this
tweet:
2022-06-04
:: Jimmy Hartzell
#Rust
#programming
#computers
I just made a pull request
to reqwest. I thought this
particular one was interesting enough to be worth blogging about, so I am.
We know that many C++ family languages have a feature known as function
overloading, where two functions or methods can exist with the same name
but different argument types. It looks something like this:
void use_connector(ConnectorA conn) {
// IMPL
}
void use_connector(ConnectorB conn) {
// IMPL
}
The compiler then chooses which method to call, at compile-time, based
on the static type of the argument. In C++, this is part of compile-time
polymorphism, an easy “if
statement” in the template meta-language. In
Java and many other languages, it’s merely a convenience, for when an
ad-hoc group of types are possible for what an outsider sees as the
same operation, but which from the perspective of the library requires
different implementations.
2022-05-11
:: Jimmy Hartzell
#rust
#programming
#computers
#C++
#Rust vs C++
There’s more than one way to do it.
There should be one– and preferably only one –obvious way to do it.
When it comes to statically-typed systems programming languages, C++ is
the Perl, and Rust is the Python. In this post, the next installment of
my Rust vs C++ series, I will attempt to explain
why C++’s feature-set is problematic, and explain how Rust does better.
2022-05-09
:: Jimmy Hartzell
#programming
#computers
I have worked on a lot of programming projects in my time, and while I
was a programming consultant I have worked in a lot of different corporate
environments. At some of them, it was easy to be concretely productive:
I was able to contribute immediately, and at a rapid rate. At others,
actual useful contributions would be impossible until I had a month or
more of experience with a codebase, and even then every change would be
a long slog. The difference can be overwhelming and palpable.
2022-03-22
:: Jimmy Hartzell
#essay
#computers
#programming
#nontechnical
NOTE: This post has the #programming tag, but is intended to be comprehensible
by everyone, programmer or not. In fact, I hope some non-programmers
read it, as my goal with this post is to explain some of what it means
to be a programmer to non-programmers. Therefore, it is also
tagged with “nontechnical”.
What is the most important skill for a software engineer? It’s
definitely not any particular programming language; they come and
go,
and a good programmer can pick them up as they work. It’s not estimating
how long a project will take, as important and elusive as that skill
is – because fundamentally, no one can, and many, many programmers are
successful without having fully built up that skill.
2022-03-12
:: Jimmy Hartzell
#programming
#Rust
#computers
#C++
#Rust vs C++
For my next entry in my series comparing Rust
to C++, I will be discussing a specific data structure API: the Rust
map API. Maps are often one of the more awkward parts of a collections
library, and the Rust map API is top-notch, especially its
entry API – I literally squealed
when I first learned about entries.
And as we shall discuss, this isn’t just because Rust made better choices
than other standard libraries when designing the maps API. Even more so,
it’s because the Rust programming language provides features that better
expresses the concepts involved in querying and mutating maps. Therefore,
this serves as a window into some deep differences between C++ and Rust
that show why Rust is better.
2022-02-28
:: Jimmy Hartzell
#programming
#historical
#computers

Let’s talk about an ancient programming language! I think we
can all learn things from history, and it gives us grounding
to realize that our time is just one time among many, to see
what people in the past did differently, what they got wrong
that we would never do now, and also to see what they got right.
Do you remember MS-DOS? Do you remember that it came with
an interpreted programming language? From MS-DOS 5 onwards,
it came with not Python, not Javascript or R or Matlab,
but a dialect
of BASIC. But
I think most people, especially most people my age who
were children at the height of the MS-DOS era, remember
it for the games, the two sample programs that came with it, namely
Gorillas
and Nibbles (their name for Snake).
2022-02-25
:: Jimmy Hartzell
#Rust
#programming
#computers
What is “bad” Rust?
When we say that a snippet of code is “bad” Rust, it’s ambiguous.
We might on the one hand mean that it is “invalid” Rust, like the
following function (standing on its own in a module):
fn foo(bar: u32) -> u32 {
bar + baz // but baz is never declared...
}
In this situation, a rule of the programming language has been violated.
The compiler stops compiling and does not output a binary. In fact, it
has to stop compiling, because this is not a Rust program. It might resemble
one, but it in fact does not make any sense, because it is violating
one of the extra-syntactic constraints that text has to have to be a Rust
program.
2022-02-16
:: Jimmy Hartzell
#programming
#Haskell
#computers
I am a big fan of strongly typed languages, and my favorite GC’d language
is Haskell. And I want you, the reader, to keep that in mind today.
What I am writing is some commentary about a language I deeply love,
some loving criticism.
So here’s what happened: A few days ago, I was showing off some Haskell
for a friend who primarily programs in Python. The stakes were high
– could I demonstrate that this strange language was worth some
investigation?
2022-01-20
:: Jimmy Hartzell
#programming
#Rust
#Rust vs C++
#C++
#computers
For this next iteration in my series comparing
Rust to C++, I want to talk about something I’ve been avoiding so far:
memory safety. I’ve been avoiding this topic so far because I think it
is the most discussed difference between C++ and Rust, and therefore I
felt I’d have relatively little to add to the conversation. I’ve also
been avoiding it because I wanted to draw attention to all the other
little ways in which Rust is a better-designed programming language,
to say that even if you concede to the C++ people that Rust isn’t “truly
memory safe” or “memory safe enough,” Rust still wins.
2022-01-03
:: Jimmy Hartzell
#programming
#Rust
#computers
#async
Finally in 2019, Rust stabilized the async
feature, which supports
asynchronous operations in a way that doesn’t require multiple operating
system threads. This feature was so anticipated and hyped and in
demand that there was a website whose sole
purpose was to announce its stabilization.
async
was controversial from its inception; it’s still controversial
today; and in this post I am throwing my own 2 cents into this
controversy, in defense of the feature. I am only going to try to
counter one particular line of criticism here, and I don’t anticipate
I’ll cover all the nuance of it – this is a multifaceted issue, and
I have a day job. I am also going to assume for this
post that you have some understanding of how async
works, but if
you don’t, or just want a refresher I heartily recommend the Tokio
tutorial.
2021-11-21
:: Jimmy Hartzell
#programming
#Rust
#computers
I have been working on a serialization project recently that involves
endianness (also known as byte order), and it caused me to explore parts
of the Rust standard library that deals with endianness, and share my
thoughts about how endianness should be represented in a programming
language and its standard library, as I think this is also something
that Rust does better than C++, and also makes for a good case study to
talk about API design and polymorphism in Rust.
2021-11-03
:: Jimmy Hartzell
#programming
#Rust
#Rust vs C++
#C++
#computers
This post is part of my series
comparing C++ to Rust, which I introduced
with a discussion of C++ and Rust syntax. In
this post, I discuss move semantics. This post is framed around the
way moves are implemented in C++, and the fundamental problem with
that implementation, With that context, I shall then explain how Rust
implements the same feature. I know that move semantics in Rust are often
confusing to new Rustaceans – though not as confusing as move semantics
in C++ – and I think an exploration of how move semantics work in C++
can be helpful in understanding why Rust is designed the way it is,
and why Rust is a better alternative to C++.
2021-10-26
:: Jimmy Hartzell
#programming
#Rust
#Rust vs C++
#C++
#computers
This past May, I started a new job working in Rust. I was somewhat
skeptical of Rust for a while, but it turns out, it really is all it’s
cracked up to be. As a long-time C++ programmer, and C++ instructor,
I am convinced that Rust is better than C++ in all of C++’s application
space, that for any new programming project where C++ would make sense
as the programming language, Rust would make more sense.
2020-11-16
:: Jimmy Hartzell
#computers
This year, Apple released, to much fanfare, a somewhat obscure
technical change to how its computers work: Macs will transition
away from Intel’s CPUs to in-house processors known as “Apple
Silicon,” more similar to the technology Apple already
uses in its phones and tablets. It is a tremendous amount of
hype for something rather technical, and to people used to more
user-visible feature announcements, this can be
somewhat disappointing,
or at least confusing.
2019-12-23
:: Jimmy Hartzell
#computers
The Internet promised — and still promises — a revolution in
democratic, decentralized, and open communications. And yet,
we see today a tech world controlled by a few central players,
as Elizabeth Warren promises to break them up and Congress summons
Mark Zuckerberg to explain his company’s role in privacy-violating
election-manipulating foreign conspiracies. But Presidential use of
anti-trust laws and new Congressional regulations of social media
won’t address the more fundamental issues: The Internet is now
structured, on a technical and social level, so as to naturally
encourage centralized monopolies.
2019-08-11
:: Jimmy Hartzell
#programming
#Haskell
#computers
When I was first learning to program, a long time ago, it was in
BASIC, and you had to annotate your variable names to indicate what
type something is. foo
would be a number, whereas foo$
would be a
string. This meant that there could only be as many types of information
as there were symbols to put after your variable, but that was okay for
the sort of programming BASIC was used for. These were called sigils,
and they helped you keep straight in your head what was going on +++
and made it easier for the computer too. Any aggregates had to be
explicitly declared.
2019-07-11
:: Jimmy Hartzell
#computers
#operating systems
#technical
In previous posts,
we discussed historic operating systems and where various OS features come
from, but we only gave a brief overview of how they worked.
Now that we have a modern operating system’s full complement of features,
we can look at what components need to exist in a modern operating system
to get those features. As discussed with MS-DOS, an operating system,
even today, is partially code, and partially conventions, like file
formats or rules of good behavior – the difference being, that modern
operating systems have more ability to enforce some of these
conventions.
2019-05-26
:: Jimmy Hartzell
#computers
#operating systems
#technical
We use operating systems all the time in our life, whether designed for
a computer, a phone, or for a server we’re more indirectly interacting
with, but a lot of people don’t know very much about what connects
the different systems we use, and what makes them distinct. We
discussed fundamental concepts of operating systems in the last
post, so in this post we will discuss
how some of the same concepts apply to modern operating systems, going
over them one at a time.
2019-04-28
:: Jimmy Hartzell
#computers
#operating systems
#technical
A user of modern technology hears the term “operating system” thrown
around a lot. Most people can name a few examples: Windows and macOS on
workstations and laptops, iOS and Android on phones. Some people might
even throw in Linux or Unix or ChromeOS. Most people also understand
that a program or a game or even a sufficiently advanced website might
work on some operating systems but not others, and might require different
versions for different operating systems. But it’s a bit less clear what
an operating system actually is, how it fits into the general model of
a computer, and how it works.
2019-02-26
:: Jimmy Hartzell
#programming
#C++
#computers
Programmers of functional programming languages will often point out that,
in functional programming languages, the order of the arguments is often
significant, because of currying.
If you have a function that takes two
arguments (e.g. map which takes a function to apply and a list to apply
it to) it actually takes the first argument, and returns a function that
takes the second argument and returns the final result. This makes it more
convenient to write a lambda where the second argument is the unknown
parameter: \x -> map someFunc x
can be written as map f
, whereas \f -> map f someValue
has no such convenient shorthand (flip map someValue
is actually clunkier).