主页 > imtoken安卓版钱包 > 比特币源码研究2——程序入口函数解析(一)
比特币源码研究2——程序入口函数解析(一)
在第一讲中,我们使用了which bitcoind和which bitcoin-cli这两个命令来验证比特币客户端是否安装成功。 那么我们可以猜测会有一个bitcoind相关的程序入口。
果然src目录下有一个bitcoind.cpp文件。
从这个文件中可以找到程序入口的主要功能。
int main(int argc, char* argv[])
{
设置环境();
// 连接 bitcoind 信号处理程序
noui_connect();
返回(AppInit(argc,argv)?EXIT_SUCCESS:EXIT_FAILURE);
}
本节主要讲解SetupEnvironment(),这是一个定义在src/util.cpp文件中的函数。
它的作用有以下三个方面:
1.内存分配区设置
#ifdef HAVE_MALLOPT_ARENA_MAX
// glibc-specific: 在 32 位系统上将竞技场数设置为 1。
// 默认情况下,从 glibc 2.10 开始,C 库将创建最多两个堆
// 每个核心的竞技场。 已知这会导致过多的虚拟地址空间
// 在我们的用法中的用法。 通过设置最大数量来解决它
// 竞技场到 1。
如果 (sizeof(void*) == 4) {
mallopt(M_ARENA_MAX, 1);
}
这里判断如果是32位系统(sizeof(void*) == 4),即只分配一个arena内存区域,防止过度使用虚拟地址空间。 从glibc 2.10版本开始,C标准库会默认为每个核心创建两个堆内存区域。 这是导致内存地址空间过度使用的公认问题。
科普一下:arena:可以理解为一个很大的、连续的内存分配区域比特币占多大内存,需要手动管理。
2.本地化设置
#万一
// 在大多数 POSIX 系统(例如 Linux,但不是 BSD)上,环境的语言环境
// 可能无效,在这种情况下比特币占多大内存,“C”区域设置用作后备。
#if !defined(WIN32) && !defined(MAC_OSX) && !defined(__FreeBSD__) && !defined(__OpenBSD__)
尝试 {
std::locale(""); // 如果当前语言环境无效,则引发运行时错误
} catch (const std::runtime_error&) {
setenv("LC_ALL", "C", 1);
}
在大多数 POSIX 系统(比如 Linux,但不是 BSD)中,环境的 locale,即系统 locale 设置,可能是无效的。 如果当前本地化设置无效,将抛出此运行时异常,并将值设置为“C”。
尖端:
locale 决定了当前程序使用的语言编码、日期格式、数字格式和其他与区域相关的设置。 详情请参考:
C:默认值:ANSI-C约定,C语言标准规范和约定。 例如函数命名规范等,由美国国家标准协会发布。
POSIX:便携式操作系统接口。 Portable Operating System Interface (POSIX) 是 IEEE 计算机协会指定的一系列标准,用于维护操作系统之间的兼容性。
关于函数setenv(const char *name, const char *value, int overwrite),作用是修改或添加一个环境变量,详见
3.本地化文件路径设置
#万一
// 路径语言环境是惰性初始化的,以避免反初始化错误
// 在多线程环境中,它由主线程显式设置。
// 虚拟语言环境用于提取内部默认语言环境,供
// fs::path,然后用于显式注入路径。
std::locale loc = fs::path::imbue(std::locale::classic());
fs::path::imbue(loc);
路径区设置采用lazy initialization,即延迟初始化的方法,可以避免多线程环境下销毁过程中的错误,通过主线程显式设置。 虚拟语言环境可用于提取 fs::path 使用的内部默认语言环境(路径),然后可以显式设置。
imbue:此函数将要设置的 loc 值与流以及与该流关联的流缓冲区(如果有)相关联,作为新的系统区域设置对象。 详情请参考:
这里设置的是文件系统路径的本地化。
下一节将解释比特币源代码如何处理信号连接。
区块链研究院源码学习班Jacky