द्वारा बार-बार अनब्लॉक किया गया है, मैं एक प्रोग्राम लिख रहा हूं जो फ़ाइल से यूनिक्स कमांड की एक सूची लेता है और क्रमशः उन्हें निष्पादित करता है। सबकुछ क्रम में रखने के लिए, मेरे पास प्रत्येक कमांड प्रारंभ होना चाहिए और SIGUSR1
के लिए sigwait()
के माध्यम से प्रतीक्षा करना होगा। जब प्रत्येक आदेश प्रारंभ होता है, तो प्रत्येक आदेश निष्पादित कर सकता है।sigwait() SIGUSR1
उपयोग: > program.c input.txt
हालांकि, ऐसा लगता है कि SIGUSR1 बार-बार कहा जाता है पूरी तरह से sigwait()
आगे निकल गए। यहाँ क्या हो रहा है? मैंने कई अलग-अलग चीजों की कोशिश की है, लेकिन हाल ही में इसे this answer के बाद मॉडलिंग किया गया है। पुन: प्रयास करने के लिए, मैं चाहता हूं कि प्रारंभिकरण के तुरंत बाद संकेतों के लिए सिग्नल उठाया जाए। की कोशिश की sigaction()
को signal()
बदलते: मैं जब सभी आदेशों पूरी तरह से प्रारंभ कर रहे हैं
#include <stdio.h>
#include <signal.h>
#include <string.h>
#include <stdlib.h>
#include <unistd.h>
void on_sigusr1(int sig)
{
// Note: Normally, it's not safe to call almost all library functions in a
// signal handler, since the signal may have been received in a middle of a
// call to that function.
printf("SIGUSR1 received!\n");
}
int main(int arc, char* argv[])
{
FILE *file;
file = fopen(argv[1] ,"r");
int BUF_SIZE = 100;
char *token;
char buffer[BUF_SIZE];
char programs[BUF_SIZE];
char *commands[BUF_SIZE];
int i = 0;
int counter = 1;
while (fgets(buffer, sizeof buffer, file) != NULL)
{
strcpy(programs, buffer);
int length = strlen(buffer)-1;
if (buffer[length] == '\n')
{
buffer[length] = '\0';
}
i = 0;
token = strtok(buffer," ");
while(token != NULL)
{
commands[i++] = token;
token = strtok(NULL, " ");
}
commands[i] = 0;
pid_t pids[counter];
// Set a signal handler for SIGUSR1
signal(SIGUSR1, &on_sigusr1);
// At program startup, SIGUSR1 is neither blocked nor pending, so raising it
// will call the signal handler
raise(SIGUSR1);
// Now let's block SIGUSR1
sigset_t sigset;
sigemptyset(&sigset);
sigaddset(&sigset, SIGUSR1);
sigprocmask(SIG_BLOCK, &sigset, NULL);
// SIGUSR1 is now blocked, raising it will not call the signal handler
printf("About to raise SIGUSR1\n");
raise(SIGUSR1);
printf("After raising SIGUSR1\n");
for(i = 0; i < counter; ++i)
{
pids[i] = fork();
if(pids[i] > 0)
{
printf("Child process %d ready to execute command %s", getpid(), programs);
// SIGUSR1 is now blocked and pending -- this call to sigwait will return
// immediately
int sig;
int result = sigwait(&sigset, &sig);
if(result == 0) {
printf("Child process %d executing command %s", getpid(), programs);
execvp(commands[0], commands);
}
}
}
// All programs have been launched
for(i = 0; i < counter; ++i)
{
wait(&pids[i]);
}
// All programs are waiting to execute
for (i = 0; i < counter; ++i)
{
// SIGUSR1 is now no longer pending (but still blocked). Raise it again and
// unblock it
raise(SIGUSR1);
printf("About to unblock SIGUSR1\n");
sigprocmask(SIG_UNBLOCK, &sigset, NULL);
printf("Unblocked SIGUSR1\n");
}
}
exit(0);
fclose(file);
return 0;
}
अद्यतन संकेत अनवरोधित करना चाहते हैं। कोई परिवर्तन नहीं होता है।
"* ... SIGUSR1 बार-बार कहा जाता है *" एक संकेत नहीं कहा जाता है। कृपया आप वास्तव में क्या व्यक्त करना चाहते हैं? – alk
'सिग्नल' के बजाय 'सिग्नेक्शन' का उपयोग करने का प्रयास करें। –
@alk: मैं चाहता हूं कि प्रारंभिकरण के तुरंत बाद संकेतों के लिए संकेत उठाया जाए। मैं चाहता हूं कि सिग्नल को अनब्लॉक किया जाए जब सभी आदेश पूरी तरह से प्रारंभ हो जाएं। –