① linux能同時啟動多少個線程
默認情況下:
主線程+輔助線程 +<253個自己的線程<=255
含主線程和一個輔助線程,最多255個,即一個用戶只能生成253個線程。
Linux最大線程數限制及當前線程數查詢:
1、總結系統限制有:
/proc/sys/kernel/pid_max #查系統支持的最大線程數,一般會很大,相當於理論值
/proc/sys/kernel/thread-max
max_user_process(ulimit -u) #系統限制某用戶下最多可以運行多少進程或線程
/proc/sys/vm/max_map_count
硬體內存大小
2、java虛擬機本身限制:
-Xms #intial java heap size
-Xmx #maximum java heap size
-Xss #the stack size for each thread
3、查詢當前某程序的線程或進程數
pstree -p `ps -e | grep java | awk '{print $1}'` | wc -l 或 pstree -p 3660 | wc -l
4、查詢當前整個系統已用的線程或進程數
pstree -p | wc -l
1、 cat /proc/${pid}/status
2、pstree -p ${pid}
3、top -p ${pid} 再按H 或者直接輸入 top -bH -d 3 -p ${pid}
top -H
手冊中說:-H : Threads toggle
加上這個選項啟動top,top一行顯示一個線程。否則,它一行顯示一個進程。
4、ps xH
手冊中說:H Show threads as if they were processes
這樣可以查看所有存在的線程。
5、ps -mp <PID>
手冊中說:m Show threads after processes
這樣可以查看一個進程起的線程數。
② linux多線程為什麼不能同時操作同一個全局變數
因為多線程的執行和CPU調度、進程調度有關,簡單的理解就是進程調度是把CPU資源分為時間片,各個進程輪番執行,多線程的情況和這個類似。如果有一個全局變數,有的線程是進行寫操作,有的線程是進行讀操作,假設程序員希望的是先對全局變數進行寫,在另一個線程進行讀,但是那個線程先執行不是我們能控制的,這個調度工作屬於操作系統內核,內核有它的考量,程序無法干預,而且每個線程的運行時間也不一樣,這個也影響線程執行順序,你就把這個執行順序看成是隨機的吧(免得你抱有幻想)。所以實際的執行順序有可能是先由一個線程進行讀,然後才有另一個線程進行寫操作,這樣就讀到了一個舊的值,這就是邏輯錯誤咯,典型的bug啊。
其實多線程也不是不能同時操作同一個全局變數,只要用上了多線程裡面的「線程同步」技術就可以了。
③ Linux多線程編程
程序代碼test.c共兩個線程,一個主線程,一個讀緩存區的線程:
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
char globe_buffer[100];
void *read_buffer_thread(void *arg); //這里先聲明一下讀緩存的線程,具體實現寫在後面了
int main()
{
int res,i;
pthread_t read_thread;
for(i=0;i<20;i++)
globe_buffer[i]=i;
printf("\nTest thread : write buffer finish\n");
sleep(3);\\這里的3秒是多餘,可以不要。
res = pthread_create(&read_thread, NULL, read_buffer_thread, NULL);
if (res != 0)
{
printf("Read Thread creat Error!");
exit(0);
}
sleep(1);
printf("waiting for read thread to finish...\n");
res = pthread_join(read_thread, NULL);
if (res != 0)
{
printf("read thread join failed!\n");
exit(0);
}
printf("read thread test OK, have fun!! exit ByeBye\n");
return 0;
}
void *read_buffer_thread(void *arg)
{
int i,x;
printf("Read buffer thread read data : \n");
for(i=0;i<20;i++)
{
x=globe_buffer[i];
printf("%d ",x);
globe_buffer[i]=0;//清空
}
printf("\nread over\n");
}
---------------------------------------------------------------------------------
以上程序編譯:
gcc -D_REENTRANT test.c -o test.o –lpthread
運行這個程序:
$ ./test.o:
④ Linux下多線程的如何執行
主線程結束,則進程結束,屬於該進程的所有線程都會結束,可以在主線程中join,也可以在主線程中加死循環。
⑤ linux 並行 線程選多少合適
具體問題具體分析,如果你主要是做純計算(比如數學運算,物理計算等),那麼線程數應該等於cpu核心數。如果主要是io操作(即需要訪問硬體外設),一般來說線程數的提升並不能提高運行速度。 如果是 計算 + IO, 一般來說線程數應該大於cpu核心數。
總的來說,除了第一種,後兩種情況都應該實際測試看效果。
⑥ Linux線程的幾種結束方式
Linux線程的幾種結束方式
Linux創建線程使用
int pthread_create(pthread_t *thread, const pthread_attr_t *attr,
void *(*start_routine)(void *), void *arg)
1
2
Linux線程的幾種結束方式:
調用pthread_exit(exit_code),exit_code為線程退出的狀態代碼。同一進程下的其他線程可以通過pthread_join(exit_code)來使用。
函數start_routine使用return返回,與調用pthread_exit()作用相同。
線程被取消pthread_cancel()。
同一進程中的其他線程調用了exit(),,或者主線程從main函數返回。