多线程-linux 下c 程序,开了1024个线程 依次等待共同完成某个任务,程序异常退出,不出core

问题描述

linux 下c 程序,开了1024个线程 依次等待共同完成某个任务,程序异常退出,不出core

程序简单来说类似一个多线程下载器,开了1024个线程,然后并发去服务器读取一个大文件的某一块,读取完成后,文件合并要按照顺序写文件,所以我采用了pthread_join依次等待上一个线程写完成操作。测试时候发现程序偶尔会突然down掉,也不出core,并不是总down,也会有成功执行时候。机器配制足够高了,内存96G,24核cpu。。。希望大家帮忙分析下。。谢谢,代码逻辑如下。

void* thread_fun()
{
     ......

     if(id != 0)pthread_join(thread_list[id - 1],NULL);//等待上一个线程结束
       write(fd,th_d->file,file - th_d->file);//写文件

}

解决方案

想了一下,想不出原因,你加GDB调试一下喽,看看在哪core dump 掉的,不出core 你是不是没有设置啊,
linux 默认的core 文件是不打开的,你需要设置一下他的大小,或者是不限制大小。
#ulimit -c unlimite 设置core 文件大小为不限定状态就可以打开了,

时间: 2024-08-18 10:36:13

多线程-linux 下c 程序,开了1024个线程 依次等待共同完成某个任务,程序异常退出,不出core的相关文章

linux下,如何使用grub使某个线程独占一个core

问题描述 linux下,如何使用grub使某个线程独占一个core 现在使用fedora18, 电脑有多个CPU core,为了提高core执行速度,打算让每一个core独自执行一个线程.当有其他的任务分配的时候,发现不到上述的这些core,从而运行在另外的core上,听别人说可以在grub上配置,但是具体细节他也不懂.哪位知道在grub中怎么配置可以实现上面的功能,或者怎么在C语言中实现. 网上只搜到C#的,求指教. 谢谢啦.

udp多线程-linux下udp 多线程错误

问题描述 linux下udp 多线程错误 udp 的多线程调用怎么报sendto参数无效错误啊!!! Invalid argument 解决方案 是不是调用sendto的socket对象不能跨线程使用 解决方案二: 把你的sendto附近的代码贴出来?

linux下多线程-linux下 多线程共享数据问题

问题描述 linux下 多线程共享数据问题 环境:linux64位服务器 现有海量文件(按秒级的时间顺序源源不断的来),我需要起多线程读取这些文件,并利用文件内容构建一个比较庞大的数据结构(各种map.list的组合),另外还有一批线程检测这个数据结构某些位置的值并触发具体的任务(当然也可以在构建数据结构的同时进行触发). 问题是: 1.多线程如何并发的构建这个数据结构(结构中的list是需要按照文件到来时间排序的),要对数据结构里面的所有数据都上锁么?上锁上在哪?能不上锁么? 2.如何并行的对

Linux下获取代码文件名、代码所在行数及日期时间的C程序实现

一.概述 在实际的软件开发项目中,为了方便排查程序问题,要求在日志文件中输出日志信息所在的程序文件名及日志代码所在的行数.此外,某些软件还会要求将程序启动时的日期时间输出到日志文件中,方便跟踪软件运行状况. 本文介绍了Linux下获取代码文件名.代码行数及日期时间的C代码实现. 二.几个标准预定义宏简介 在C语言中,使用几个标准预定义宏,便可轻松实现获取代码文件名.代码行数及日期时间的功能. 这几个宏的定义如下(注意:前后都是两条连续的下划线): __FILE__:在源文件中插入当前源文件名.

多线程-linux下,子线程如何通过pthread_kill向主线程发送信号?

问题描述 linux下,子线程如何通过pthread_kill向主线程发送信号? //如下代码 #include <stdio.h> #include <signal.h> #include <pthread.h> void signal_deal(int sig); void* fun(); pthread_t pt_main; int main(int argc, char* argv[]) { pthread_t pt; //pt_main = getpid();

Linux下如何查看高CPU占用率线程 LINUX CPU利用率计算

目录(?)[-] proc文件系统 proccpuinfo文件 procstat文件 procpidstat文件                                           procpidtasktidstat文件 系统中有关进程cpu使用率的常用命令 ps 命令 top命令 单核情况下Cpu使用率的计算 基本思想 总的Cpu使用率计算 计算方法 某一进程Cpu使用率的计算 计算方法   实验数据 某一线程Cpu使用率的计算 计算方法   实验数据 多核情况下cpu使用率

Linux下如何查看高CPU占用率线程 专题

Java 系统性能分析 命令 1. cpu分析 top , pidstat(sysstat) pid -p PID -t 1 10 vmstat 1 CPU上下文切换.运行队列.利用率 ps Hh -eo tid pcpu 查看具体线程的CPU消耗 sar 来查看一定世界范围内以及历史的cpu消耗情况信息 查看java线程信息 jstack pid | grep 'nid=0x9999' 2. cs sy消耗比较高 上下文切换性能偏高, jstack -l pid, 查看on object mo

Linux下如何查看高CPU占用率线程

在 Linux 下 top 工具可以显示 cpu 的平均利用率(user,nice,system,idle,iowait,irq,softirq,etc.) ,可以显示每个 cpu 的利用率.但是无法显示每个线程的 cpu 利用率情况,这时就可能出现这种情况,总的 cpu 利用率中 user 或 system 很高,但是用进程的 cpu 占用率进行排序时,没有进程的 user 或 system 与之对应. 可以用下面的命令将 cpu 占用率高的线程找出来: $ ps H -eo user,pid

在linux下如何编译C++程序

一.GCC(GNU Compiler Collection)是linux下最主要的编译工具,GCC不仅功能非常强大,结构也异常灵活.它可以通过不同的前端模块来支持各种语言,如Java.Fortran.Pascal.Modula-3和Ada          g++是GCC中的一个工具,专门来编译C++语言的.          GCC的参数有:( 也是分步实现)                                   -E  让GCC在预处理结束后停止编译  g++ -E hello