nm命令

WEB2.0 jackxiang 2009-7-21 14:23
nm看可执行文件定义了哪些函数。

nm用来列出目标文件的符号清单。下面是nm命令的格式:  nm [-a|--debug-syms] [-g|--extern-only] [-B][-C|--demangle] [-D|--dynamic] [-s|--print-armap][-o|--print-file-name] [-n|--numeric-sort][-p|--no-sort] [-r|--reverse-sort] [--size-sort][-u|--undefined-only] [-l|--line-numbers] [--help][--version] [-t radix|--radix=radix][-P|--portability] [-f format|--format=format][--target=bfdname] [objfile...]

  如果没有为nm命令指出目标文件,则nm假定目标文件是a.out。下面列出该命令的任选项,大部分支持“-”开头的短格式和“—“开头的长格式。

    * -A、-o或--print-file-name:在找到的各个符号的名字前加上文件名,而不是在此文件的所有符号前只出现文件名一次。

      例如nm libtest.a的输出如下:
      CPThread.o:
      00000068 T Main__8CPThreadPv
      00000038 T Start__8CPThread
      00000014 T _._8CPThread
      00000000 T __8CPThread
      00000000 ? __FRAME_BEGIN__
      …………………………………

      则nm –A 的输出如下:
      libtest.a:CPThread.o:00000068 T Main__8CPThreadPv
      libtest.a:CPThread.o:00000038 T Start__8CPThread
      libtest.a:CPThread.o:00000014 T _._8CPThread
      libtest.a:CPThread.o:00000000 T __8CPThread
      libtest.a:CPThread.o:00000000 ? __FRAME_BEGIN__
      …………………………………………………………
    * -a或--debug-syms:显示调试符号。
    * -B:等同于--format=bsd,用来兼容MIPS的nm。
    * -C或--demangle:将低级符号名解码(demangle)成用户级名字。这样可以使得C++函数名具有可读性。
    * -D或--dynamic:显示动态符号。该任选项仅对于动态目标(例如特定类型的共享库)有意义。
    * -f format:使用format格式输出。format可以选取bsd、sysv或posix,该选项在GNU的nm中有用。默认为bsd。
    * -g或--extern-only:仅显示外部符号。
    * -n、-v或--numeric-sort:按符号对应地址的顺序排序,而非按符号名的字符顺序。
    * -p或--no-sort:按目标文件中遇到的符号顺序显示,不排序。
    * -P或--portability:使用POSIX.2标准输出格式代替默认的输出格式。等同于使用任选项-f posix。
    * -s或--print-armap:当列出库中成员的符号时,包含索引。索引的内容包含:哪些模块包含哪些名字的映射。
    * -r或--reverse-sort:反转排序的顺序(例如,升序变为降序)。
    * --size-sort:按大小排列符号顺序。该大小是按照一个符号的值与它下一个符号的值进行计算的。
    * -t radix或--radix=radix:使用radix进制显示符号值。radix只能为“d”表示十进制、“o”表示八进制或“x”表示十六进制。
    * --target=bfdname:指定一个目标代码的格式,而非使用系统的默认格式。
    * -u或--undefined-only:仅显示没有定义的符号(那些外部符号)。
    * -l或--line-numbers:对每个符号,使用调试信息来试图找到文件名和行号。对于已定义的符号,查找符号地址的行号。对于未定义符号,查找指向符号重定位入口的行号。如果可以找到行号信息,显示在符号信息之后。
    * -V或--version:显示nm的版本号。
    * --help:显示nm的任选项。

如:

nm -D /lib/libc.so.6 | grep log
 分析实施总结报告:
我的测试报告如下:(注意是我的)数据十几万条
采用zouql的索引优化后,每单条网站搜索的CPU负担至少上升一半,如果并发五六条搜索,那等着服务器挂好了
经过彻夜的分析与研究(本人不是程序员,没有理论基础,花的时间也久些)得出:
老柏默认的索引为多列索引,zouql的为单列索引.
看了N多资料后,发现多列肯定是优于单列索引,想想老柏默认的索引是有道理的,否则他不会这样设计的,因为程序的SQL表字段的调用,他最清楚^^
还原老柏默认索引后,性能马上提高一半多.忘了默认索引的朋友我帮大家贴一下:
首先删除所有的索引,除了ID那个,再运行下面:
ALTER TABLE `dede_archives` ADD INDEX `typeid` (sortrank,click,pubdate,senddate,lastpost,postnum);
ALTER TABLE `dede_archives` ADD INDEX `typeid_2` (typeid,typeid2);
ALTER TABLE `dede_archives` ADD INDEX `senddate` (memberID,mtype);
ALTER TABLE `dede_archives` ADD INDEX `title` (title,keywords);
在使用这个默认索引前,我自已也测试了几个多列组合,性能也有所下降,我搞着玩的^^阅读全文
写了一个简单的队列任务处理。多进程任务,异步任务可能会用到这个(主要是命令行应用)
比如,任务的某个一个环节速度十分不稳定,可能执行几秒,也可能执行几分钟,
我就可以把那个环节包括前面的部分扔进队列,多跑几个进程,同时往队列里面写。
然后后面比较快的环节只跑一个处理任务就OK了。让整体速度达到更好的效果。

write.php: 将任务写入队列

<?php
/*
产生队列
*/
//用微秒生成队列文件名。因为会有多个队列,所以加了一个identifier来区分各个队列
function mt($identifier='default')
{
        return sprintf("%.6f.%s",strtok(microtime(),' ')+strtok(''),$identifier);
}

while(1) //实际中尽量不要while(1) 非要while(1)记得任务完成要break
{
        if(count(glob('./queue/*.identifier'))>=10) //队列最大长度,不限制的话硬盘可能会受不了哦。
        {
                sleep(1);//记住这里要sleep,否则队列满了cpu占用很高
                continue;
        }
        $url = 'www.'.time().'.com'; //随便举个例子,我用时间戳生成了一个网址
        echo "$url\r\n";
        $fp = fopen('./queue/'.mt('identifier'),'w');
        fwrite($fp,$url);
        fclose($fp);
        sleep(1);//这里不需要sleep,我sleep是因为我的任务太简单。
}
?>


read.php:

<?php
/*
处理队列
*/

while(1) //实际程序最好不要while(1)如果while(1),记得处理完任务要break
{
        if($queue = glob('./queue/*.identifier'))
        {
                $q = array_shift($queue);
                $url = file_get_contents($q);
                echo $url."\r\n";
                unlink($q);
        }
        sleep(1);//这里要不要sleep或sleep多久自己凭感觉来。
}
?>

yum install openldap openldap-devel nss_ldap openldap-clients openldap-servers

cd php-5.2.8/
./configure 省略参数 --with-ldap --with-ldap-sasl
make ZEND_EXTRA_LIBS='-liconv'
make install

substr()函数可以分割文字,但要分割的文字如果包括中文字符往往会遇到问题,这时可以用mb_substr()/mb_strcut这个函数,mb_substr()/mb_strcut的用法与substr()相似,只是在mb_substr()/mb_strcut最后要加入多一个参数,以设定字符串的编码,但是一般的服务器都没打开php_mbstring.dll,需要在php.ini在把php_mbstring.dll打开。
举个例子:
echo mb_substr('这样一来我的字符串就不会有乱码^_^', 0, 7, 'utf-8');
?>
输出:这样一来我的字
echo mb_strcut('这样一来我的字符串就不会有乱码^_^', 0, 7, 'utf-8');
?>
输出:这样一
从上面的例子可以看出,mb_substr是按字来切分字符,而mb_strcut是按字节来切分字符,但是都不会产生半个字符的现象
在下找到了一个超详细配置教程,大家可以看看去 http://eidiot.net/lessons/fdt/

另外fdt的破解这里也有 , http://my.opera.com/smile_bug/blog/show.dml/192412

这里还有个eclipse的入门,可惜是英文的,偶看了一部分,还没坚持看完- -b

http://www.actionscript.com/Article/tabid/54/ArticleID/Optimizing-Your-Workflow-with-Eclipse-and-FDT/Default.aspx

这还有个针对上篇文章的快捷键总结

http://www.betriebsraum.de/blog/2006/03/12/eclipsefdt-shortcut-sheet/

偶发现这些资源或教程都会在 本站首页 http://www.nshen.net 更新,以后就不会发到blog里了恩。。

eclipse真是强大啊,好多方便的东西。得备忘一下

快捷键:
ctrl shift r 寻找类,很方便不用知道类的路径了

ctrl f 在本文件中查找,替换。当close查找窗口后,ctrl k 继续查找下一个,ctrl shift k 查找前一个

最常用的查找ctrl + J ,可以不用打开新窗口,查找下一个ctrl +J ,查找上一个ctrl shift j

ctrl h 在很多文件中都寻找某字符串,这都是flash灭有的。。

方法属性查找 ctrl+ o

在某变量或方法上按f3可以查找声明该变量或方法的地方

f4可以打开该属性的class类型

f5会打开该class的super class //好象没打开- -b

下边这个厉害了 (Type Hierarchy view),找个类,ctrl+T ,整个类库结构1清2楚了
翻开扉页,购书日期:2003.2.10。实在汗颜,且此类书,我的案头还有许多。
   在两周中抽出时间,翻看完了这本传说中的经典。阅读全文
今天在做GSM模块收发短信中,遇到了一个问题,0X0D和0X0A会自动只收到0X0A,在网上查了下,果真有这个问题。

现在把原因及解决方法写出来:



在我们发送字符0x0d的时候,往往接受端得到的字符是0x0a 这是怎么回事,原因是在串口配置中c_iflag和c_oflag中存在从NL-CR 和CR-NL的映射,也就是说,串口能够把回车和换行看成一个字符,所以,此时我们应该屏蔽掉这些,用options.c_oflag &=~(INLCR|IGNCR|ICRNL|);和options.c_oflag &=~(ONLCR|OCRNL); 进行配置。



还有一个例子:

  struct  termios Opt;
  int  m_fd = open("/dev/ttyAM1", O_RDWR | O_NOCTTY | O_NDELAY);
  if(m_fd==-1) perror("lcd_drawlib: Cannot open ttyAM1! \n" ) ;
  //设置 串口的NL-CR 和CR-NL 的映射
  tcgetattr(m_fd,&Opt);               //首先读取系统默认设置options
  Opt.c_iflag &=~(INLCR|IGNCR|ICRNL);
  Opt.c_oflag &=~(ONLCR|OCRNL);  
  tcflush(m_fd,TCIFLUSH); /* Update the options and do it NOW */    //刷新和立刻写进去
//设置波特率        
  cfsetispeed(&Opt,B9600);
  cfsetospeed(&Opt,B9600);
  tcsetattr(m_fd,TCSANOW,&Opt);
  write(m_fd, "\x0a", 1);
  close(m_fd);


参考资料:http://www.oldlinux.org/oldlinux/viewthread.php?tid=7903,http://www.idcnews.net/html/edu/20070101/285934.html注意:参考中Opt.c_iflag写错,我已进行了修改
<?php
class EchoParam
{
  function EchoValue($a,$b)
  {
    echo "value = ".$a*$b."\n";    
  }

  function EchoValues($a,$b)
  {
    echo "jjjj";
  }
}
class ClsFactory
{
  public static function CreateNoCheckModel($classname)
  {
    return new $classname;
  }
}
class Vmware
{  
  public function doProx($method, $args)  
  {
    $model = ClsFactory::CreateNoCheckModel("EchoParam");
    echo call_user_func_array ( array ($model, $method), $args);
  }
  public function __call($method, $args)
  {  var_dump($method);
    return $this->doProx($method, $args);
  }
}
$a = 1;
$b = 88;
$mwallobj = new Vmware();
$mwallobj->EchoValue($a, $b);
$mwallobj->EchoValues($a, $b);
?>

这个$method 就是调用的函数名,这就给代理前作判断,而可以代理后就调用modle层的方法,正是因为类Vmware没有这个方法名,而modle层有这个方法名,达到了代理认证的目的。

结果:

[root@vm0000055 ~]# php call_user_func_array.php
string(9) "EchoValue"
value = 88
string(10) "EchoValues"
jjjj


==========================================
call_user_func_array函数也可以调用类内部的方法的:
Class ClassA
{
  function bc($b, $c) {
    $bc = $b + $c;
    echo $bc;
  }
}
call_user_func_array(array('ClassA','bc'), array("111", "222"));
//显示 333
?>
注意POST:

$this->para['uid'] = $_POST['uid'];
$this->para['content'] =$_POST['content'];

GET接收:

$this->para['uid'] = $_GET['uid'];
$this->para['content'] =$_GET['content'];

中文问题:

    var url="a.jsp?name=小李";
    url=encodeURI(url);
    url=encodeURI(url); //两次,很关键[具体为什么,我也不清楚]
    /********************************************/
    也有人写成var url="a.jsp?name=escape("小李")";
    功能和encodeURI方法类似。
    /********************************************/
    xmlHTTP.setrequestheader("cache-control","no-cache");
    xmlHTTP.setrequestheader("Content-Type","application/x-www-form-urlencoded");
    xmlHTTP.setrequestheader("contentType","text/html;charset=uft-8")//指定发送数据的编码格式
    xmlHTTP.open ("post",url,true);

PHP得做:urldecode()的操作。

用httpfox抓包,用httpwatcher调试js错误。
以下是Ajax POST提交方式提交:
阅读全文

$HTTP["host"] == "xd.sina.com.cn" {
    server.document-root = "/opt/www/pengyou/framework2/"
    accesslog.filename = space_logdir + "xd.sina.com.cn-access.log"
    server.errorlog = space_logdir + "xd.sina.com.cn-error.log"

    url.rewrite-once = (
        "^/?$"                  => "/control/index.php",
        "^/view/(.*)"           => "/view/$1",
        "^/(.*)"                => "/control/$1",
      )        
        

}
PHP开发,个人觉得还是要轻量级去做框架,分为3个层次:data 层  modle层 control 层,而我们在data层里面可能会用到设计模式的单一模式,而在modle层里面可能采用简单工厂模式,而在control层里面有order模式,和代理(proxy层,让框架去自动调用),而这里面往往这些都在一个依赖倒转原则下(也就是会修电脑但你不会修收音机),其实就是一个里氏代换原则,让data modle control彻底的分开,就像电脑插槽一样,随时随地可以替换,而且很容易查到问题 的所在。


工厂类调用方式:

                $smarty = ClsFactory::Create ( "libs::MySmarty" );
                $this->template = 'myrecord.html';



工厂类实现方法:

class ClsFactory
{
        function Create($classname)
        {
                $c = explode("::",$classname);
                if(count($c) == 2)
                {
                        $package = $c[0];
                        $classname = $c[1];
                }

                if(!class_exists($classname))
                {
                        $classpath = SERVER_ROOT."/libs/";
                        //if($package) $classpath .= $package."/";
                        $classfile = $classpath.strtolower($classname).".class.php";
                        if(!file_exists($classfile)) return 0;
                        include($classfile);
                }
                if(!class_exists($classname)) {
                        return 0;
                }
                return new $classname;
        }
}


路径定义:

./stdafx.php:define ( "SERVER_ROOT", dirname ( __FILE__ ) );


全局变量:

function init_www()
{

        $need_include = array (

                        SERVER_ROOT,
                        SERVER_ROOT . DIRECTORY_SEPARATOR . "libs" . DIRECTORY_SEPARATOR,
                        SERVER_ROOT . DIRECTORY_SEPARATOR . "program" . DIRECTORY_SEPARATOR,
                        dirname ( SERVER_ROOT ) . DIRECTORY_SEPARATOR . "libs" . DIRECTORY_SEPARATOR );
        $include_path = explode ( PATH_SEPARATOR, ini_get ( 'include_path' ) );
        foreach ( $need_include as $path )
        {
                if (! in_array ( $path, $include_path ))
                {
                        $include_path [] = $path;
                }
        }
        ini_set ( 'include_path', join ( PATH_SEPARATOR, $include_path ) );
}
init_www ();



背景:在Flash里直接在浏览器关闭时实现上报数据(Get;/Post;),发现有些浏览器不支持,调用Js实现也有这样的一个问题,记录在:
http://jackxiang.com/post/6084/

chrome浏览器支持onbeforeunload事件吗?
Chrome Safari 在调用 document.write、document.open、document.close 方法以及 "javascipt:" 伪协议时,不会触发 onbeforeunload 事件。

http://w3help.org/zh-cn/causes/BX2047


于是我就自己也试了一把这个Js调用Flash,Flash再调用Js的一个过程,记录如下:
这一篇文章是最好的实践方法,尤其是对Js调用Flash里的函数不同浏览器的不同方法:
http://www.imququ.com/post/39.html
再就是在使用FlashDevelop时新建时默认要用ActionScript AS3 Project,默认的AS3才行。

核心:http://www.imququ.com/post/39.html
结果,除了IE之外,其他浏览器都不会工作,会提示找不到hello这个方法。这个问题困扰了我比较久。最后发现:在非IE浏览器里,flash提供的方法是加在embed上的,我们要得到object下的embed对象,调用embed上的方法才会成功!

1)Html代码如下,index.html:



2)Flash的代码如下,Main.as:



阅读全文
多选select 的name必须是一个name_value[],后面有这个中括号,为哈?
如果不是中括号的话,你用httpfox抓下包,
select  1
select  2
select  3

php他会得到一个值,也就是多选最下面的那个值,而在加上中括号后呢,就会出现如下:
select[]  1
select[]  2
select[]  3


select.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>提交多选的静态页</title>
</head>

<body>
<form id="post_form" name="post_form" method="post" action="./select.php">
  <select name="select[]" size="10" multiple="multiple" id="select">
    <option value="1">1</option>
    <option value="2">2</option>
    <option value="3">3</option>
    <option value="4">4</option>
  </select>
  <label> <br />
  <input type="submit" name="button" id="button" value="提交" />
  </label>
</form>
</body>
</html>



<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>PHP接收多选是一个数组</title>
</head>
select.php
<body>

<?php
print_r($_POST['select']);

?>

</body>
</html>




这样PHP得到:

Array
(
    [0] => 1
    [1] => 2
    [2] => 3
)



1. 自己技术很强很全面.
作为leader, 不一定要写很多代码, 但是下面人有了问题你要能解决. 这既是项目需要, 也是leader建立威信所必须的. 从lz的描述来看, 自己只参与了数据库相关的开发, 以至于小到搭环境出现问题大到改架构都需要X来处理, 而对于X没处理好的lz似乎很不满

2. 底下有个技术和关系都很过硬的人.
这个不用多说了, 只要这个技术牛人很服你, 你们沟通肯定没问题, 出现技术问题他自然可以帮你顶着. 有技术没关系, 别人没这个义务(如果只有你是leader的话). 没技术, 那啥也不用说了.

3. 团队技术过硬,关系融洽.
技术过硬问题就少, 关系融洽, 有问题就可以内部消化, 基本不会暴露到你跟前.
一、90%的困难你现在想都没有想到,你都不知道那是困难。

    二、团队核心成员有人要提出辞职时,不要挽留,既然提出了,他迟早是要走的。

    三、如果没有价格上的优势与技术上的绝对优势,千万不要进入红海市场,否则你会必输无疑!

    四、做连锁经营业务,一定要做一套傻瓜版的营销手册与管理手册,只有这样,才能实现远距离的管理。  

    五、做成功一个店之后离你大的成功就不远了,所以你首先就是脚踏实地、集中精力地先做出一家,也是要放弃掉连锁的这种,不要在将来如何做连锁方面做太多的梦,先脚踏实地做出第一家。 阅读全文
分页: 245/339 第一页 上页 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 下页 最后页 [ 显示模式: 摘要 | 列表 ]