Просто не можах да се сдържа, а и как да не публикувам това при условие, че е колкото смешно толкова и жалко. Случката не си я измислям и ми се случи преди няколко дена. Смешно - трагичното е как един системен администратор от малък провинциален град, (в който съм роден аз) се опитва да покаже знания в областта на програмирането. И така, бяхме седнали в едно заведение и почнахме да говорим естествено за Линукс, като в един момент въпросния човек ми задава въпросът: "Ти знаеш ли функцията 'ФОРКЕ'? Знаеш ли какво прави?!?!" При което реакцията от моя страна беше голямо изненадване. Все пак за първи път чувах такава функция и се опитвах да направя асоциация с нещо сходно, но преди да отговоря веднага бях стопиран с въпрос: "Как не знаеш 'ФОРКЕ', като програмираш под Линукс?!?! Аз как я знам, а и ако знаеш колко шелове съм хакнал с нея..." Последва веднага от моя страна корекция, че функцията е fork(void) /*'ФОРК'*/, но така и не разбрах как с тази функция се хакват Shell-ове. Незнам защо, но системните администратори в големите градове /*поне тези които познавам*/ си казват честно, че от програмиране не разбират и не се опитват да спорят за неща, които не разбират, така както аз не споря за неща от тяхната област.
Това не е с цел да обидя някой. Просто ми се стори адски смешно, а и най-вече това до къде може да доведе незнанието на хората с голямо желание да се изтъкнат пред някой. Това доста често ми се случва в това градче.
А какво прави fork? Може да го видите от man fork. А ето и самата страница:
Цитат |
NAME fork - create a child process
SYNOPSIS #include #include
pid_t fork(void);
DESCRIPTION fork creates a child process that differs from the parent process only in its PID and PPID, and in the fact that resource utilizations are set to 0. File locks and pending signals are not inherited.
Under Linux, fork is implemented using copy-on-write pages, so the only penalty incurred by fork is the time and memory required to duplicate the parent's page tables, and to create a unique task structure for the child.
RETURN VALUE On success, the PID of the child process is returned in the parent's thread of execution, and a 0 is returned in the child's thread of execution. On fail- ure, a -1 will be returned in the parent's context, no child process will be created, and errno will be set appropriately.
ERRORS EAGAIN fork cannot allocate sufficient memory to copy the parent's page tables and allocate a task structure for the child.
EAGAIN It was not possible to create a new process because the caller's RLIMIT_NPROC resource limit was encountered. To exceed this limit, the process must have either the CAP_SYS_ADMIN or the CAP_SYS_RESOURCE capability.
ENOMEM fork failed to allocate the necessary kernel structures because memory is tight.
CONFORMING TO The fork call conforms to SVr4, SVID, POSIX, X/OPEN, BSD 4.3.
|
Ако някой може да ми обясни как само с тази функция се хакват shell-ове ще съм му много благодарен. И аз поне ще науча нещо.