关闭

Linux Advance--输出错误信息

标签: linux线程
238人阅读 评论(0) 收藏 举报
分类:

最近在学习 linux 高级编程中的线程控制,因为一般情况下创建线程或者给临界资源上锁是不会出错的,我想故意返回个错误码看输出的是什么,但是终端直接抛出 “segmentation fault” 我也是很纳闷,后来发现输出错误信息调用了 strerror 函数,然后我在 c++ reference 上查了一下,发现这个函数必须要引入头文件 string.h 才能用。下面是我实验的源代码:


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <errno.h>

void *thr_fn(void *arg)
{
	printf(arg);
}

int makethread(void *(*fn) (void *), void *arg)
{
	int 			err;
    pthread_t		tid;
    pthread_attr_t 	attr;

    err = pthread_attr_init(&attr);
    if (err != 0)
		return err;
    err = pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_DETACHED);
    if (err == 0)
		err = pthread_create(&tid, &attr, fn, arg);
	pthread_attr_destroy(&attr);
	return err;
}

int main()
{
	int err = makethread(thr_fn, "thread 1 is running\n");
	if (err != 0) {
		printf("can't create thread: %s\n", strerror(err));
		exit(1);
	}
	sleep(1);
	printf("thread created\n");
    exit(0);
}


0
0
查看评论

linux C 打印错误信息和标准输入输出

Linux 使用strerror 和 perror 函数来打印响应的错误信息 ,这两个函数的标准调用格式说明如下:#include<string.h> char *strerror(int errnum) #include<stdio.h> void perror(const...
  • lym152898
  • lym152898
  • 2016-07-17 00:44
  • 3570

编译Linux/Android 输出很多信息很难找到错误/警告信息怎么办?

记住,Linux无所不能,有办法的! 1.只保留错误信息:  make 2>log.txt               #(注意2和>之间不...
  • lqxandroid2012
  • lqxandroid2012
  • 2016-05-12 20:43
  • 818

linux 输出正确或错误信息到文件 1> 或 2>>

1> :以覆盖的方法将『正确的数据』输出到指定的文件或装置上;1>>:以累加的方法将『正确的数据』输出到指定的文件或装置上;2> :以覆盖的方法将『错误的数据』输出到指定的文件或装置上;2>>:以累加的方法将『错误的数据』输出到指定的文件或装置上; 例: 1....
  • prince_jun
  • prince_jun
  • 2013-11-13 17:03
  • 3503

使用Linux输出重定向将debug信息和ERROR信息分离

最近在安装Apache sentry,发现启动metastore和hiveserver2服务的时候会弹出大量的debug信息,有时候需要在一长串的信息中寻找ERROR信息,觉得挺花时间的,于是想到使用重定向将debug信息输出到指定的debug目录下,ERROR信息输出到ERROR目录下,这样能提高...
  • lym152898
  • lym152898
  • 2017-08-20 22:49
  • 282

如何获取shell命令输出的错误信息?

rmmod xxx(xxx为某个ko的名称) 系统提示:ERROR:Module xxx ins use 这个如何获取“ERROR:Module xxx ins use”? 尝试了rmmod xxx > log,无法得到。因为命令执行出错之后,不会再重定向到log文件中 ...
  • xiaaiwu
  • xiaaiwu
  • 2015-10-15 14:26
  • 2213

查找linux文件错误信息

grep -i -E 'error|fail|false|fault' /citic/switch/switch.log 其中-i为忽略大小写,|代表或者
  • qiuyang0607
  • qiuyang0607
  • 2016-01-06 16:35
  • 615

使用命令将logcat中的内容输出到文本文件中(防止滑屏看不到错误信息)

输出日志信息到文件 :  -- "-f"选项 : 该选向后面跟着输入日志的文件, 使用adb logcat -f /sdcard/log.txt 命令, 注意这个log文件是输出到手机上,需要指定合适的路径。 ...
  • u010477502
  • u010477502
  • 2016-07-10 18:12
  • 458

oracle sqlplus下查询错误输出信息

SQL> !oerr ora 00271 00271, 00000, "there are no logs that need archiving" // *Cause:  An attempt was made to archive the unarchiv...
  • huashnag
  • huashnag
  • 2013-01-29 13:42
  • 1419

sql server 存储过程 返回错误信息 (编号:20110617A1020)

http://msdn.microsoft.com/en-us/library/ms178592.aspx  RAISERROR (Transact-SQL) ...BEGIN TRY -- RAISERROR with severity 11-19 will c...
  • lmn13
  • lmn13
  • 2011-06-17 10:22
  • 920

Linux Advance--守护进程

在linux或者unix操作系统中在系统引导的时候会开启很多服务,这些服务就叫做守护进程。为了增加灵活性,root可以选择系统开启的模式,这些模式叫做运行级别,每一种运行级别以一定的方式配置系统。 守护进程是脱离于终端并且在后台运行的进程。守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终...
  • qq_20480611
  • qq_20480611
  • 2015-11-22 21:27
  • 267
    个人资料
    • 访问:559650次
    • 积分:10876
    • 等级:
    • 排名:第1785名
    • 原创:517篇
    • 转载:3篇
    • 译文:0篇
    • 评论:45条