エンジニアのライフプラン
リンカ・ローダ実践開発テクニック の著者は、KOZOSというオープンソースの小さなOSを公開している。
仕事をしながら、趣味でもプログラミングする感じ。
技術士(情報工学)の資格を取ったり、IPAで10歳前後の若者たちとセキュリティキャンプを実施したりしている。
エンジニアのライフプランは、仕事、趣味、生活の3本で、別々の柱があるとよい。
オープンソースが趣味の一つでもいいじゃないか。
<この項は書きかけです。順次追記します。>
This article is not completed. I will add some words in order.
リンカ ローダ
リンカ・ローダ実践開発テクニック―実行ファイルを作成するために必須の技術-COMPUTER-TECHNOLOGY-坂井-弘亮
https://www.amazon.co.jp//dp/4789838072/
https://bookmeter.com/books/630946
参考文献にあるLinkers & Loadersは斜め読みしただけで、自分ではこういう道具は作らないだろうと勝手に思っていた。本書では簡易リンカの作成と、道具の作り方まで有るのがすごい。「setjmp()とlongjmp()」というコラムが1頁に入りきらず4頁になっているのに、節にしていないところも興味深い。
https://shop.cqpub.co.jp/hanbai/books/38/38071.html
checksym.c リンカ・ローダ実践開発テクニック(0) 坂井弘亮 coding(88)
https://qiita.com/kaizen_nagoya/items/51709d5989204ef2a371
第3章 ライブラリ・アーカイブの解析
3.1 ライブラリ・アーカイブとは
3.2 ライブラリ・アーカイブの構造
3.3 アーカイブの解析例
3.4 ライブラリ・アーカイブの解析
3.5 ライブラリ・アーカイブのリンク
コラム 二つのアーカイブ・フォーマットが混在した場合
コラム checksymの使いかた
ardump.c リンカ・ローダ実践開発テクニック 坂井弘亮(1) coding(89)
https://qiita.com/kaizen_nagoya/items/2a7bf3050ee6ac662272
binary.c リンカ・ローダ実践開発テクニック 坂井弘亮(2) coding(90)
https://qiita.com/kaizen_nagoya/items/23b985cefc5338677812
combine.c リンカ・ローダ実践開発テクニック 坂井弘亮(3) coding(91)
https://qiita.com/kaizen_nagoya/items/59161e3274270cfd2009
const.c, リンカ・ローダ実践開発テクニック 坂井弘亮(4) coding(92) error(123) docker(174)
https://qiita.com/kaizen_nagoya/items/6f74dbf637a91685d0d1
constructor.c リンカ・ローダ実践開発テクニック 坂井弘亮(5) coding(93)
https://qiita.com/kaizen_nagoya/items/37e14a0943907b6f836f
continue.c リンカ・ローダ実践開発テクニック 坂井弘亮(6) coding(95)
https://qiita.com/kaizen_nagoya/items/e124223fd49db6d9e7a2
down.c リンカ・ローダ実践開発テクニック 坂井弘亮(7) coding(96)
https://qiita.com/kaizen_nagoya/items/866449f129cc8ce4dee7
ctors.c リンカ・ローダ実践開発テクニック 坂井弘亮(8) coding(97)
https://qiita.com/kaizen_nagoya/items/135524de5f8fea10e90f
duplicate.c リンカ・ローダ実践開発テクニック 坂井弘亮(9) coding(123)
https://qiita.com/kaizen_nagoya/items/2339c517f223e556bf67
edata.c リンカ・ローダ実践開発テクニック 坂井弘亮(10) coding(124)
https://qiita.com/kaizen_nagoya/items/bbfe0d6a3c5375026c64
elfread.c リンカ・ローダ実践開発テクニック 坂井弘亮(11) coding(125)
https://qiita.com/kaizen_nagoya/items/600c4a1133dc08da215e
edata.c リンカ・ローダ実践開発テクニック 坂井弘亮(12) coding(126)
https://qiita.com/kaizen_nagoya/items/b6eff6b348d7cf5f257c
hello.c リンカ・ローダ実践開発テクニック 坂井弘亮(13) coding(127)
https://qiita.com/kaizen_nagoya/items/4af05d017d73ebe789d5
inicialize.c リンカ・ローダ実践開発テクニック 坂井弘亮(14) coding(128)
https://qiita.com/kaizen_nagoya/items/4feeb9ef85bfc28fd821
layer.c リンカ・ローダ実践開発テクニック 坂井弘亮(15) coding(129)
https://qiita.com/kaizen_nagoya/items/90bb95f9e538e66d2dbf
ordermain.c リンカ・ローダ実践開発テクニック 坂井弘亮(16) coding(130)
https://qiita.com/kaizen_nagoya/items/446a6768a0abdd13c8b5
pointer.c リンカ・ローダ実践開発テクニック 坂井弘亮(17) coding(131)
https://qiita.com/kaizen_nagoya/items/68cae98797c2e6018499
rasm.c リンカ・ローダ実践開発テクニック 坂井弘亮(18) coding(132)
https://qiita.com/kaizen_nagoya/items/6c3ac31457551e788163
section.c リンカ・ローダ実践開発テクニック 坂井弘亮(19) coding(133)
https://qiita.com/kaizen_nagoya/items/00aadb9a9c0a222ebce2
setjmp.c リンカ・ローダ実践開発テクニック 坂井弘亮(20) coding(134)
https://qiita.com/kaizen_nagoya/items/648200e728c982e79819
sample.c リンカ・ローダ実践開発テクニック 坂井弘亮(21) coding(135)
https://qiita.com/kaizen_nagoya/items/360d99ed47ddc4780bf2
stack_sample.c リンカ・ローダ実践開発テクニック 坂井弘亮(22) coding(136)
https://qiita.com/kaizen_nagoya/items/06a4c9eb6edd1921dca7
N3220 Information technology — Programming languages — C N3220 working draft
https://www.open-std.org/JTC1/SC22/WG14/www/docs/n3220.pdf
N3219 Information technology — Programming languages — C ISO/IEC 9899:2023 DIS Draft
https://www.open-std.org/jtc1/sc22/wg14/www/docs/n3219.pdf
ardump
LinerLoaderTech
https://www.cqpub.co.jp/interface/download/2005/02/linker/LinkerLoaderTech.zip
#include <stdlib.h>
#include <string.h>
#include <fcntl.h>
#include <unistd.h>
#include <elf.h>
#include <ar.h>
#include <sys/stat.h>
#include <sys/mman.h>
static int elfdump(char *head)
{
Elf_Ehdr *ehdr;
Elf_Shdr *shdr, *shstr, *str, *sym, *rel;
Elf_Phdr *phdr;
Elf_Sym *symp;
Elf_Rel *relp;
int i, j, size;
char *sname;
ehdr = (Elf_Ehdr *)head;
if (!IS_ELF(*ehdr)) {
fprintf(stderr, "This is not ELF file.\n");
return (1);
}
if (ehdr->e_ident[EI_CLASS] != ELF_CLASS) {
fprintf(stderr, "unknown class. (%d)\n", (int)ehdr->e_ident[EI_CLASS]);
return (1);
}
if (ehdr->e_ident[EI_DATA] != ELF_DATA) {
fprintf(stderr, "unknown endian. (%d)\n", (int)ehdr->e_ident[EI_DATA]);
return (1);
}
/* •ª•Ø•∑•Á•ÛÃæ≥ «ºÕ—•ª•Ø•∑•Á•Û(.shstrtab)§ŒºË∆¿ */
shstr = (Elf_Shdr *)(head + ehdr->e_shoff +
ehdr->e_shentsize * ehdr->e_shstrndx);
/* •ª•Ø•∑•Á•ÛÃæ∞ÏÕ˜§Ú…Ωº® */
printf("Sections:\n");
for (i = 0; i < ehdr->e_shnum; i++) { /* •ª•Ø•∑•Á•Û•ÿ•√•¿•∆°º•÷•Î§Ú∏°∫˜ */
shdr = (Elf_Shdr *)(head + ehdr->e_shoff + ehdr->e_shentsize * i);
sname = (char *)(head + shstr->sh_offset + shdr->sh_name);
printf("\t[%d]\t%s\n", i, sname);
if (!strcmp(sname, ".strtab")) str = shdr;
}
/* •ª•∞•·•Û•»∞ÏÕ˜§Ú…Ωº® */
printf("Segments:\n");
for (i = 0; i < ehdr->e_phnum; i++) { /* •◊•Ì•∞•È•‡•ÿ•√•¿•∆°º•÷•Î§Ú∏°∫˜ */
phdr = (Elf_Phdr *)(head + ehdr->e_phoff + ehdr->e_phentsize * i);
printf("\t[%d]\t", i);
for (j = 0; j < ehdr->e_shnum; j++) { /* •ª•Ø•∑•Á•Û•ÿ•√•¿•∆°º•÷•Î§Ú∏°∫˜ */
shdr = (Elf_Shdr *)(head + ehdr->e_shoff + ehdr->e_shentsize * j);
size = (shdr->sh_type != SHT_NOBITS) ? shdr->sh_size : 0;
if (shdr->sh_offset < phdr->p_offset) continue;
if (shdr->sh_offset + size > phdr->p_offset + phdr->p_filesz) continue;
sname = (char *)(head + shstr->sh_offset + shdr->sh_name);
printf("%s ", sname);
}
printf("\n");
}
/* •∑•Û•‹•ÎÃæ∞ÏÕ˜§Ú…Ωº® */
printf("Symbols:\n");
for (i = 0; i < ehdr->e_shnum; i++) { /* •∑•Û•‹•Î•∆°º•÷•Î§Ú∏°∫˜ */
shdr = (Elf_Shdr *)(head + ehdr->e_shoff + ehdr->e_shentsize * i);
if (shdr->sh_type != SHT_SYMTAB) continue;
sym = shdr;
for (j = 0; j < sym->sh_size / sym->sh_entsize; j++) {
symp = (Elf_Sym *)(head + sym->sh_offset + sym->sh_entsize * j);
if (!symp->st_name) continue;
printf("\t[%d]\t%d\t%d\t%s\n",
j, (int)ELF_ST_TYPE(symp->st_info), symp->st_size,
(char *)(head + str->sh_offset + symp->st_name));
}
}
/* ∫∆«€√÷§π§Î•∑•Û•‹•Î∞ÏÕ˜§Ú…Ωº® */
printf("Relocations:\n");
for (i = 0; i < ehdr->e_shnum; i++) { /* ∫∆«€√÷•∆°º•÷•Î§Ú∏°∫˜ */
shdr = (Elf_Shdr *)(head + ehdr->e_shoff + ehdr->e_shentsize * i);
if ((shdr->sh_type != SHT_REL) && (shdr->sh_type != SHT_RELA)) continue;
rel = shdr;
for (j = 0; j < rel->sh_size / rel->sh_entsize; j++) {
relp = (Elf_Rel *)(head + rel->sh_offset + rel->sh_entsize * j);
symp = (Elf_Sym *)(head + sym->sh_offset +
(sym->sh_entsize * ELF_R_SYM(relp->r_info)));
if (!symp->st_name) continue;
printf("\t[%d]\t%d\t%s\n",
j, ELF_R_SYM(relp->r_info),
(char *)(head + str->sh_offset + symp->st_name));
}
}
return (0);
}
int main(int argc, char *argv[])
{
int fd, size;
struct stat sb;
char *head, *fname;
struct ar_hdr *arhdr, *nhdr = NULL;
fd = open(argv[1], O_RDONLY);
if (fd < 0) exit (1);
fstat(fd, &sb);
head = mmap(NULL, sb.st_size, PROT_READ, MAP_SHARED, fd, 0);
if (!memcmp(head, ARMAG, SARMAG)) {
fprintf(stderr, "This is archive file.\n");
for (arhdr = (struct ar_hdr *)(head + SARMAG);
(char *)arhdr < head + sb.st_size;
arhdr = (struct ar_hdr *)((char *)arhdr + sizeof(struct ar_hdr) + size)) {
size = atoi(arhdr->ar_size);
if (!memcmp(arhdr->ar_name, "/ ", 2)) {
fprintf(stderr, "symbol table found.\n");
} else if (!memcmp(arhdr->ar_name, "//", 2)) {
fprintf(stderr, "string table found.\n");
nhdr = arhdr;
} else {
if (arhdr->ar_name[0] == '/') {
if (nhdr == NULL) {
fprintf(stderr, "string table not found.\n");
exit (1);
}
fname = (char *)nhdr + sizeof(struct ar_hdr) + atoi(&arhdr->ar_name[1]);
} else {
fname = arhdr->ar_name;
}
fprintf(stderr, "found: %.*s\n", strchr(fname, '/') - fname, fname);
elfdump((char *)arhdr + sizeof(struct ar_hdr));
}
if (size % 2) size++;
}
} else {
elfdump(head);
}
munmap(head, sb.st_size);
close(fd);
exit (0);
}
エンジニアとしての考え方
ソースコードから出発してもよい。
C言語規格から出発してもよい。
コンパイラから出発してもよい。
少なくとも、3つの道はひらけている。
上記の3つの道以外の「C言語教育」には近寄らない方がいいかもしれない。
ソースコード
何か一つのコンパイラでコンパイルしてみる。
コンパイラそのものを深掘りするよりも、
そのコンパイラで、このコードが通るようにすることに専念する。
コンパイルエラーが出たら記録する。
Error一覧(C/C++, python, bash...) Error(0)
https://qiita.com/kaizen_nagoya/items/48b6cbc8d68eae2c42b8
コードがプログラマの意図通りの動作をするかどうかを確認する。
validationともいう。
C言語規格
C言語規格には、FreestandingというPosixOSを使わない仕様と、
HostedというPosixOSを使う仕様がある。
Hostedの場合には、関数がC言語の関数かPosixの関数かを調べるとよい。
https://pubs.opengroup.org/onlinepubs/9699919799/
The C++ Standard Library: clang++とg++でコンパイルしてみた(まとめ):14件
https://qiita.com/kaizen_nagoya/items/9bdfaa392443d13e5759
C++17 - The Complete Guide clang++とg++でコンパイルしてみた(まとめ):4件
https://qiita.com/kaizen_nagoya/items/c000f307e642990781e1
C++N3242, 2011, ISO/IEC 14882, C++ standard(1) Example code compile list
https://qiita.com/kaizen_nagoya/items/685b5c1a2c17c1bf1318
C++N4606 Working Draft 2016, ISO/IEC 14882, C++ standard(1) Example code compile list
https://qiita.com/kaizen_nagoya/items/df5d62c35bd6ed1c3d43/
C++N4741, 2018 Standard Working Draft on ISO/IEC 14882 sample code compile list
https://qiita.com/kaizen_nagoya/items/3294c014044550896010
C++N4910:2022 Standard Working Draft on ISO/IEC 14882(0) sample code compile list
https://qiita.com/kaizen_nagoya/items/fc957ddddd402004bb91
Autosar Guidelines C++14 example code compile list(1-169)
https://qiita.com/kaizen_nagoya/items/8ccbf6675c3494d57a76
コンパイラ
gccとClangと、Visual Studioの3つのコンパイラでコンパイルしてみるとよい。
3つのコンパイラでコンパイルできるコードは、Portabilityがあると言えるかもしれない。
gcc/g++(GNU) v.s. Clang/Clang++(LLVM) コンパイラ警告等比較、Error(13), C++(36)
https://qiita.com/kaizen_nagoya/items/9a82b958cc3aeef0403f
コンパイル用shell script C版(clangとgcc)とC++版(clang++とg++)
https://qiita.com/kaizen_nagoya/items/74220c0577a512c2d7da
関数調査
C言語と、POSIXで検索する。
main
posix hosted implementation startup function.
It is not necesary in freestaindig implementation.
C N3219 5.1.2.3 Hosted environment
5.1.2.3.2 Program startup
The function called at program startup is named main. The implementation declares no prototype for this function. It shall be defined with a return type of int and with no parameters:
int main(void) { /* ... */ }
or with two parameters (referred to here as argc and argv, though any names may be used, as they
are local to the function in which they are declared):
int main(int argc, char *argv[]) { /* ... */ }
or equivalent;6) or in some other implementation-defined manner.
open
Posix open
https://pubs.opengroup.org/onlinepubs/9699919799/functions/open.html
#include <fcntl.h>
int open(const char *path, int oflag, ...);
fstat
posix fstat
https://pubs.opengroup.org/onlinepubs/007904875/functions/fstat.html
#include <sys/stat.h>
int fstat(int fildes, struct stat *buf);
mmap
posix mmap
https://pubs.opengroup.org/onlinepubs/9699919799/functions/mmap.html
#include <sys/mman.h>
void *mmap(void *addr, size_t len, int prot, int flags,
int fildes, off_t off);
memcmp
C N3219 7.26.4 Comparison functions
7.26.4.1 The memcmp function
#include <string.h>
int memcmp(const void *s1, const void *s2, size_t n);
fprintf
C N3219 7.8 Format conversion of integer types
7.8.1 Macros for format specifiers
The fprintf macros for signed integers are:
PRIdN PRIdLEASTN PRIdFASTN PRIdMAX PRIdPTR
PRIiN PRIiLEASTN PRIiFASTN PRIiMAX PRIiPTR
The fprintf macros for unsigned integers are:
PRIbN PRIbLEASTN PRIbFASTN PRIbMAX PRIbPTR PRIoN PRIoLEASTN PRIoFASTN PRIoMAX PRIoPTR PRIuN PRIuLEASTN PRIuFASTN PRIuMAX PRIuPTR PRIxN PRIxLEASTN PRIxFASTN PRIxMAX PRIxPTR PRIXN PRIXLEASTN PRIXFASTN PRIXMAX PRIXPTR
The following fprintf macros for unsigned integer types are optional: PRIBN PRIBLEASTN PRIBFASTN PRIBMAX PRIBPTR
atoi
C N3219 7.24.1 Numeric conversion functions
7.24.1.2 The atoi, atol, and atoll functions
#include <stdlib.h>
int atoi(const char *nptr);
sizeof
C N3219 6.7.3 Type specifiers
6.7.3.6 Typeof specifiers
EXAMPLE 3 The equivalence between sizeof and typeof’s deduction of the type means this program has no constraint violations:
int main (int argc, char* argv[]) { static_assert(sizeof(typeof(’p’)) ==
sizeof(int)); static_assert(sizeof(typeof(’p’)) == sizeof(’p’));
static_assert(sizeof(typeof((char)’p’)) == sizeof(char));
static_assert(sizeof(typeof((char)’p’)) == sizeof((char)’p’));
static_assert(sizeof(typeof("meow")) == sizeof(char[5]));
static_assert(sizeof(typeof("meow")) == sizeof("meow"));
static_assert(sizeof(typeof(argc)) == sizeof(int));
static_assert(sizeof(typeof(argc)) == sizeof(argc));
static_assert(sizeof(typeof(argv)) == sizeof(char**));
static_assert(sizeof(typeof(argv)) == sizeof(argv));
}
static_assert(sizeof(typeof_unqual(’p’)) == sizeof(int));
static_assert(sizeof(typeof_unqual(’p’)) == sizeof(’p’));
static_assert(sizeof(typeof_unqual((char)’p’)) == sizeof(char));
static_assert(sizeof(typeof_unqual((char)’p’)) == sizeof((char)’p’));
static_assert(sizeof(typeof_unqual("meow")) == sizeof(char[5]));
static_assert(sizeof(typeof_unqual("meow")) == sizeof("meow"));
static_assert(sizeof(typeof_unqual(argc)) == sizeof(int));
static_assert(sizeof(typeof_unqual(argc)) == sizeof(argc));
static_assert(sizeof(typeof_unqual(argv)) == sizeof(char**));
static_assert(sizeof(typeof_unqual(argv)) == sizeof(argv));
return 0;
elfdump
bsd:elfdump()
https://man.freebsd.org/cgi/man.cgi?query=elfdump&sektion=1
munmap
posix:munmap
https://pubs.opengroup.org/onlinepubs/009604499/functions/munmap.html
#include <sys/mman.h>
int munmap(void *addr, size_t len); [Option End]
URL
502: Bad Gateway
リクエストの処理に時間がかかっています。しばらくしてから再度お試しください。
このページが繰り返し表示される場合は
support@qiita.comまでご連絡ください。
なお、Twitterにて最新の情報を配信しております。
ログインせずにアクセスすると表示する。理由は不明。
関連資料
私が効果を確認した「小川メソッド」
https://qiita.com/kazuo_reve/items/a3ea1d9171deeccc04da
自己記事一覧
Qiitaの記事に3段階または5段階で到達するための方法
https://qiita.com/kaizen_nagoya/items/6e9298296852325adc5e
物理記事 上位100
https://qiita.com/kaizen_nagoya/items/66e90fe31fbe3facc6ff
量子(0) 計算機, 量子力学
https://qiita.com/kaizen_nagoya/items/1cd954cb0eed92879fd4
数学関連記事100
https://qiita.com/kaizen_nagoya/items/d8dadb49a6397e854c6d
統計(0)一覧
https://qiita.com/kaizen_nagoya/items/80d3b221807e53e88aba
品質一覧
https://qiita.com/kaizen_nagoya/items/2b99b8e9db6d94b2e971
言語・文学記事 100
https://qiita.com/kaizen_nagoya/items/42d58d5ef7fb53c407d6
医工連携関連記事一覧
https://qiita.com/kaizen_nagoya/items/6ab51c12ba51bc260a82
自動車 記事 100
https://qiita.com/kaizen_nagoya/items/f7f0b9ab36569ad409c5
通信記事100
https://qiita.com/kaizen_nagoya/items/1d67de5e1cd207b05ef7
日本語(0)一欄
https://qiita.com/kaizen_nagoya/items/7498dcfa3a9ba7fd1e68
英語(0) 一覧
https://qiita.com/kaizen_nagoya/items/680e3f5cbf9430486c7d
転職(0)一覧
https://qiita.com/kaizen_nagoya/items/f77520d378d33451d6fe
仮説(0)一覧(目標100現在40)
https://qiita.com/kaizen_nagoya/items/f000506fe1837b3590df
音楽 一覧(0)
https://qiita.com/kaizen_nagoya/items/b6e5f42bbfe3bbe40f5d
「@kazuo_reve 新人の方によく展開している有益な情報」確認一覧
https://qiita.com/kaizen_nagoya/items/b9380888d1e5a042646b
Qiita(0)Qiita関連記事一覧(自分)
https://qiita.com/kaizen_nagoya/items/58db5fbf036b28e9dfa6
鉄道(0)鉄道のシステム考察はてっちゃんがてつだってくれる
https://qiita.com/kaizen_nagoya/items/26bda595f341a27901a0
安全(0)安全工学シンポジウムに向けて: 21
https://qiita.com/kaizen_nagoya/items/c5d78f3def8195cb2409
一覧の一覧( The directory of directories of mine.) Qiita(100)
https://qiita.com/kaizen_nagoya/items/7eb0e006543886138f39
Ethernet 記事一覧 Ethernet(0)
https://qiita.com/kaizen_nagoya/items/88d35e99f74aefc98794
Wireshark 一覧 wireshark(0)、Ethernet(48)
https://qiita.com/kaizen_nagoya/items/fbed841f61875c4731d0
線網(Wi-Fi)空中線(antenna)(0) 記事一覧(118/300目標)
https://qiita.com/kaizen_nagoya/items/5e5464ac2b24bd4cd001
OSEK OS設計の基礎 OSEK(100)
https://qiita.com/kaizen_nagoya/items/7528a22a14242d2d58a3
Error一覧 error(0)
https://qiita.com/kaizen_nagoya/items/48b6cbc8d68eae2c42b8
++ Support(0)
https://qiita.com/kaizen_nagoya/items/8720d26f762369a80514
Coding(0) Rules, C, Secure, MISRA and so on
https://qiita.com/kaizen_nagoya/items/400725644a8a0e90fbb0
プログラマによる、プログラマのための、統計(0)と確率のプログラミングとその後
https://qiita.com/kaizen_nagoya/items/6e9897eb641268766909
なぜdockerで機械学習するか 書籍・ソース一覧作成中 (目標100)
https://qiita.com/kaizen_nagoya/items/ddd12477544bf5ba85e2
言語処理100本ノックをdockerで。python覚えるのに最適。:10+12
https://qiita.com/kaizen_nagoya/items/7e7eb7c543e0c18438c4
プログラムちょい替え(0)一覧:4件
https://qiita.com/kaizen_nagoya/items/296d87ef4bfd516bc394
Python(0)記事をまとめたい。
https://qiita.com/kaizen_nagoya/items/088c57d70ab6904ebb53
官公庁・学校・公的団体(NPOを含む)システムの課題、官(0)
https://qiita.com/kaizen_nagoya/items/04ee6eaf7ec13d3af4c3
「はじめての」シリーズ ベクタージャパン
https://qiita.com/kaizen_nagoya/items/2e41634f6e21a3cf74eb
AUTOSAR(0)Qiita記事一覧, OSEK(75)
https://qiita.com/kaizen_nagoya/items/89c07961b59a8754c869
プログラマが知っていると良い「公序良俗」
https://qiita.com/kaizen_nagoya/items/9fe7c0dfac2fbd77a945
LaTeX(0) 一覧
https://qiita.com/kaizen_nagoya/items/e3f7dafacab58c499792
自動制御、制御工学一覧(0)
https://qiita.com/kaizen_nagoya/items/7767a4e19a6ae1479e6b
Rust(0) 一覧
https://qiita.com/kaizen_nagoya/items/5e8bb080ba6ca0281927
100以上いいねをいただいた記事16選
https://qiita.com/kaizen_nagoya/items/f8d958d9084ffbd15d2a
小川清最終講義、最終講義(再)計画, Ethernet(100) 英語(100) 安全(100)
https://qiita.com/kaizen_nagoya/items/e2df642e3951e35e6a53
<この記事は個人の過去の経験に基づく個人の感想です。現在所属する組織、業務とは関係がありません。>
This article is an individual impression based on my individual experience. It has nothing to do with the organization or business to which I currently belong.
文書履歴(document history)
ver. 0.01 初稿 20240706
最後までおよみいただきありがとう4ざいました。
いいね 💚、フォローをお願いします。
Thank you very much for reading to the last sentence.
Please press the like icon 💚 and follow me for your happy life.