data:image/s3,"s3://crabby-images/ffa0a/ffa0a47e2ec6dc27680ff0e94671e82e416f544b" alt="Notepad++ portable 32 bit"
data:image/s3,"s3://crabby-images/6feb8/6feb827a7046f76e8b8e4ae3905def9c36958cb3" alt="notepad++ portable 32 bit notepad++ portable 32 bit"
Now, get any installer from Windows and try to run.
data:image/s3,"s3://crabby-images/cbbcd/cbbcdd7d003a62fe1d44126304343e1395b77a2e" alt="notepad++ portable 32 bit notepad++ portable 32 bit"
deb from an old Debian and try to run on a new Debian, it likely won't work. This means that distributed binaries will eventually fail to run. Unfortunately distros rarely keep around old libraries indefinitely.
data:image/s3,"s3://crabby-images/1e16a/1e16ace9fdf1975aa5aab9dbdf326f7a3c08c89d" alt="notepad++ portable 32 bit notepad++ portable 32 bit"
Traditionally, Linux binaries aren't distributed with their libraries it's expected that the distro will place the libraries in the right version and in the correct place. I think the point is that the Linux kernel ABI is super stable, but the Linux userland ABI (meaning, the system libraries your program uses) has breaking changes. That is, Linux churns so much that a given program written today won't work in a year meanwhile, programs written in the Windows 95 32-bit era are guaranteed to never change again. I think I started thinking about this idea when I read the remark "win32 is the stable Linux userland ABI".
data:image/s3,"s3://crabby-images/ffa0a/ffa0a47e2ec6dc27680ff0e94671e82e416f544b" alt="Notepad++ portable 32 bit"