最全的Linux教程,Linux从入门到精通
======================
-
linux从入门到精通(第2版)
-
Linux系统移植
-
Linux驱动开发入门与实战
-
LINUX 系统移植 第2版
-
Linux开源网络全栈详解 从DPDK到OpenFlow
第一份《Linux从入门到精通》466页
====================
内容简介
====
本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。
本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。
需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
{
pnode tmp = (pnode)malloc(sizeof(node));
tmp->num = n;
tmp->next=NULL;
return tmp;
}
void listinit(ppnode head)
{
pnode tmp = (pnode)malloc(sizeof(node));
tmp->num = 0;
tmp->next = NULL;
head = tmp;
}
void pushfront(pnode head,int m)
{
int n = m;
pnode newhead = buynode(n);
newhead->next=head->next;
head->next=newhead;
}
void poplist(pnode head)
{
if(head->next==NULL)
perror(“pop”);
pnode tmp = head->next;
head->next=tmp->next;
//free(tmp);
}
void runC(void arg)//消费者
{
pnode head = ((ppnode)arg);
while(1)
{
pthread_mutex_lock(&mutex);
while(head->next==NULL)
{
printf(“consumer need waitting…\n”);
pthread_cond_wait(&cond,&mutex);
}
int d = head->next->num;
printf(“consumer get data:%d\n”,d);
poplist(head);
//pthread_mutex_unlock(&mutex);
sleep(2);
}
}
void* runP(void* arg)//生产者
{
pnode head= *((ppnode)arg);
while(1)
{
sleep(2);
int d = rand()%100+1;
pushfront(head,d);
printf(“product data:%d\n”,d);
pthread_cond_signal(&cond);
pthread_mutex_unlock(&mutex);
sleep(2);
}
}
int main()
{
srand((unsigned long)time(NULL));
pnode head = NULL;
listinit(&head);
pthread_mutex_init(&mutex,NULL);
pthread_cond_init(&cond,NULL);
pthread_t p,c;
pthread_create(&c,NULL,runC,&head);
pthread_create(&p,NULL,runP,&head);
pthread_join(c,NULL);
pthread_join(p,NULL);
pthread_mutex_destroy(&mutex);
pthread_cond_destroy(&cond);
return 0;
}

通过结果我们不难看出他们之间的关系。这里就不在多说。
接下来我们要看的是环形队列实现生产者消费者模型,环形队列与链表不同的一点是如果生产者一直生产而消费者不消费的话,总有满的时候,一旦队列满了的话,生产者就不去消费了,同理,如果没有数据,消费者也不能去消费。
因此我们不难发现,在这里我们需要一个可以实现计数器功能的东西去协助我们进行数据量的和空白队列的表示,所以我们在这里就要了解一个东西,POSIX信号量。POSIX信号量可以用于进程也可以用于线程,由用户自己选择。
#include<semaphore.h>这是它需要引用的头文件。
信号量初始化函数:
int sem\_init(sem\_t\* sem,int pshared,unsigned int value);
pshared:0表示线程间,1表示进程间。
value:初始值。
销毁信号量:
int sem\_destroy(sem\_t\* sem);
等待信号量:
int sem\_wait(sem\_t\* sem);等待信号量,会将信号量减1;
发布信号量:
int sem\_post(sem\_t\* sem);发布信号量,将信号量加1;
接下来我们就利用信号量来完成利用环形队列模拟的生产者消费者模型。
#include<stdio.h>
#include<stdlib.h>
#include<pthread.h>
#include<unistd.h>
#include<sys/types.h>
#include<semaphore.h>
int arr[6];
pthread_mutex_t lock1;
pthread_mutex_t lock2;
sem_t sem_data;
sem_t sem_blank;
void* runP(void* arg)//生产者
{
static int i = 0;
while(1)
{
pthread_mutex_lock(&lock1);
sem_wait(&sem_data);
int n = arr[i];
printf(“consumer get: %d\n”,n);
sem_post(&sem_blank);
i++;
i=i%6;
pthread_mutex_unlock(&lock1);
sleep(2);
}
}
void* runC(void* arg)//消费者
{
static int i = 0;
while(1)
{
pthread_mutex_lock(&lock2);
sem_wait(&sem_blank);
int n = rand()%1000+1;
arr[i]=n;
printf(“product data:%d\n”,n);
i++;
i=i%6;
sem_post(&sem_data);
pthread_mutex_unlock(&lock2);
sleep(2);
}
}
int main()
{
srand((unsigned long)time(NULL));
为了做好运维面试路上的助攻手,特整理了上百道 【运维技术栈面试题集锦】 ,让你面试不慌心不跳,高薪offer怀里抱!
这次整理的面试题,小到shell、MySQL,大到K8s等云原生技术栈,不仅适合运维新人入行面试需要,还适用于想提升进阶跳槽加薪的运维朋友。
本份面试集锦涵盖了
- 174 道运维工程师面试题
- 128道k8s面试题
- 108道shell脚本面试题
- 200道Linux面试题
- 51道docker面试题
- 35道Jenkis面试题
- 78道MongoDB面试题
- 17道ansible面试题
- 60道dubbo面试题
- 53道kafka面试
- 18道mysql面试题
- 40道nginx面试题
- 77道redis面试题
- 28道zookeeper
总计 1000+ 道面试题, 内容 又全含金量又高
- 174道运维工程师面试题
1、什么是运维?
2、在工作中,运维人员经常需要跟运营人员打交道,请问运营人员是做什么工作的?
3、现在给你三百台服务器,你怎么对他们进行管理?
4、简述raid0 raid1raid5二种工作模式的工作原理及特点
5、LVS、Nginx、HAproxy有什么区别?工作中你怎么选择?
6、Squid、Varinsh和Nginx有什么区别,工作中你怎么选择?
7、Tomcat和Resin有什么区别,工作中你怎么选择?
8、什么是中间件?什么是jdk?
9、讲述一下Tomcat8005、8009、8080三个端口的含义?
10、什么叫CDN?
11、什么叫网站灰度发布?
12、简述DNS进行域名解析的过程?
13、RabbitMQ是什么东西?
14、讲一下Keepalived的工作原理?
15、讲述一下LVS三种模式的工作过程?
16、mysql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
17、如何重置mysql root密码?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
ql的innodb如何定位锁问题,mysql如何减少主从复制延迟?
17、如何重置mysql root密码?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!