Linux下線程編程(2)
線程(英語:thread)是操作系統能夠進行運算調度的最小單位。它被包含在進程之中,是進程中的實際運作單位。一條線程指的是進程中一個單一順序的控制流,一個進程中可以并發多個線程,每條線程并行執行不同的任務。在Unix System V及SunOS中也被稱為輕量進程(lightweight processes),但輕量進程更多指內核線程(kernel thread),而把用戶線程(user thread)稱為線程。
?1.6 線程取消函數pthread_cancel
int pthread_cancel(pthread_t thread);
函數功能:
??取消同一進程中的其他線程。
形 參:
??pthread_t thread — 線程描述符
返回值: 0 — 成功,其他值 — 失敗
??示例:
#include
#include
#include
void *start_routine_func(void *arg)
{
int data=*(int *)arg;
while(1)
{
printf("data=%d\n",data);
sleep(1);
data++;
}
}
int main()
{
int data=10;
pthread_t pth_id;
if(pthread_create(&pth_id,NULL,start_routine_func,&data)!=0)
{
printf("線程創建失敗\n");
return 0;
}
printf("子線程ID:%lu\n",pth_id);
while(1)
{
sleep(1);
printf("主線程運行中data=%d\n",data);
data++;
if(data==15)
{
pthread_cancel(pth_id);//取消子線程
}
}
}
[xsw@xsw 系統編程]$ gcc pthread.c -lpthread
[xsw@xsw 系統編程]$ ./a.out
子線程ID:3079162736
data=10
主線程運行中data=10
data=11
主線程運行中data=11
data=12
主線程運行中data=12
data=13
主線程運行中data=13
data=14
主線程運行中data=14
主線程運行中data=15
主線程運行中data=16
主線程運行中data=17
1.7 線程分離屬性pthread_detach
創建一個線程默認的狀態是joinable(結合屬性),如果一個線程結束但沒有調用pthread_join,則它的狀態類似于進程中的zombie process(僵尸進程),即還有一部分資源沒有被回收(退出狀態碼),所以創建線程時應該使用函數pthread_join來等待線程運行結束,并可得到線程的退出代碼,回收其資源(類似進程中的wait、waitpid)。但是調用pthread_join(pthread_id)函數后,如果該線程沒有運行結束,調用者會被阻塞,有些情況下我們并不希望如此。 pthread_detach函數可以將該線程狀態設置為detached(分離狀態),則該線程運行結束后自動會釋放所有資源。
??函數原型:
int pthread_detach(pthread_t thread);
形 參:
??pthread_t thread — 線程標志符
返回值: 0 — 成功,其它值 – 失敗
??示例:
#include
#include
#include
void *start_routine_func(void *arg)
{
int data=*(int *)arg;
while(1)
{
printf("data=%d\n",data);
sleep(1);
data++;
}
}
int main()
{
int data=10;
pthread_t pth_id;
if(pthread_create(&pth_id,NULL,start_routine_func,&data)!=0)
{
printf("線程創建失敗\n");
return 0;
}
printf("子線程ID:%lu\n",pth_id);
//設置分離屬性
pthread_detach(pth_id);
//等待子線程退出
pthread_join(pth_id,NULL);//未設置分離屬性則會阻塞主線程
while(1)
{
sleep(1);
printf("主線程運行中...\n");
}
return 0;
}
[xsw@xsw 系統編程]$ gcc pthread.c -lpthread
[xsw@xsw 系統編程]$ ./a.out
子線程ID:3078335344
data=10
主線程運行中...
data=11
主線程運行中...
data=12
主線程運行中...
data=13
主線程運行中...
data=14
主線程運行中...
data=15
1.8 設置線程棧空間
??查看線程堆棧空間:
[wbyq@wbyq ~]$ ulimit -s
8192
??8192單位是KB,也就是默認棧空間大小為8M
??通過命令ulimit -a查看線程棧空間詳細信息
[wbyq@wbyq ~]$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 15407
max locked memory (kbytes, -l) 65536
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 15407
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
??通過命令ulimit -s <棧空間大小>
[wbyq@wbyq ~]$ ulimit -s 10240
[wbyq@wbyq ~]$ ulimit -s
10240
??每個線程的棧空間都是獨立的,如果堆棧空間溢出程序會出現段錯誤。如果一個進程有10個線程,那么分配的棧空間大小為10*<每個線程棧空間大小>
??示例:
#include
int main()
{
char buff[12*1024*1024+1]="hello,world\n";
printf("buff=%s,%d",buff,sizeof(buff));
return 0;
}
[xsw@xsw 系統編程]$ ./a.out
段錯誤 (core dumped)
?1.9 通過函數設置和查詢線程棧空間
#include
#include
#include
int main()
{
/*查看線程棧空間最小值*/
printf("STACK_MIN:%d\n",PTHREAD_STACK_MIN);//16384byte--16kb
pthread_attr_t attr;
size_t ret,stack_size;
ret=pthread_attr_init(&attr);//初始化線程屬性
if(ret!=0)
{
printf("初始化失敗\n");
return 0;
}
/*獲取線程棧空間*/
ret=pthread_attr_getstacksize(&attr,&stack_size);
printf("線程棧空間:%ld kb\n",stack_size/1024);
/*設置線程棧空間*/
stack_size=8*1024*1024;//8M
pthread_attr_setstacksize(&attr,stack_size);
/*獲取線程棧空間*/
ret=pthread_attr_getstacksize(&attr,&stack_size);
printf("修改后棧空間:%ld kb\n",stack_size/1024);
}
[wbyq@wbyq ubuntu]$ gcc main.c -pthread
[wbyq@wbyq ubuntu]$ ./a.out
STACK_MIN:16384
線程棧空間:10240 kb
修改后棧空間:8192 kb
審核編輯:湯梓紅
-
Linux
+關注
關注
87文章
11229瀏覽量
208927 -
函數
+關注
關注
3文章
4306瀏覽量
62431 -
線程編程
+關注
關注
0文章
5瀏覽量
6126
發布評論請先 登錄
相關推薦
評論