linux c動的リンクライブラリの作成のメリット
2699 ワード
ダイナミックリンクライブラリを作成するメリットは何ですか.
linuxでは、コード量の大きいプログラムの場合、システムに複数のプログラムインスタンスが存在する場合があります.この場合、一部のコードをダイナミックリンクライブラリに実装すると、メモリを節約するメリットがあります.
ここではstraceというツールを紹介し、プログラムのシステム呼び出しを追跡することができ、常に潰されるプログラムにとって、デバッグ時に役立ちます.
簡単なprintf()プログラムの場合:
int main()
{
printf("hello ");
return 1;
}
上記プログラムをstraceで起動して出力する.
printfを呼び出す過程でlibcを開いた後、mmapを呼び出すとファイルの内容がプロセスの空間にマッピングされ、システムに複数のプログラムインスタンスがlibcを参照する必要がある場合に共有されるメモリは同じであるため、ダイナミックリンクライブラリを使用するとメモリを節約できることがわかります.
printfの下位実装がwrite関数であることも分かる.
linuxでは、コード量の大きいプログラムの場合、システムに複数のプログラムインスタンスが存在する場合があります.この場合、一部のコードをダイナミックリンクライブラリに実装すると、メモリを節約するメリットがあります.
ここではstraceというツールを紹介し、プログラムのシステム呼び出しを追跡することができ、常に潰されるプログラムにとって、デバッグ時に役立ちます.
簡単なprintf()プログラムの場合:
int main()
{
printf("hello ");
return 1;
}
上記プログラムをstraceで起動して出力する.
execve("./a.out", ["./a.out"], [/* 19 vars */]) = 0
brk(0) = 0x199e000
access("/etc/ld.so.nohwcap", F_OK) = -1 ENOENT (No such file or directory)
mmap(NULL, 8192, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f68e0141000
access("/etc/ld.so.preload", R_OK) = -1 ENOENT (No such file or directory)
open("/etc/ld.so.cache", O_RDONLY|O_CLOEXEC) = 3
fstat(3, {st_mode=S_IFREG|0644, st_size=70103, ...}) = 0
mmap(NULL, 70103, PROT_READ, MAP_PRIVATE, 3, 0) = 0x7f68e012f000
close(3) = 0
access("/etc/ld.so.nohwcap", F_OK) = -1 ENOENT (No such file or directory)
open("/lib/x86_64-linux-gnu/libc.so.6", O_RDONLY|O_CLOEXEC) = 3
read(3, "\177ELF\2\1\1\0\0\0\0\0\0\0\0\0\3\0>\0\1\0\0\0\200\30\2\0\0\0\0\0"..., 832) = 832
fstat(3, {st_mode=S_IFREG|0755, st_size=1815224, ...}) = 0
mmap(NULL, 3929304, PROT_READ|PROT_EXEC, MAP_PRIVATE|MAP_DENYWRITE, 3, 0) = 0x7f68dfb61000
mprotect(0x7f68dfd16000, 2097152, PROT_NONE) = 0
mmap(0x7f68dff16000, 24576, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_DENYWRITE, 3, 0x1b5000) = 0x7f68dff16000
mmap(0x7f68dff1c000, 17624, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0x7f68dff1c000
close(3) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f68e012e000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f68e012d000
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f68e012c000
arch_prctl(ARCH_SET_FS, 0x7f68e012d700) = 0
mprotect(0x7f68dff16000, 16384, PROT_READ) = 0
mprotect(0x600000, 4096, PROT_READ) = 0
mprotect(0x7f68e0143000, 4096, PROT_READ) = 0
munmap(0x7f68e012f000, 70103) = 0
fstat(1, {st_mode=S_IFCHR|0620, st_rdev=makedev(136, 2), ...}) = 0
mmap(NULL, 4096, PROT_READ|PROT_WRITE, MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0x7f68e0140000
write(1, "hi
", 3hi
) = 3
exit_group(1) = ?
printfを呼び出す過程でlibcを開いた後、mmapを呼び出すとファイルの内容がプロセスの空間にマッピングされ、システムに複数のプログラムインスタンスがlibcを参照する必要がある場合に共有されるメモリは同じであるため、ダイナミックリンクライブラリを使用するとメモリを節約できることがわかります.
printfの下位実装がwrite関数であることも分かる.