当前位置:  技术问答>linux和unix

多线程 多进程 多CPU 多核心的一些疑惑

    来源: 互联网  发布时间:2017-05-02

    本文导语:  一般来说我们写程序,一个客户端占用一个进程,一个进程分配到一个CPU执行。 尽管我们的客户端采用了多线程,这样感觉还是在单个CPU上跑? -------------- 针对多CPU多核心的编程有没有什么优化的处理方法? ...

一般来说我们写程序,一个客户端占用一个进程,一个进程分配到一个CPU执行。
尽管我们的客户端采用了多线程,这样感觉还是在单个CPU上跑?
--------------
针对多CPU多核心的编程有没有什么优化的处理方法?

|
linux内核没有线程概念,访问相同资源的进程一般都固定在某一核上运行。这样做是为了减少CPU核与核之间的数据交换,提高CPU缓存命中率,提高了整体性能。在用户空间,一个进程里的多个线程是共享地址空间的,能访问的资源是一样的。如果将同一进程内的线程分派到不同核上运行,那么在访问相同资源时,数据需要频繁的在核与核之间交换,每个核的缓存都会一直无法命中。所以linux会尽量将同一进程的线程分派到同一CPU上执行。不过你可以手动将某一线程绑定到某一核上。

|
线程是最小调度单位,一个进程中的多个线程可以被分配到不同处理器上并行执行。

|
一个CPU可以有多个核心,一个核心同一时刻只能处理一个线程

    
 
 

您可能感兴趣的文章:

  • 关于线程创建的疑惑??????????
  • 疑惑求助:unix线程执行被异步中断后的问题
  • 请教!!!关于多线程的疑惑!!!
  • 关于线程的一点疑惑
  • 求助啊,新手对linux下线程同步的疑惑...
  • 主进程有两个线程,fork子进程后复制主进程两个线程的内存么?
  • 如何实现这样的API,可同时被不同的进程/线程使用,但是又不区分进程/线程?
  • 请问:进程创建的线程是怎样运行的啊,线程的处理函数运行完了,线程就退出了吗?
  • 如果父进程有多个线程,那么它的子进程也该拥有这些线程
  • 一个进程创建了两个线程,如何使得当任何一个线程(比如线程a)结束时,同时也结束线程b,也就是使两个线程一起死掉,怎么办呢?
  • 如何让子进程继承父进程的线程
  • 请问,在一个进程中创建多线程时如何能避免不同的线程获得同一个线程标识
  • 在一个进程的主线程中如何判断自己创建的线程是否存在?
  • Linux中最多同时可以开多少个进程,一个进程可以开多少个线程?
  • 请教:线程中调用一个阻塞的方法后,进程及其它线程会阻塞么?
  • 请问在单进程,多线程程序里,线程间使用IPC的信号量来同步,能行吗?
  • linux线程与进程的问题
  • 在程序中启动一个进程(不是线程),如何知道该进程已运行结束
  • 如何准确理解“程序”、“进程”、“线程”这三个概念
  • 进程和线程的区别
  • 请问:linux下的子进程与线程的区别
  • linux进程(线程)运行过程中如何获取本进程当前的内存使用状况,统计信息?
  • socket+多进程+多线程
  • sleep是进程域还是线程域的?
  • 线程上下文切换和进程上下文切换那个代价大?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Java中多线程相关类Thread介绍
  • java 线程,对当前线程(非主线程)调用sleep,为什么主线程(窗口)也没反应了
  • c#多线程更新窗口(winform)GUI的数据
  • 如何实现一个线程组内多线程的非同不执行,即一个线程执行完毕后再执行下一个线程???
  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 关于线程的问题,什么样的线程不是active线程?
  • c++的boost库多线程(Thread)编程(线程操作,互斥体mutex,条件变量)详解
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 我的一个多线程服务里, 总是有一个线程莫名其妙的变成僵尸线程。
  • 能否通过线程id控制线程的状态?或是观察到线程的状态?
  • 如何在一个线程中启动另外一个线程,然后本线程就退出?
  • 我要设置一个线程的优先级, 这个属性结构并没有线程的id,它怎么知道是设置哪个线程呢?
  • 请问在java多线程中,是只有run(){}内的代码运行在一个新线程下呢?还是这个类中的代码都运行在一个新线程下?
  • gcc链接的库,分不分单线程版本的和多线程版本的?
  • 内核栈~ 内核线程 ~用户线程 之间关系 问题
  • 子线程的数据如何返回给主线程?
  • 如果父线程死掉 那么子线程会不会死掉呢
  • 多线程为何比单线程慢许多?
  • 如何设计线程池的监视线程
  • 大家来讨论一下,一个客户端一个线程好,还是线程池好?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,