㈠ 如何用c語言來判斷網路是否通
判斷網路通暢 一般用ping的方式
可以直接使用系統命令
通過popen 打開Ping名令 到結果找返回的時間關鍵字
如果ping通比例達到一定值以上,即可認為網路通暢。
popen具體用法 請自行網路。
㈡ c語言如何檢測網路是否連接
1、如果對方斷開連接的話,那麼readNum = recv ( socketId, rcvBuf, rcvBufSize, 0 );
readNum返回值應該是0,可以根據返回值判斷。
2、recv函數返回值說明
recv函數
int recv( SOCKET s, char FAR *buf, int len, int flags);
不論是客戶還是伺服器應用程序都用recv函數從TCP連接的另一端接收數據。該函數的第一個參數指定接收端套接字描述符; 第二個參數指明一個緩沖區,該緩沖區用來存放recv函數接收到的數據; 第三個參數指明buf的長度; 第四個參數一般置0。
這里只描述同步Socket的recv函數的執行流程。當應用程序調用recv函數時,
(1)recv先等待s的發送緩沖中的數據被協議傳送完畢,如果協議在傳送s的發送緩沖中的數據時出現網路錯誤,那麼recv函數返回SOCKET_ERROR,
(2)如果s的發送緩沖中沒有數據或者數據被協議成功發送完畢後,recv先檢查套接字s的接收緩沖區,如果s接收緩沖區中沒有數據或者協議正在接收數 據,那麼recv就一直等待,直到協議把數據接收完畢。當協議把數據接收完畢,recv函數就把s的接收緩沖中的數據到buf中(注意協議接收到的數據可能大於buf的長度,所以 在這種情況下要調用幾次recv函數才能把s的接收緩沖中的數據完。recv函數僅僅是數據,真正的接收數據是協議來完成的), recv函數返回其實際的位元組數。如果recv在時出錯,那麼它返回SOCKET_ERROR;如果recv函數在等待協議接收數據時網路中斷了,那麼它返回0。 默認 socket 是阻塞的 解阻塞與非阻塞recv返回值沒有區分,都是 <0 出錯 =0 連接關閉 >0 接收到數據大小,
特別:返回值<0時並且(errno == EINTR || errno == EWOULDBLOCK || errno == EAGAIN)的情況下認為連接是正常的,繼續接收。只是阻塞模式下recv會阻塞著接收數據,非阻塞模式下如果沒有數據會返回,不會阻塞著讀,因此需要循環讀取)。
返回說明: 成功執行時,返回接收到的位元組數。另一端已關閉則返回0。失敗返回-1,errno被設為以下的某個值 EAGAIN:套接字已標記為非阻塞,而接收操作被阻塞或者接收超時 EBADF:sock不是有效的描述詞 ECONNREFUSE:遠程主機阻絕網路連接 EFAULT:內存空間訪問出錯 EINTR:操作被信號中斷 EINVAL:參數無效 ENOMEM:內存不足 ENOTCONN:與面向連接關聯的套接字尚未被連接上 ENOTSOCK:sock索引的不是套接字 當返回值是0時,為正常關閉連接;
思考:當對側沒有send,即本側的套接字s的接收緩沖區無數據,返回值是什麼(EAGAIN,原因為超時,待測)
㈢ 通過c語言實現手機給電腦發送信號指令
你看看linux 網路編程試試 我覺的你應該還是在linux上建立一個伺服器用來解析通過網路發來的命令,起先你應該用一個可以用c語言為主體的可以調用硬體操作的代碼 用伺服器來解析執行你要的操作,在你的linux主機上可以通過路由器等連入Internet 你通過c/s架構通過一台電腦或是手機來訪問linux伺服器 這個client可以是一個php網頁 通過socket與操作運行的代碼交互
㈣ C語言信號處理程序
#include<signal.h>
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
voidmy_func(intsign_no)
{
if(sign_no==SIGINT)
printf("IhavegetSIGINT ");
elseif(sign_no==SIGTERM)
printf("IhavegetSIGQUIT ");
}
intmain()
{
printf(" ");
printf("processis%d ",getpid());
signal(SIGINT,my_func);
signal(SIGTERM,my_func);
while(1);
exit(0);
}
linux 平台就 用while阻塞就行
不知道你用的是什麼平台?
㈤ C語言中信號問題
信號是程序執行過程中出現的異常情況。它可能是由程序中的錯誤造成的,例如引用內存中的一個非法地址;或者是由程序數據中的錯誤造成的,例如浮點數被0除;或者是由外部事件引發的,例如用戶按了Ctrl+Break鍵。
你可以利用標准庫函數signal()指定要對這些異常情況採取的處理措施(實施處理措施的函數被稱為「信號處理函數」)。signal()的原型為:
#include <signal.h>
void(*signal(int hum,void(*func)(int)))(int);
如果定義一個typedef,理解起來就容易一些了。下面給出的sigHandler_t類型是指向一個程序的指針,該函數有一個int類型的參數,並且返回一個void類型:
typedef void(*sigHandler_t)(int);
sigHandler_t signal(int num , sigHandler_t func);
signal()有兩個參數,分別為int類型和sigHandler_t類型,其返回值為sigHandler_t類型。以func參數形式傳遞給signal()的那個函數將成為第num號異常情況的新的信號處理函數。signal()的返回值是信號hum原來的信號處理函數。在設置了一個暫時的信號處理函數之後,你可以利用該值恢復程序先前的行為。num的可能值依賴於系統,並且在signal.h中列出。func的可能值可以是你的程序中的任意函數,或者是SIG_DFL和SLG_IGN這兩個特別定義的值之一。SIG_DFL是指系統的預設處理措施,通常是暫停執行程序;SIG_IGN表示信號將被忽略。
㈥ linux中c語言有關信號的程序
簡單處理了一下,希望對你有幫助
#define err_sys( str ) printf("error:%s\n" , str )
static void sig_int(int signo)
{
struct tms timebuf;
int wallclock=times(&timebuf);
fprintf(stderr,"clock ticks since system startup are %d,\n",wallclock);
}
static void sig_term(int signo)
{
struct tms timebuf;
int wallclock=times(&timebuf);
fprintf(stderr,"clock ticks since system start are %d,\n",wallclock);
exit(0); //終止程序
}
static void sig_alrm(int signo)
{
static int times=1;
alarm(0);//輸出時,不再計時
printf("time:%d\n" , times*10 );
times++ ;
alarm(10); //重新開始計時
}
int main()
{
if (signal(SIGINT,sig_int)==SIG_ERR)
err_sys("can't catch SIGINT");
if (signal(SIGTERM,sig_term)==SIG_ERR)
err_sys("can't catch SIGTERM");
alarm(10); //開始計時
if (signal(SIGALRM,sig_alrm)==SIG_ERR)
err_sys("can't catch SIGALRM");
while(1) ; //等待在這里
return(0);
}