linux

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::

随笔分类 -  linux应用程序学习

1 2 下一页

摘要:转自:http://www.dbafree.net/?p=870我们可以使用kill -l查看所有的信号量解释,但是没有看到SIGNAL 0的解释。[root@testdb~]# kill -l 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP 6) SIGABRT 7) SIGBUS SIGFPE 9) SIGKILL 10) SIGUSR1 11) SIGSEGV 12) SIGUSR213) SIGPIPE 14) SIGALRM ... 阅读全文
posted @ 2012-09-28 14:54 h13 阅读(11476) 评论(0) 推荐(0) 编辑

摘要:Author:Jiujin.hong转载请说明出处:http://blog.csdn.net/hongjiujing orwww.linuxforum.net嵌入式linux版块tslib背景:在采用触摸屏的移动终端中,触摸屏性能的调试是个重要问题之一,因为电磁噪声的缘故,触摸屏容易存在点击不准确、有抖动等问题。Tslib是一个开源的程序,能够为触摸屏驱动获得的采样提供诸如滤波、去抖、校准等功能,通常作为触摸屏驱动的适配层,为上层的应用提供了一个统一的接口。tslib插件:pthres 为Tslib 提供的触摸屏灵敏度门槛插件;variance 为Tslib 提供的触摸屏滤波算法插件;deji 阅读全文
posted @ 2012-07-26 23:17 h13 阅读(979) 评论(0) 推荐(0) 编辑

摘要:tcp协议本身是可靠的,并不等于应用程序用tcp发送数据就一定是可靠的.不管是否阻塞,send发送的大小,并不代表对端recv到多少的数据.在阻塞模式下, send函数的过程是将应用程序请求发送的数据拷贝到发送缓存中发送并得到确认后再返回.但由于发送缓存的存在,表现为:如果发送缓存大小比请求发送的大小要大,那么send函数立即返回,同时向网络中发送数据;否则,send向网络发送缓存中不能容纳的那部分数据,并等待对端确认后再返回(接收端只要将数据收到接收缓存中,就会确认,并不一定要等待应用程序调用recv);在非阻塞模式下,send函数的过程仅仅是将数据拷贝到协议栈的缓存区而已,如果缓存区可用空 阅读全文
posted @ 2011-11-15 10:44 h13 阅读(1362) 评论(0) 推荐(0) 编辑

摘要:open("/dev/null",..)很多程序在一开始的时候要做这样的处理/** make sure we have stdin/stdout/stderr reserved*/while((t = open("/dev/null",O_RDWR)) < 3 && T >= 0)if(t >= 3) close(t)写入/dev/null的东西会被系统丢掉就像注释写的那样,对stdin/stdout/stderr进行保护代码中利用while先把文件描述符0,1,2分配出去,以后再分配的时候就不会将stdin/stdou 阅读全文
posted @ 2011-09-19 17:52 h13 阅读(3014) 评论(0) 推荐(0) 编辑

摘要:线程创建1.1 线程与进程相对进程而言,线程是一个更加接近于执行体的概念,它可以与同进程中的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。在串行程序基础上引入线程和进程是为了提高程序的并发度,从而提高程序运行效率和响应时间。线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源的管理和保护;而进程正相反。同时,线程适合于在SMP机器上运行,而进程则可以跨机器迁移。1.2 创建线程POSIX通过pthread_create()函数创建线程,API定义如下:int pthread_create(pthread_t * thread, pthread_attr_t * attr... 阅读全文
posted @ 2011-09-19 16:31 h13 阅读(1466) 评论(0) 推荐(0) 编辑

摘要:如何将stdin、stdout、stderr重定向到/dev/nullQ:我使用了如下代码将stdin、stdout、stderr重定向到/dev/nullfreopen("/dev/null","w",stdout);freopen("/dev/null","w",stderr);freopen("/dev/null","r",stdin);这样做正确吗,是否使用"w+"或者"a"更正确一些。在很多代码中是这样完成重定向的:close 阅读全文
posted @ 2011-09-19 14:24 h13 阅读(3959) 评论(0) 推荐(0) 编辑

摘要:如何分析命令行参数Sun, 2006-07-16 01:27 — MarchdayGNU/Linux的命令行选项有两种类型:短选项和长选项,前者以 '-' 作为前导符,后者以 '--' 作为前导符。比如有一个命令:$ myprog -a vv --add -b --file a.txt b.txt - -- -e c.txt在GNU/Linux系统,对这种情况的一种合理解释是:a是短选项,带一个参数vv;add是长选项,无参数;b是短选项,无参数;file是长选项,带一个参数a.txt;b.txt是参数;-是参数,通常表示标准输入,stdin;--是一个指示符, 阅读全文
posted @ 2011-09-19 10:29 h13 阅读(1307) 评论(0) 推荐(1) 编辑

摘要:下面的说明摘自于最新的Linux内核2.6.29,说明了strtok()这个函数已经不再使用,由速度更快的strsep()代替/** linux/lib/string.c** Copyright (C) 1991, 1992 Linus Torvalds*//** stupid library routines.. The optimized versions should generally be found* as inline code in <asm-xx/string.h>** These are buggy as well..** * Fri Jun 25 1999, 阅读全文
posted @ 2011-09-19 10:17 h13 阅读(30560) 评论(2) 推荐(4) 编辑

摘要:brk和sbrk主要的工作是实现虚拟内存到内存的映射.在GNUC中,内存分配是这样的: 每个进程可访问的虚拟内存空间为3G,但在程序编译时,不可能也没必要为程序分配这么大的空间,只分配并不大的数据段空间,程序中动态分配的空间就是从这一块分配的。如果这块空间不够,malloc函数族(realloc,calloc等)就调用sbrk函数将数据段的下界移动,sbrk函数在内核的管理下将虚拟地址空间映射到内存,供malloc函数使用。(参见linux内核情景分析)#include <unistd.h> int brk(void *end_data_segment); void *sbrk(p 阅读全文
posted @ 2011-09-08 17:25 h13 阅读(2531) 评论(0) 推荐(1) 编辑

摘要:inux下的时间函数我们在编程中可能会经常用到时间,比如取得系统的时间(获取系统的年、月、日、时、分、秒,星期等),或者是隔一段时间去做某事,那么我们就用到一些时间函数。linux下存储时间常见的有两种存储方式,一个是从1970年到现在经过了多少秒,一个是用一个结构来分别存储年月日时分秒的。time_t 这种类型就是用来存储从1970年到现在经过了多少秒,要想更精确一点,可以用结构struct timeval,它精确到微妙。struct timeval{ long tv_sec; /*秒*/ long tv_usec; /*微秒*/};而直接存储年月日的是一个结构:struct tm{ int 阅读全文
posted @ 2011-08-23 16:00 h13 阅读(696) 评论(0) 推荐(0) 编辑

摘要:很久没看APUE,今天一位朋友问道关于一个mutex的问题,又翻到了以前讨论过的东西,为了不让自己忘记,把曾经的东西总结一下。先大体看下网上很多地方都有的关于pthread_cond_wait()的说明:条件变量 条件变量是利用线程间共享的全局变量进行同步的一种机制,主要包括两个动作:一个线程等待"条件变量的条件成立"而挂起;另一个线程使"条件成立"(给出条件成立信号)。为了防止竞争,条件变量的使用总是和一个互斥锁结合在一起。 1. 创建和注销 条件变量和互斥锁一样,都有静态动态两种创建方式,静态方式使用PTHREAD_COND_INITIALIZER常 阅读全文
posted @ 2011-08-23 10:17 h13 阅读(918) 评论(0) 推荐(0) 编辑

摘要:1 线程取消的定义一般情况下,线程在其主体函数退出的时候会自动终止,但同时也可以因为接收到另一个线程发来的终止(取消)请求而强制终止。2 线程取消的语义1. 线程取消的方法是向目标线程发Cancel信号,但如何处理Cancel信号则由目标线程自己决定,或者忽略(当禁止取消时)、或者立即终止(当在取消点或异步模式下)、或者继续运行至Cancelation-point(取消点,下面将描述),总之由不同的Cancelation状态决定。2. 线程接收到CANCEL信号的缺省处理(即pthread_create()创建线程的缺省状态)是继续运行至取消点再处理(退出),或在异步方式下直接退出。一个线程处 阅读全文
posted @ 2011-08-02 09:55 h13 阅读(820) 评论(0) 推荐(0) 编辑

摘要:我们在编写一个C语言程序的时候,经常会遇到好多重复或常用的部分,如果每次都重新编写固然是可以的,不过那样会大大降低工作效率,并且影响代码的可读性,更不利于后期的代码维护。我们可以把他们制作成相应的功能函数,使用时直接调用就会很方便,还可以进行后期的功能升级。 例如我要在一段代码中多次交换两个变量的值,我可以在代码中多次写入i=x;x=y;y=i; 不过这样未免有点麻烦我们可以编写一个change_two_int()函数进行简化。定义如下函数:void change_two_int(int *a,int *b) { int c; c=*a; *a=*b; *b=c; } 这样每次要进行交换时只需 阅读全文
posted @ 2011-07-25 21:01 h13 阅读(5530) 评论(0) 推荐(1) 编辑

摘要:__attribute__详解GNU C的一大特色就是__attribute__机制。__attribute__可以设置函数属性(Function Attribute)、变量属性(Variable Attribute)和类型属性(Type Attribute)。__attribute__书写特征是:__attribute__前后都有两个下划线,并切后面会紧跟一对原括弧,括弧里面是相应的__attribute__参数。__attribute__语法格式为:__attribute__ ((attribute-list))其位置约束为:放于声明的尾部“;”之前。函数属性(Function Attri 阅读全文
posted @ 2011-07-13 08:55 h13 阅读(655) 评论(0) 推荐(0) 编辑

摘要:只有 pthreads 使用属性和取消功能。本章中介绍的 API 仅适用于 POSIX 线程。除此之外,Solaris 线程和 pthreads 的功能大致是相同的。有关相似和不同之处的更多信息,请参见第 8 章,Solaris 线程编程。属性对象通过设置属性,可以指定一种不同于缺省行为的行为。使用 pthread_create(3C) 创建线程时,或初始化同步变量时,可以指定属性对象。缺省值通常就足够了。属性对象是不透明的,而且不能通过赋值直接进行修改。系统提供了一组函数,用于初始化、配置和销毁每种对象类型。初始化和配置属性后,属性便具有进程范围的作用域。使用属性时最好的方法即是在程序执行早 阅读全文
posted @ 2011-07-06 10:09 h13 阅读(3471) 评论(0) 推荐(0) 编辑

摘要:对消息队列的操作无非有下面三种类型:1、 打开或创建消息队列消息队列的内核持续性要求每个消息队列都在系统范围内对应唯一的键值,所以,要获得一个消息队列的描述字,只需提供该消息队列的键值即可;注:消息队列描述字是由在系统范围内唯一的键值生成的,而键值可以看作对应系统内的一条路经。2、 读写操作消息读写操作非常简单,对开发人员来说,每个消息都类似如下的数据结构:struct msgbuf{long mtype;char mtext[1];};mtype成员代表消息类型,从消息队列中读取消息的一个重要依据就是消息的类型;mtext是消息内容,当然长度不一定为1。因此,对于发送消息来说,首先预置一个m 阅读全文
posted @ 2011-07-06 09:24 h13 阅读(974) 评论(0) 推荐(0) 编辑

摘要:在unix系统调用中,标准输入描述字用stdin,标准输出用stdout,标准出错用stderr表示,但在一些调用函数,引用了STDIN_FILENO表示标准输入才,同样,标准出入用STDOUT_FILENO,标准出错用STDERR_FILENO.他们的区别:stdin等是FILE *类型,属于标准I/O,在<stdio.h>。STDIN_FILENO等是文件描述符,是非负整数,一般定义为0, 1, 2,属于没有buffer的I/O,直接调用系统调用,在<unistd.h>。 下面一个例子是对STDOUT_FIFENO 和STDIN_FILENO的应用:#include 阅读全文
posted @ 2011-05-11 11:39 h13 阅读(20827) 评论(0) 推荐(1) 编辑

摘要:1. 前言 2. 使用临时文件 3. 使用匿名管道 4. 使用popen 5. 小结 1. 前言Unix界有一句名言:“一行shell脚本胜过万行C程序”,虽然这句话有些夸张,但不可否认的是,借助脚本确实能够极大的简化一些编程工作。比如实现一个ping程序来测试网络的连通性,实现ping函数需要写上200~300行代码,为什么不能直接调用系统的ping命令呢?通常在程序中通过 system函数来调用shell命令。但是,system函数仅返回命令是否执行成功,而我们可能需要获得shell命令在控制台上输出的结果。例如,执行外部命令ping后,如果执行失败,我们希望得到ping的返回信息。2. 阅读全文
posted @ 2011-05-11 11:27 h13 阅读(12747) 评论(0) 推荐(0) 编辑

摘要:#include <stdio.h>#include <stdlib.h>void test(int* a,int* b){b = a;}int main(void){ int *a,*b=NULL; int c = 2; a = &c; //b = a; test(a,b); if(b) printf("aaaaaaaaaaaaa:%d\n",*b); else printf("bbbbbbbbbbbb\n");}为什么在函数test赋值之后b还是null?毛病出在函数test中。编译器总是要为函数的每个参数制作临时副本 阅读全文
posted @ 2011-04-29 14:56 h13 阅读(1870) 评论(0) 推荐(0) 编辑

摘要:生成静态链接库/动态链接库的makefile如下:#CC:=arm-linux-gccCFLAGS := -I..LDFLAGS := -lpthread -lrtSRCS := $(wildcard *.c)ifdef ARCHlibclient := libclient-$(ARCH).aelselibclient := libclient.aendifall: $(libclient) libclient.so$(libclient): client.o net.o $(AR) -rcv $@ $^libclient.so: client.o net.o $(CC) -shared -o 阅读全文
posted @ 2011-04-25 11:08 h13 阅读(2208) 评论(0) 推荐(0) 编辑

1 2 下一页