记一次 c 语言 的 多线程查找 简单实现
- //仅供参考学习
- 1 #define _CRT_SECURE_NO_WARNINGS //屏蔽 vs 的a
- #include <stdio.h>
- #include <stdlib.h>
- #include <windows.h>
- #include <process.h>
- #include <time.h>
- #include <memory.h>
- //直接改 m_MAX 的值则是改变总的范围
- #define m_MAX 250000 //最好是 totalThread 的整数倍
- typedef struct s{
- int *begin;//每个线程其实索引地址
- int lenth;//索引长度
- int target;//need find
- int Id;//thread id
- int *flag;//线程之间通信
- int *isFind;//附加功能标记那个线程找到的
- }s_t;
- void find(void *p)
- {
- s_t* pS = (s_t*)p;//indo
- int* cur = NULL;//need find number addres
- for (cur = pS->begin; cur != pS->begin + pS->lenth; ++cur)
- {
- if ( == *(pS->flag))
- {
- char str[] = { };
- sprintf(str, " thread %d incapable been thread %d Preemptive\n", pS->Id, *(pS->isFind));
- printf("%s", str);
- _endthread();
- }
- if ((*cur) == pS->target)
- {
- printf(TEXT("thread %d finde \n"), pS->Id);
- printf(" %d\n", *cur);
- Sleep();
- *(pS->flag) = ;
- *(pS->isFind) = pS->Id;
- _endthread();
- }
- }
- {//快语句 看起来 代码整洁
- char str[] = { };
- sprintf(str, " Thread %.5d is incapable \n", pS->Id, *(pS->isFind));
- printf("%s", str);
- }
- _endthread();
- }
- int main()
- {
- srand((unsigned int)time(NULL));
- //需要寻找的源
- int array[m_MAX];
- //标志位
- int flag = ;
- int isFind = ;
- //随机的目标
- int target = rand() % m_MAX;
- printf("Need find number is %d \n", target);
- int totalThread = ;
- //线程需要的信息
- s_t s[]; //设定线程个数 ## 这里的 50 与 totalThread 变量是相关的 要改都改
- int dividedDataSize = (m_MAX / totalThread); //设定每个线程需要索引的大小
- //随机初始化 源内的数据
- for (int j = ; j < m_MAX; ++j) {
- array[j] = rand()%m_MAX;
- }
- //初始化每个线程
- for (int i = ; i < totalThread; ++i)
- {
- s[i].begin = array + (i*dividedDataSize);
- s[i].Id = i;
- s[i].lenth = (dividedDataSize);
- s[i].target = target;
- s[i].flag = &flag;
- s[i].isFind = &isFind;
- _beginthread(find, , &s[i]);
- Sleep(); //避免出现线程访问冲突
- }
- system("pause");
- return ;
- }
结语:有问题欢迎提在下方 ,本人在校学生,时间较为充裕, 有时间会回复的。
记一次 c 语言 的 多线程查找 简单实现的更多相关文章
- [R语言]R语言使用多线程对数据库进行大批量访问时出现无法连接问题
问题描述: 在R中使用多线程对数据库进行写入,在服务器端运行脚本(linux环境),总是在第6-7万个任务线程时,出现无法连接到数据库的问题.任务中断,错误信息为task 6xxxx failed,C ...
- swift语言之多线程操作和操作队列(下)———坚持51天吃掉大象(写技术文章)
欢迎有兴趣的朋友,参与我的美女同事发起的活动<51天吃掉大象>,该美女真的很疯狂,希望和大家一起坚持51天做一件事情,我加入这个队伍,希望坚持51天每天写一篇技术文章.关注她的微信公众号: ...
- c语言下多线程
原文:c语言下多线程 [问题]创建了10个线程,10个线程公用一个线程体,创建如下: int t1=0,t2=1,t3=2,t4=3,t5=4,t6=5,t7=6,t8=7,t9=8,t10=9; i ...
- Java入门到精通——基础篇之多线程实现简单的PV操作的进程同步
Java入门到精通——基础篇之多线程实现简单的PV操作的进程同步 一.概述 PV操作是对信号量进行的操作. 进程同步是指在并发进程之间存在一种制约关系,一个进程的执行依赖另一个进程的消 ...
- C语言排序算法之简单交换法排序,直接选择排序,冒泡排序
C语言排序算法之简单交换法排序,直接选择排序,冒泡排序,最近考试要用到,网上也有很多例子,我觉得还是自己写的看得懂一些. 简单交换法排序 /*简单交换法排序 根据序列中两个记录键值的比较结果来对换这两 ...
- C语言程序设计:模拟简单运算器的工作
目录 C语言程序设计:模拟简单运算器的工作 1.题目 2.分析 3.代码实现 4.结尾 C语言程序设计:模拟简单运算器的工作 1.题目 模拟简单运算器的工作,输入一个算式(没有空格),遇等号&qu ...
- c语言经典算法——查找一个整数数组中第二大数
题目: 实现一个函数,查找一个整数数组中第二大数. 算法思想: 设置两个变量max1和max2,用来保存最大数和第二大数,然后将数组剩余的数依次与这两个数比较,如果这个数a比max1大,则先将max1 ...
- Rust语言的多线程编程
我写这篇短文的时候,正值Rust1.0发布不久,严格来说这是一门兼具C语言的执行效率和Java的开发效率的强大语言,它的所有权机制竟然让你无法写出线程不安全的代码,它是一门可以用来写操作系统的系统级语 ...
- 基于JAVA语言的多线程技术
1.简介 多线程技术属于操作系统范围内的知识: 进程与线程 可以这么理解,一个应用程序就是一个进程,在一个进程中包含至少一个线程:进程就是线程的容器,真正工作.处理任务的是线程. 进程是操作系统分配资 ...
随机推荐
- angular开发环境搭建及新建项目
最近一个星期准备学习一下angular前端框架,因为之前在学习abp框架的时候,都要求前端要掌握angular,所以不得不回来恶补一下了,学习的过程有时间的话会记录在这里,方便以后复习. 闲言少叙,下 ...
- 简单地做一下“回到顶部”按钮,用jQuery实现其隐藏和显示
1.首先,我们要准备HTML代码: <div id="return-top"> <a href="#top">返回顶部</a> ...
- mssql sqlserver 给已存在表添加新的字段及字段备注的方法
转自:http://www.maomao365.com/?p=8102 摘要: 下文讲述向已存在表上添加新字段及字段备注的方法,如下所示: 实验环境:sql server 2008 R2 1. 添加新 ...
- kali linux中的yum、rpm常见的问题
事件起因:今天我在kali里面使用yum命令来部署Linux环境时,出现了错误: bash:yum command not found,然后就百度,找到一片好的文章,链接:http://www.pia ...
- node项目自动化部署--基于Jenkins,Docker,Github(1)安装Jenkins
前言 每次项目代码更新后都要重新部署,如果只有一台服务器还好. 但是如果是分布式系统,动不动就很多台服务器,所以代码的自动部署就显得十分重要了. 这里用几篇文章来记录一下如何使用Jenkins,Doc ...
- 在 ASP.NET Core 中集成 Skywalking APM
前言 大家好,今天给大家介绍一下如何在 ASP.NET Core 项目中集成 Skywalking,Skywalking 是 Apache 基金会下面的一个开源 APM 项目,有些同学可能会 APM ...
- PHP mysql查询工具
PHP基于PDO的 mysql 查询工具 单页面实现,将页面放在任意目录即可. 访问用户 admin 密码 password 代码很简单,主要为了在没有phpMyAdmin时方便执行SQL. 效果如下 ...
- 一行命令更新所有 npm 依赖包
npm 包的更新速度很快,为了将项目或者全局依赖更新到最新版本.传统的做法是一个一个更新,比如更新 react 到最新版本,命令如下: # npm npm i --save react@latest ...
- RabbitMQ第一次不能正常读取第二次正常的问题
1.利用rabbitmq导数据包,第一不能正常导入,第二次正常,第三次又出现问题,第四次又恢复正常的坑爹问题. 2.可访问rabbitmq注意消费者个数是否正常 有两个消费者,导致第一次消息被第一个消 ...
- Spring Cloud实战的代码和视频位置
大家好,本博文的连接里包含了Spring Cloud实战的代码和视频位置. 代码下载连接: 视频下载连接: