Ⅰ 如何在linux下用c++強制結束一個線程呢
執行完成後隱式退出
由線程本身顯示調用pthread_exit 函數退出;
pthread_exit (void * retval)
被其他線程用回pthread_cance函數終止:答
pthread_cance (pthread_t thread)
解決辦法:
// 創建線程前設置 PTHREAD_CREATE_DETACHED 屬性
pthread_attr_t attr;
pthread_t thread;
pthread_attr_init (&attr);
pthread_attr_setdetachstat(&attr, PTHREAD_CREATE_DETACHED);
pthread_create (&thread, &attr, &thread_function, NULL);
pthread_attr_destroy (&attr);
當線程為joinable時,使用pthread_join來獲取線程返回值,並釋放資源。
當線程為joinable時,也可在線程中調用 pthread_detach(pthread_self());
Ⅱ linux下C/C++如何實現非阻塞等待子線程結束
主線程可以使用一個數組存儲子線程的ID,不調用 pthread_join來等候子線程退出,要是版子線程退出後權還有工作要清理,可以使用 pthread_cancel_push函數來注冊退出控制流時調用的函數
Ⅲ Linux C中父進程退出時,使用什麼方法可使子進程退出
發信號,抄kill(子進程ID, SIG信號)
如果不只一個襲子進程,需要把所有的子進程ID存起來,然後用上述方法一個一個的kill
SIG信號需要能使子進程退出,如SIGQUIT,SIGINT...等一些默認的信號;也可以在子進程中捕獲某些信號,然後子進程收到後自己退出
注意:最好是在子進程退出時,父進程要等待所有子進程退出
Ⅳ 如何在linux下用c++強制結束一個線程
不要用線程死循環啊,
用一個標志變數,退出時改變此變數的值,讓線程退出。
while(!bFlag)
{}
Ⅳ linux下多進程或者多線程編程的問題。新手,望指教!
你好,多進程抄或多線程,都不會阻襲塞當前語句代碼。為了您的理解,我就大膽舉下面兩個例子:
多進程:你可以看成是本來是一條路的,現在從中間拆成兩條,然後每一條路都有屬於自己這條路的代碼在運行。
多線程:你可以看成是一條路,然後分出車道,比如左車道和右車道甚至是停車道,然後每條車道都單獨通車,其他車道的不能對這條車道進行干擾。
所以,把一條路從中間拆成兩條,成本是很高的。但是把一條路分車道,成本就不是很高了。
對於您提出的main函數的疑問,當main函數最後執行完畢,程序退出後,所有的進程包括線程,都會被關閉的,哪怕你的程序中沒有關閉,操作系統也會幫你關閉的,現在的操作系統都非常的完善了。當然,也存在有線程或進程不被釋放的特殊情況,最好在編程中要記得釋放。
Ⅵ Linux C語言網路編程問題!
unsigned int dir(char * server) {
int sck;//套接字變數
struct sockaddr_in serv_adr; //遠程主機的地址
struct hostent *host; //指向遠程主機的指針
unsigned char databuf[FILEBUF_SIZE]; //數據
int bytes = 0, bytesread = 0; //位元組數,讀取到的位元組數
host = gethostbyname(server); //根據遠程主機的主機名,得到指向遠程主機的指針
if (host == (struct hostent *) NULL) { //如果得到指向遠程主機的指針失敗,報告錯誤,並返回
perror("gethostbyname failed");
return 0;
}memset(&serv_adr, 0, sizeof(serv_adr)); //初始化遠程主機的地址,結構體內所有成員清零
serv_adr.sin_family = AF_INET; //設置地址類型
memcpy(&serv_adr.sin_addr, host->h_addr, host->h_length);//取出指向遠程主機的指針中包含的地址信息,賦給遠程主機地址變數
serv_adr.sin_port = htons(SERVICE_PORT);//設置埠號,比如http服務對應80埠,ftp對應21埠
if ((sck = socket(AF_INET, SOCK_STREAM, 0)) < 0) { //如果建立TCP協議的套接字失敗,報告錯誤,並返回
perror("error on socket()");
return 0;
}
if (connect(sck, (struct sockaddr *)&serv_adr, sizeof(serv_adr)) < 0) {//如果使用該套接字連接到遠程主機失敗,報告錯誤,並返回
perror("error on connect()");
return 0;
}write(sck, "DI\n\n", 4); //連接成功,發送內容為"DI\n\n"的消息,遠程主機收到該消息,解析後生成目錄列表,並將目錄列表信息傳遞回來
printf("Remote directory listing:\n");//輸出提示信息「遠程主機正在生成目錄列表」
while ((bytes = read(sck, databuf, FILEBUF_SIZE)) > 0) { //從套接字的數據流中讀取遠程主機的返回信息(即目錄列表),每次讀取FILEBUF_SIZE個位元組,直到全部讀取完畢
write(fileno(stdout), databuf, bytes);//將每次讀到的數據,輸出到標准輸出流(stdout),即屏幕上
bytesread += bytes;//接收到的位元組數累加
}
close(sck); /* Close the socket */ //通信完成,關閉套接字,關閉連接
return bytesread; //返回讀取到的位元組數(即遠程主機返回的信息的大小)
}