Vì vậy, công việc của tôi là viết một hàm sẽ hoạt động như sau:
ps-ef| tr -s ' ' :| cắt -d: -f1 | sắp xếp | uniq -c |sort -n
Đây là mã của tôi:
ống vô hiệu4 ()
{
int pdesk1[2];
int pdesk2[2];
int pdesk3[2];
int pdesk4[2];
int pdesk5[2];
đường ống (pdesk1);
đường ống (pdesk2);
đường ống (pdesk3);
đường ống (pdesk4);
đường ống (pdesk5);
nếu (pdesk1 < 0 || pdesk2 < 0 || pdesk3 < 0 || pdesk4 < 0 || pdesk5 < 0)
{
perror("ống");
thoát(1);
}
nếu (ngã ba() == 0)
{
dup2(pdesk1[1], 1);
đóng(pdesk1[0]);
đóng(pdesk1[1]);
execlp("ps", "ps", "-e", "-f", NULL);
lỗi ("ps");
thoát(1);
}
nếu (ngã ba() == 0)
{
dup2(pdesk1[0], 0);
dup2(pdesk2[1], 1);
đóng(pdesk2[0]);
đóng(pdesk2[1]);
đóng(pdesk1[0]);
đóng(pdesk1[1]);
execlp("tr", "tr", "-s", " ", ":", NULL);
perror("tr");
thoát(1);
}
nếu (ngã ba() == 0)
{
dup2(pdesk2[0], 0);
dup2(pdesk3[1], 1);
đóng(pdesk3[0]);
đóng(pdesk3[1]);
đóng(pdesk2[0]);
đóng(pdesk2[1]);
execlp("cắt", "cắt", "-d", ":", "-f", "1", NULL);
perror("cắt");
thoát(1);
}
nếu (ngã ba() == 0)
{
dup2(pdesk3[0], 0);
// bình luận để xem kết quả tại thời điểm này
// dup2(pdesk4[1], 1);
đóng(pdesk4[0]);
đóng(pdesk4[1]);
đóng(pdesk3[0]);
đóng(pdesk3[1]);
//cái này in ra không có gì
execlp("sắp xếp", "sắp xếp", NULL);
// nhưng cái này hoạt động
// execlp("đầu", "đầu", NULL);
perror("sắp xếp");
thoát(1);
}
nếu (ngã ba() == 0)
{
dup2(pdesk4[0], 0);
dup2(pdesk5[1], 1);
đóng(pdesk5[0]);
đóng(pdesk5[1]);
đóng(pdesk4[0]);
đóng(pdesk4[1]);
execlp("uniq", "uniq", "-c", NULL);
perror("uniq");
thoát(1);
}
nếu (ngã ba() == 0)
{
dup2(pdesk5[0], 0);
đóng(pdesk5[0]);
đóng(pdesk5[1]);
execlp("sắp xếp", "sắp xếp", "-n", NULL);
perror("sắp xếp -n");
thoát(1);
}
đợi (NULL);
thoát(1);
}
Vì vậy, như tôi đã viết trong phần nhận xét, cho đến khi phần sắp xếp hoạt động tốt, tôi đã kiểm tra kết quả đầu ra trong mỗi quy trình và so sánh nó với kết quả tôi nhận được bằng cách viết lệnh trong thiết bị đầu cuối.
Tôi thậm chí còn bối rối hơn vì tôi phát hiện ra rằng khi tôi thay thế sắp xếp bằng đầu (hoặc mèo chẳng hạn), mã hoạt động, uniq dường như hoạt động tốt và sau đó lại sắp xếp cuối cùng không hoạt động.