- Mastering Embedded Linux Programming
- Chris Simmonds
- 396字
- 2021-07-30 09:44:59
Choosing the C library
The programming interface to the Unix operating system is defined in the C language, which is now defined by the POSIX standards. The C library is the implementation of that interface; it is the gateway to the kernel for Linux programs, as shown in the following diagram. Even if you are writing programs in another language, maybe Java or Python, the respective run-time support libraries will have to call the C library eventually:

The C library is the gateway to the kernel for applications
Whenever the C library needs the services of the kernel it will use the kernel system call
interface to transition between user space and kernel space. It is possible to bypass the C library by making kernel system calls directly, but that is a lot of trouble and almost never necessary.
There are several C libraries to choose from. The main options are as follows:
- glibc: Available at big and, until recently, not very configurable, but it is the most complete implementation of the POSIX API.
- eglibc: Available at of patches to glibc which added configuration options and support for architectures not covered by glibc (specifically, the PowerPC e500). The split between eglibc and glibc was always rather artificial and, fortunately, the code base from eglibc has been merged back into glibc as of version 2.20, leaving us with one improved library. eglibc is no longer maintained.
- uClibc: Available at that this is the micro controller C library. It was first developed to work with uClinux (Linux for CPUs without memory management units), but has since been adapted to be used with full Linux. There is a configuration utility which allows you to fine-tune its features to your needs. Even a full configuration is smaller than glibc but it is not as complete an implementation of the POSIX standards.
- musl libc: Available at designed for embedded systems.
So, which to choose? My advice is to use uClibc only if you are using uClinux or if you have very limited amounts of storage or RAM and so the small size would be an advantage. Otherwise, I prefer to use an up-to-date glibc, or eglibc. I have no experience of musl libc but if you find that glibc/eglibc is not suitable, by all means give it a go. This process is summarized in the following figure:

Choosing a C library
- SQL Server 從入門到項目實踐(超值版)
- 深度實踐OpenStack:基于Python的OpenStack組件開發
- Python從小白到大牛
- 垃圾回收的算法與實現
- Offer來了:Java面試核心知識點精講(原理篇)
- Mastering QGIS
- 精通軟件性能測試與LoadRunner實戰(第2版)
- 實戰低代碼
- 手把手教你學C語言
- SQL基礎教程(第2版)
- INSTANT Yii 1.1 Application Development Starter
- C# and .NET Core Test Driven Development
- C語言程序設計與應用(第2版)
- Scala編程(第5版)
- 3ds Max印象 電視欄目包裝動畫與特效制作