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

为什么一个线程创建的套接字在另一线程中无法使用?

    来源: 互联网  发布时间:2016-06-10

    本文导语:  如题,一个进程中的所有资源不是都共享的吗? | 可以用的,如下为《unix网络编程》中的例子: #include "unpthread.h" static void *doit(void *); /* each thread executes this function */ int main(int argc,...

如题,一个进程中的所有资源不是都共享的吗?

|
可以用的,如下为《unix网络编程》中的例子:


#include "unpthread.h"

static void *doit(void *); /* each thread executes this function */

int
main(int argc, char **argv)
{
int listenfd, connfd;
socklen_t addrlen, len;
struct sockaddr *cliaddr;

if (argc == 2)
listenfd = Tcp_listen(NULL, argv[1], &addrlen);
else if (argc == 3)
listenfd = Tcp_listen(argv[1], argv[2], &addrlen);
else
err_quit("usage: tcpserv01 [  ] ");

cliaddr = Malloc(addrlen);

for ( ; ; ) {
len = addrlen;
connfd = Accept(listenfd, cliaddr, &len);

Pthread_create(NULL, NULL, &doit, (void *) connfd);
}
}

static void *
doit(void *arg)
{
Pthread_detach(pthread_self());
str_echo((int) arg); /* same function as before */
Close((int) arg); /* we are done with connected socket */
return(NULL);
}

|
俺一般都不跨线程使用套接字

这个也不太了解  

Linux 和 Windows不一样 不能简单说 所有资源都共享

确实Clone的标志是
CLONE_VM | CLONE_FS | CLONE_FILES | CLONE_SIGNAL
     | CLONE_SETTLS | CLONE_PARENT_SETTID
     | CLONE_CHILD_CLEARTID | CLONE_SYSVSEM

也就是共享虚地址空间 文件系统 文件描述符表,但是fork子进程时 CLONE_FS | CLONE_FILES 这两也有,也就是
fork之前的 比如套接字 或者其他文件描述符是 共有的 都能用 但是  fork之后 父进程再打开的 文件描述符 子进程就不可以了。

基本线程也就比子进程多 CLONE_VM 这一个标志位。 所以。。。 (不敢确定,希望有更好的解释吧)

|



最好能举个 pthread_create之后 主线程 再socket 然后能在子线程使用的例子

|
线程也有自己局部的栈的,虽然他们可以共享到全局的数据。

一般的做法是建个全局的int fd[]数组,来获取。
或者可以在pthread_create的时候,把fd传进去。

可以看看unix网络编程实例,都有典型模型的例子。

|
heap  的空间是共享的,
stack 的空间不是共享的。

也就是说全局变量共享, 局部变量不共享。

    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












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


  • 站内导航:


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

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3