Смерть -это решение всех проблем. Нет человека - нет проблемы
Comp1: Ubuntu 16.04 Comp2: Arch Linux
Comp3: Ubuntu Server 16.04 Comp4: Centos 6.5
Comp5: Linux mint 16 Comp6: Raspberry pi (olika OS hela tiden)
Phone: Motorola Google Nexus 6
c/c++ popen/pclose || är det en bra eller dålig implemntation?
En hake är att du dödar nuvarande användarens alla vlc-processer. Om du inte behöver stdout och bara vill starta processen och döda den efter viss tid/ett ett specifikt kriterium borde något i stil med detta fungera
#include <stdio.h>
#include <signal.h>
#include <sys/types.h>
#include <unistd.h>
int main() {
pid_t child_pid = fork();
if (child_pid == 0) {
while (1) {
printf("child process\n");
sleep(1);
}
} else {
printf("time to sleep, main process\n");
sleep(5);
printf("die, child process!\n");
kill(child_pid, SIGKILL);
}
}
...om du byter ut den meningslösa child-loopen mot någon lämplig variant av exec och ändrar SIGKILL till SIGTERM.
Senare hade jag i tanke att eventuellt göra något med stdout, men till en början vill jag bara får den att hantera olika program genom att slå på och döda dem.
Hur som helst har jag testa en liknade de du föreslår ovan (koden nedan är tagen från stackoverflow):
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <signal.h>
#include <string.h>
#include <sys/wait.h>
#include <errno.h>
#include <string>
#include <sstream>
using namespace std;
#define READ 0
#define WRITE 1
FILE * popen2(string command, string type, int & pid)
{
pid_t child_pid;
int fd[2];
pipe(fd);
if((child_pid = fork()) == -1)
{
perror("fork");
exit(1);
}
/* child process */
if (child_pid == 0)
{
if (type == "r")
{
close(fd[READ]); //Close the READ end of the pipe since the child's fd is write-only
dup2(fd[WRITE], 1); //Redirect stdout to pipe
}
else
{
close(fd[WRITE]); //Close the WRITE end of the pipe since the child's fd is read-only
dup2(fd[READ], 0); //Redirect stdin to pipe
}
setpgid(child_pid, child_pid); //Needed so negative PIDs can kill children of /bin/sh
execl("/bin/sh", "/bin/sh", "-c", command.c_str(), NULL);
exit(0);
}
else
{
if (type == "r")
{
close(fd[WRITE]); //Close the WRITE end of the pipe since parent's fd is read-only
}
else
{
close(fd[READ]); //Close the READ end of the pipe since parent's fd is write-only
}
}
pid = child_pid;
if (type == "r")
{
return fdopen(fd[READ], "r");
}
return fdopen(fd[WRITE], "w");
}
int pclose2(FILE * fp, pid_t pid)
{
int stat;
fclose(fp);
while (waitpid(pid, &stat, 0) == -1)
{
if (errno != EINTR)
{
stat = -1;
break;
}
}
return stat;
}
int main()
{
int pid;
string command = "ls -l";
FILE * fp = popen2(command, "r", pid);
char command_out[100] = {0};
stringstream output;
//Using read() so that I have the option of using select() if I want non-blocking flow
while (read(fileno(fp), command_out, sizeof(command_out)-1) != 0)
{
output << string(command_out);
// https://linux.die.net/man/2/kill
kill(-pid, 9);
memset(&command_out, 0, sizeof(command_out));
}
string token;
while (getline(output, token, '\n'))
printf("OUT: %s\n", token.c_str());
pclose2(fp, pid);
return 0;
}
Vilket jag använde mig av för att göra vlc test grej med där jag bara skrev om main till:
int main(){
FILE *fd;
Timer timer;
int pid;
fd = popen2("vlc", "r", pid);
if( fd == NULL ){
std::cout << "Shit is going done" << std::endl;
}
while(10000.0 > timer.elapsed()){
std::cout << "Still waiting" << std::endl;
}
// https://linux.die.net/man/2/kill
kill(-pid, 9);
std::cout << "After wait" << std::endl;
pclose2(fd, pid);
}
Problemet är att de nedre koden där jag skrev om main, så dödar den fortfarande inte VLC. Men enligt denna länk är sigkill = 9. Då den koden på stackoverflow använder sig av negativa PID för att döda innebär att den dödar hela process gruppen med -pid, enligt denna länk.
Det var då jag skrev min "ful" kod längst upp. För jag förstår inte varför VLC lever.
P.S här nedan är TIMER koden:
#ifndef _TIMER_H_
#define _TIMER_H_
#include <chrono>
#include <thread>
class Timer {
typedef std::chrono::high_resolution_clock clock;
public:
Timer():start(clock::now()){}
inline void reset() {
start = clock::now();
}
inline void sleep(int n) const{
std::this_thread::sleep_for(std::chrono::milliseconds(n));
}
inline double elapsed() const {
return std::chrono::duration_cast<std::chrono::milliseconds>(clock::now() - start).count();
}
private:
std::chrono::time_point<clock> start;
};
#endif /*_TIMER_H_*/
Смерть -это решение всех проблем. Нет человека - нет проблемы
Comp1: Ubuntu 16.04 Comp2: Arch Linux
Comp3: Ubuntu Server 16.04 Comp4: Centos 6.5
Comp5: Linux mint 16 Comp6: Raspberry pi (olika OS hela tiden)
Phone: Motorola Google Nexus 6
- 26 / 4 Corsair Platform 6: För dig som inte nöjer dig med Ikea-skrivbord 11
- 26 / 4 Rykte: Switch 2 släpps i höst – OLED-variant dröjer 35
- 26 / 4 Iphones marknadsandel faller i USA 43
- 25 / 4 Airtec Pro Type1 – batteridrivet alternativ till tryckluft på burk 93
- 25 / 4 Nu stiger hårddiskpriserna med uppemot 10 procent 23
- Stöd för komprimering i fler format på gång till Windows7
- 1080ti samt 3060ti0
- Elbilar - Tråden för intresserade23198
- Vilken bok läste du senast?200
- Har Microsoft blockad nätverket?11
- Guide: Sätta upp en RAM-disk för Nvidia Instant Replay (f.d. Shadowplay)80
- Formel 1-tråden8894
- Vilket VR-headset ska jag köpa?883
- Airtec Pro Type1 – batteridrivet alternativ till tryckluft på burk93
- SFW! Känn doften av nyklippt gräs med Dreame Roboticmower A139
- Köpes 17" laptop köpes.
- Köpes Sökes SFX powersupply, 400-750 watt
- Säljes Säljer helt NYTT Vengeance 32GB RGB DDR5 6000Mhz
- Säljes Bärbar ASUS 4800H, RTX 2060, 512 GB SSD, 16 GB RAM
- Säljes Helt NYTT Gigabyte Z790 Aorus Elite AX.
- Säljes Valve Index VR Kit
- Köpes Playstation 4 Pro
- Säljes 2x Xeon 5365 3.0GHz + 8gb DDR2 667MHz + Nvidia GT7300 GPU
- Säljes Lian Li O11 Dynamic XL svart samt 360mm radiatorer
- Säljes Xbox Elite Wireless Series 2 handkontroll
- Stöd för komprimering i fler format på gång till Windows7
- Krönika: "Early access" är utstuderad girighet35
- Övergivet skadeprogram infekterar miljontals maskiner11
- Helgsnack: Är all reklam till ondo?74
- Microsoft släpper källkoden till MS‑DOS 4.0016
- Ny caps lock-symbol i Windows förbryllar HP-användare21
- Corsair Platform 6: För dig som inte nöjer dig med Ikea-skrivbord11
- Rykte: Switch 2 släpps i höst – OLED-variant dröjer35
- NetonNet varnar om läckta kunduppgifter23
- Premiär på SweClockers! Månadens drop med gamingskärm hos Elgiganten74