⑴ system函数阻塞怎么办
这是进程间同步的问题。解决方法是:fork一个子进程执行system调用,父进程调用 wait 或 waitpid 等待子进程的终止信息。
父进程调用 wait 或 waitpid 时可能会:
? 阻塞(如果它的所有子进程都还在运行)。
? 带子进程的终止信息立即返回(如果一个子进程已终止,正等待父进程读取其终止信息)。
? 出错立即返回(如果它没有任何子进程)。
wait 和 waitpid 这两个函数的区别是:
? 如果父进程的所有子进程都还在运行,调用wait将使父进程阻塞,而调用waitpid时如果在options参数中指定WNOHANG可以使父进程不阻塞而立即返回0。
? wait等待第一个终止的子进程,而waitpid可以通过pid参数指定等待哪一个子进程。
⑵ 关于linux用户级线程阻塞的问题
用户级实现线程时,内核调度是以进程为单位的,内核并不知道用户级线程的存在,因此某个用户级线程的阻塞即会引起整个进程的阻塞。
内核级线程阻塞时,内核完全可以调度同进程内的其它线程运行,也就是没有阻塞整个线程
⑶ linux下system()调用失败,返回32512,但有程序执行结果有时成功有时失败
调用xfs_admin时没有指明所在路径,建议使用绝对路径。
可以在system调用前查询下当前所在目录,看是不是xfs_admin程序所在路径。
#include<unistd.h>
char*getcwd(char*buf,size_tsize);
关于返回值32512,解释如下:
As for the exit code,
Bits 15-8 = Exit code.
Bit 7 = 1 if a core mp was proced.
Bits 6-0 = Signal number that killed the process.
32512 = 0x7F00
So it didn't die from a signal, a core mp wasn't proced, and it exited with code 255.
What 255 means is unclear, which is why it should accompanied by an error message.
⑷ 如何linux 程序中启用其他进程,非阻塞,非popen
在Linux程序中启动其他进程可以用system函数,这个函数会等待它启动的那个程序结束才返回,所以它是一个阻塞调用。还有一种非阻塞的启动外部程序的方法,稍微复杂一点,是运用Linux的exec系列函数,之所以说系列函数是因为有不同的变种,只是参数的形式不同而已,其实完全是一样的,exec系列函数的行为是将当前进程替换成要启动的那个新进程,这里的当前进程就是你编写的程序,新进程启动后调用exec函数的进程就不存在了,exec系列函数调用之后的代码也不会再执行了。所以,exec系列函数的正确使用方法是在程序中进行fork调用复制进程,然后把exec函数的调用语句放在fork的子进程里面,注意子进程中exec函数调用的后面就不要写其他功能的代码了,因为exec函数后面的语句不会被执行。
⑸ 怎么调用system函数,使用Android的linux命令
先来看一下system()函数的简单介绍:
2 int system(const char *command);
system() executes a command specified in command by calling /bin/sh -c command, and returns after the command has been completed. During execution of the command, SIGCHLD will be blocked, and SIGINT and SIGQUIT will be ignored.
system()函数调用/bin/sh来执行参数指定的命令,/bin/sh 一般是一个软连接,指向某个具体的shell,比如bash,-c选项是告诉shell从字符串command中读取命令;
在该command执行期间,SIGCHLD是被阻塞的,好比在说:hi,内核,这会不要给我送SIGCHLD信号,等我忙完再说;
在该command执行期间,SIGINT和SIGQUIT是被忽略的,意思是进程收到这两个信号后没有任何动作。
再来看一下system()函数返回值:
The value returned is -1 on error (e.g. fork(2) failed), and the return status of the command otherwise. This latter return status is in the format specified in wait(2). Thus, the exit code of the command will be WEXITSTATUS(status). In case /bin/sh could not be executed, the exit status will be that of a command that does exit(127).
If the value of command is NULL, system() returns nonzero if the shell is available, and zero if not.
为了更好的理解system()函数返回值,需要了解其执行过程,实际上system()函数执行了三步操作:
1.fork一个子进程;
2.在子进程中调用exec函数去执行command;
3.在父进程中调用wait去等待子进程结束。
对于fork失败,system()函数返回-1。
如果exec执行成功,也即command顺利执行完毕,则返回command通过exit或return返回的值。
(注意,command顺利执行不代表执行成功,比如command:”rm debuglog.txt”,不管文件存不存在该command都顺利执行了)
如果exec执行失败,也即command没有顺利执行,比如被信号中断,或者command命令根本不存在,system()函数返回127.
如果command为NULL,则system()函数返回非0值,一般为1.
popen和system都可以执行外部命令。
popen相当于是先创建一个管道,fork,关闭管道的一端,执行exec,返回一个标准的io文件指针。
system相当于是先后调用了fork, exec,waitpid来执行外部命令
popen本身是不阻塞的,要通过标准io的读取使它阻塞
system本身就是阻塞的。
⑹ system是阻塞调用吗
不是。
system(命令);命令发出后 它产生一个 新的线程;是否 阻塞,取决于 这个新线程 自己 的安排。
例如,命令 用了:
START /WAIT 程序.exe 位置参数们
这个命令,设了 等待进程结束,它 能产生 阻塞。
若用 程序.exe 位置参数们 就不会产生 阻塞。
⑺ UNIX中system函数的实现为什么要阻塞SIGCHLD信号
由于system函数的实现基本原理是使用fork函数创建一个子进程,用子进程调用exec函数,之后将子进程运行的内容替换成了目标程序。如果不阻塞SIGCHLD信号,那么如果在调用system函数之前还创建了一个其它的子进程,那么当system函数中fork创建的子进程结束后会给父进程发送SIGCHLD信号,如果此时父进程设置的信号处理方式是捕捉而且在信号处理函数中调用了wait函数,那么system函数就无法根据其函数中创建的子进程返回状态获取相应的返回值。记得有这样的规定,system函数的返回应该是函数中创建子进程的返回状态。所以为了能保证system能够正确获取system函数中创建的子进程返回状态,SIGCHLD信号必须被阻塞。
同样,为了保证system函数不出现其它的一些问题,要求system函数要忽略SIGINT和SIGQUIT信号,如果system函数调用的程序是交互式的,如“ed”,就可能出现一些小问题。
⑻ linux shell 命名管道被阻塞
并不像你想象的那样(son一直读取fifo), son 只会读取一次 fifo 文件就结束了。由于father1第二次写的时候没有读取者,所以你的写fifo的函数就会被block。 把son 改成
function son (){
while true
do
read line <$pipe
echo from pipe:$LINE
done
}
即可,当然,你可以考虑在 son 中加上判断结束的条件,比如从fifo中读到特定字符串就退出循环等。这里不再赘述。
⑼ linux系统c语言进程不想被sleep阻塞等待怎么解决
1、启动后台子任务,在执行命令后加&操作符,表示将命令放在子shell中异步执行。可以达到多线程效果。如下,sleep10#等待10秒,再继续下一操作sleep10当前shell不等待,后台子shell等待。
2、wait命令wait是用来阻塞当前进程的执行,直至指定的子进程执行结束后,才继续执行。使用wait可以在bash脚本“多进程”执行模式下,起到一些特殊控制的作用。