摘要:
在SMP系统中,我们的应用程序经常使用多线程的技术,那么在Linux中如何查看某个进程的多个线程呢?本文介绍3种命令来查看Linux系统中的线程(LWP)的情况:在我的系统中,用qemu-system-x86_64命令启动了一个SMP的Guest,所以有几个qemu的线程,以此为例来说明。1. pstree 命令,查看进程和线程的树形结构关系。View CodeBASH1
2
3
4
5
[root@jay-linux ~]# pstree | grep qemu |-gnome-terminal-+-bash---qemu-system-x86---2*[{qemu-system-... 阅读全文
摘要:
本章提供足够的信息使你用够使用 Vim 来做基本的编辑。这里提供的方法不一定是高效快捷的。但起码是有效的。花些时间去练习这些命令,这是后面的知识的基础。|02.1| 第一次运行 Vim|02.2| 插入文本|02.3| 移动光标|02.4| 删除字符|02.5| 撤销与重做|02.6| 其它编辑命令|02.7| 退出|02.8| 寻求帮助 下一章:|usr_03.txt| 移动 前一章:|usr_01.txt| 关于本手册 目录:|usr_toc.txt|---------------------------------------------------------------------- 阅读全文
摘要:
C/C++中判断某一文件或目录是否存在1.C++很简单的一种办法:#include#includeusingnamespacestd;#defineFILENAME"stat.dat"intmain(){fstream_file;_file.open(FILENAME,ios::in);if(!_file){cout
#include
#include voidmain(void)
{
/*Checkforexistence*/
if((_access("ACCESS.C",0))!=-1)
{
printf("FileACCESS.Cexis 阅读全文
摘要:
题目:给出n,求出最小的m,满足m^2 % 10^k = n,其中k=0,1,2http://acm.hdu.edu.cn/showproblem.php?pid=4394只要有一个x满足条件便行了我们可以初步发现,某个数个位确定,那么平方的最后一位肯定是确定的,那么如果后两们确定,那么平方的最后两们也是确定的,这可以通过乘法的规律得到那我们只需要BFS一下,不断地找满足最后指定位数的数,1位,2位,……直到找到第一个满足条件的。注意这里可能是100001这种情况所以记录当前数字大小,当前位置,可能暂时的高位为0,以后下一个添加的数为多少.// Time 0ms; Memory 316K#in 阅读全文
摘要:
drop table zrjReinUnClaimTmpT; create table zrjReinUnClaimTmpT ( mainid SERIAL not null, RepayNo varchar(25) not null, comCode varchar(8) not null, CaseNo varchar(25) not null, reinsType varcha... 阅读全文
摘要:
问题:使用UltraISO 9.5.3制作U盘启动盘,ISO文件使用ubuntu-12.04.2-server-i386.iso,ISO文件经过MD5验证是正确的。将U盘查到计算机上,进bios选择U盘启动为第一启动顺序,重启后选择安装ubuntu 12.04 server,选择完语言,在检测硬件的过程中跳出错误:The failing step is: Load installer components from CD.即通常所说的,从光盘读取数据出错。解决办法:1. 以前碰到此类问题,基本上是通过改换烧写U盘启动的软件工具来解决的。于是,换用Universal-USB-Installer- 阅读全文
摘要:
线段树入门在自然数,且所有的数不大于30000的范围内讨论一个问题:现在已知n条线段,把端点依次输入告诉你,然后有m个询问,每个询问输入一个点,要求这个点在多少条线段上出现过;最基本的解法当然就是读一个点,就把所有线段比一下,看看在不在线段中;每次询问都要把n条线段查一次,那么m次询问,就要运算m*n次,复杂度就是O(m*n)这道题m和n都是30000,那么计算量达到了10^9;而计算机1秒的计算量大约是10^8的数量级,所以这种方法无论怎么优化都是超时-----因为n条线段是固定的,所以某种程度上说每次都把n条线段查一遍有大量的重复和浪费;线段树就是可以解决这类问题的数据结构举例说明:已知线 阅读全文
摘要:
第一章小记:每个C程序都要求有一个main()函数(多于一个main()函数是不合法的(已犯错:在VS 2010一个项目里两个C文件都有main函数,不能编译通过,必须删除一个文件,永记))。main()函数所在的位置就是程序开始运行的地方。函数的运行从该函数的开括号起,到相应的闭括号止。C程序应用小写字母书写,而大写字母则用作符号或输出字符串。程序行中的所有词之间应至少有一个空格、制表符或连字符分隔开。在C语言中,每个程序语句必须以分号结尾。所有变量在使用之前必须已经被声明为某种数据类型。如果程序引用了未定义的特定名或函数,必须使用#include命令包含相应的头文件。编译器命令(如defi 阅读全文
摘要:
问题:将一个c文件改为cpp文件,其中的perror()改用C++中的std::cerr ,而strerror()只需要用到头文件,所以,重新编译时,将替换为。2. errno无疑是一个系统定义的全局变量,不是由用户来声明或定义的。查到中有这样的宏定义#ifndef errno
extern int errno;
#endif将头文件包含到程序中,重新编译,编译顺利完成。问题解决。 阅读全文
摘要:
System V IPC分为三种:System V消息队列System V信号量System V共享内存区这三种类型的IPC使用key_t值做为它们的名字。key_t这个数据类型在有定义,通常是一个至少32位的整数。我们通常使用ftok()函数(可以如此记忆:file to key)把一个已存在的路径名和一个整数标识符转换成一个key_t值,称为IPC键。(当然,我们也可以不用ftok函数来生成该键,指定一个整数也是可以的,当然你需要考虑键的正负问题)。看下ftok的声明:1#include 2/* Generates key for System V style IPC. */3key_t 阅读全文