gcc -lpthread 干什么用

#include <stdio.h>

#include <pthread.h>

void *ThreadFunc(void *pArg)  //参数的值为123

{

int i = 0;

for(; i<10; i++)

{

printf("Hi,I‘m child thread,arg is:%d\n", (int)pArg);

sleep(1);

}

pthread_exit(NULL);

}

int main()

{

pthread_t thdId;

pthread_create(&thdId, NULL, ThreadFunc, (void *)123 );

int i = 0;

for(; i<10; i++)

{

printf("Hi,I‘m main thread,child thread id is:%x\n", thdId);

sleep(1);

}

return 0;

}

编译时需要带上线程库选项:

gcc  -o  a  a.c  -lpthread

看到 -lpthread就想到了

Gcc –o ./bin/main.exe  ./src/*.c  -I ./include/

但是似乎是不同的。搜索如下:

gcc编译线程程序,为什么要加-lpthread,头文件已经包含了<pthread.h>了啊

包含头文件了,仅能说明有了线程函数的声明, 但是还没有实现, 加上-lpthread是在链接阶段,链接这个库

http://zhidao.baidu.com/link?url=4jUrmjtqneMui7KJmOpxti_HDsAvYjmGhwuVJFLVgdHOrKfC3DKs68cm7g0y6FGxpc_qExVCwz4PMbeb_JqnV_

-lpthread -lm 这两个参数在多线程中起到什么作用? -pthread和-lpthread有什么区别?

lpthread是表示要连接到pthread的库是这里省略的lib,你应该可以找到共享库libpthread.so的。因为pthread编程用到的函数在pthread库里面,就像你使用pow等数学计算函数,需要用到math.h.需要 -lm。 

http://zhidao.baidu.com/link?url=pIOHTwSTuya_zuzCPEeT-1ibV01ISyWSUSX_Duu4qA2OKbHCbkr-7HKOBzIGtcxQ27hvrlqEfqcrqVwzW4wzua

-pthread 相比于 -lpthread 链接选项究竟多做了什么工作呢?我们可以在verbose模式下执行一下对应的gcc命令行看出来
http://chaoslawful.iteye.com/blog/568602

时间: 2024-10-10 07:49:17

gcc -lpthread 干什么用的相关文章

gcc gdb makefile学习笔记

一.gcc (GNU C compiler )1.预处理  gcc -E aaa.c  -o aaa.i   →  .i(c代码)    ↓ 2. 编译   gcc -S aaa.i  -o aaa.s   →   .s(汇编代码)    ↓3. 汇编   gcc -c  aaa.s  -o aaa.o  →   .o(目标代码-二进制)    ↓4. 链接   gcc aaa.o    -o aaa    →   aaa(可执行文件) 优化编译链接   gcc -O(O2/O3) aaa.o

多进程与多线程差别

 在Unix上编程採用多线程还是多进程的争执由来已久,这样的争执最常见到在C/S通讯中服务端并发技术 的选型上,比方WEBserver技术中.Apache是採用多进程的(perfork模式,每客户连接相应一个进程,每进程中仅仅存在唯一一个运行线程), Java的Web容器Tomcat.Websphere等都是多线程的(每客户连接相应一个线程,全部线程都在一个进程中). 从Unix发展历史看,伴随着Unix的诞生进程就出现了.而线程非常晚才被系统支持,比如Linux直到内核2.6.才支持符合P

emacs 中的键盘宏

PING(Packet InterNet Groper)中文名为因特网包探索器,是用来查看网络上另一个主机系统的网络连接是否正常的一个工具.ping命令的工作原理是:向网络上的另一个主机系统发送ICMP报文,如果指定系统得到了报文,它将把回复报文传回给发送者,这有点象潜水艇声纳系统中使用的发声装置.所以,我们想知道我这台主机能不能和另一台进行通信,我们首先需要确认的是我们两台主机间的网络是不是通的,也就是我说的话能不能传到你那里,这是双方进行通信的前提.在Linux下使用指令ping的方法和现象

多进程 vs 多线程

今天和一个朋友聊天,谈到了多进程.多线程的区别,回来搜集文章给出结论: 在Linux2.6上,多线程并不比多进程速度快,考虑到线程栈的问题,多进程在并发上有优势. 转载一篇 在Unix上编程采用多线程还是多进程的争执由来已久,这种争执最常见到在C/S通讯中服务端并发技术 的选型上,比如WEB服务器技术中,Apache是采用多进程的(perfork模式,每客户连接对应一个进程,每进程中只存在唯一一个执行线程), Java的Web容器Tomcat.Websphere等都是多线程的(每客户连接对应一个

IPC: 信号量

################################################### 信号量 信号量:在多线程环境下,用来保证多个关键代码不被并发调用,一次只能有个一个线程访问关键代码. 信号量有两组函数接口: 1.posix信号量 2.system v信号量 信号量的两种形式: 1.二进制信号量:用来保护一段代码,使其每次只能被一个执行线程运行,初始值一般为1. 2.计数信号量:有限数目的线程执行一段指定的代码,初始值一般大于1. ----------------------

IPC: 同步

################################################### 进程/线程 同步.(posix) 互斥锁 条件变量 读写锁 记录上锁 ----------------------------------------------------------- 互斥锁: 用于上锁和解锁.保护代码临界区,保证任何时刻只有一个线程在临界区内执行. gcc   -lpthread #include <pthread.h> 建立互斥量: int pthread_mute

linux 系统文件操作sem_open, sem_close, sem_post, sem_wait

信号灯分为有名信号灯和内存信号灯 一.Posix有名信号灯 1.posix有名信号灯函数    函数sem_open创建一个新的有名信号灯或打开一个已存在的有名信号灯.有名信号灯总是既可用于线程间的同步,又能用于进程间的同步. 1. sem_open 名称:: sem_open 功能: 创建并初始化有名信号灯 头文件: #include <semaphore.h> 函数原形: sem_t *sem_open(const char *name,int oflag,/*mode_t mode,un

线程异常:undefined reference to &#39;pthread_create&#39; 处理

源码: #include <stdio.h> #include <pthread.h> #include <sched.h> void *producter_f (void *arg); void *consumer_f (void *arg); int buffer_has_item=0; pthread_mutex_t mutex; int running =1 ; int main (void) { pthread_t consumer_t; pthread_t

多线程程序设计---1

一.什么是线程 1.线程就是“轻量级”的进程. 2.线程与创建它的进程共享代码段,数据段. 3.线程拥有自己独立的栈. 二.函数学习 1创建线程 1).函数名 pthread_create 2).函数原型 int pthread_create(pthread_t *thread, const pthread_attr_t *attr ,void *(*start_routine)(void *), void *arg) 3).函数功能 创建一个新的线程 4).所属头文件 <pthread.h>