linux 散知识点

大端模式,是指数据的高字节保存在内存的低地址中,而数据的低字节保存在内存的高地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;
小端模式,是指数据的高字节保存在内存的高 地址中,而数据的低字节保存在内存的低地址中,这种存储模式将地址的高低和 数据位权有效地结合起来,高地址部分权值高,低地址部分权值低,和我们的逻辑方法一致。
例如一个16bit的short型x,在内存中的地址为0x0010,x的值为0x1122,那么0x11为高字节,0x22为低字节。对于 大端模式,就将0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,刚好相反。我们常用的X86结构是小端模式,而KEIL C51则为大端模式。很多的ARM,DSP都为小端模式。有些ARM处理器还可以由硬件来选择是大端模式还是小端模式。
2

以下关于交叉编译器概述正确的是(A)

A)交叉编译器一般按照CPU类型分类,不同的CPU就有不同的交叉编译器

B)交叉编译器的速度比其他编译器的速度要快

C)linux开发环境中的交叉编译器不是gcc编译器

D)交叉编译器编译出来的目标文件一般也能在开发机(普通PC)上运行

3

Traceroute是一个正确理解IP网络并了解路由原理的重要工具

Traceroute程序的设计是利用ICMP及IP header的TTL(Time To Live)栏位(field)。首先,traceroute送出一个TTL是1的IP datagram(其实,每次送出的为3个40字节的包,包括源地址,目的地址和包发出的时间标签)到目的地,当路径上的第一个路由器(router)收到这个datagram时,它将TTL减1。此时,TTL变为0了,所以该路由器会将此datagram丢掉,并送回一个「ICMP time exceeded」消息(包括发IP包的源地址,IP包的所有内容及路由器的IP地址),traceroute 收到这个消息后,便知道这个路由器存在于这个路径上,接着traceroute 再送出另一个TTL是2 的datagram,发现第2 个路由器...... traceroute 每次将送出的datagram的TTL 加1来发现另一个路由器,这个重复的动作一直持续到某个datagram 抵达目的地。当datagram到达目的地后,该主机并不会送回ICMP time exceeded消息,因为它已是目的地了,那么traceroute如何得知目的地到达了呢?
Traceroute在送出UDP datagrams到目的地时,它所选择送达的port number 是一个一般应用程序都不会用的号码(30000 以上),所以当此UDP datagram 到达目的地后该主机会送回一个「ICMP port unreachable」的消息,而当traceroute 收到这个消息时,便知道目的地已经到达了。所以traceroute 在Server端也是没有所谓的Daemon 程式。

4
    char str[] = "Hello";
    char *p = str;
    printf("sizeof(str) : %d\n", sizeof(str));
    printf("sizeof(A) : %d\n", sizeof("A"));
    printf("sizeof('A') : %d\n", sizeof('A'));
    printf("strlen(str) : %d\n", strlen(str));
    printf("sizeof(str) : %d\n", sizeof(p));

结果:
sizeof(str) : 6
sizeof(A) : 2
sizeof('A') : 4
strlen(str) : 5
sizeof(str) : 8

5
find . -path "./dirname" -prune -o -name "*.dll" -print
不包含某个目录, 去查找文件

find . -path "./mvconfigs" -prune -o -type  f -print | wc -l
不包含某个目录, 统计所有的文件

另外说几个常用的参数:
-exec 是将查找到的文件执行命令(-exec command {} \;)
-ok    与-exec相同,只不过操作前要询问用户
-user   按文件属主查找
-group 按文件数组查找
-mtime 按文件更改时间查找
-atime  按文件访问时间查找
-ctime  按文件创建时间查找


6
指针的概念
     一个变量在内存中所占存储单元的 地址号就是该 变量的指针。
如:int i;
        i=20;
假设i变量在内存中所占存储单元的地址号为:1000 ,此时称1000这个存储地址为变量i的指针,而20是变量i的值。
2.8.1.1 指针变量的定义
     专门存放其他变量地址的变量称为指针变量。和其他变量的定义类似,指针变量在使用前也必须定义其类型。其定义的一般形式为:
   类型标识符号  *指针变量名表
如:  int i=50;
          int *ip;
说明:
(1)指针变量名前面的‘*’表示该变量为指针变量,它不是变量名本身的一部分。
(2)此处的类型标识符是该指针变量所要指向的变量的类型。

指针与函数
     前面讲过,函数的参数可以为整型、实型、字符型等普通变量。实参与形参间参数的传递是单向的“值传递”。
    但函数的参数也可为指针,它的作用是将一个变量的地址传给被调函数的形参。此时主调函数的调用点上的实参必须是地址值(指针),而被调函数的形参一定要定义成指针变量的形式
   此时,被调函数的形参得到的是实参的指针,因此,该形参变量就指向实参,在被调函数中对形参的操作就相当于对它所指向的实参的操作


7
函数的指针
一个函数在内存中的起始地址就是该函数的指针。
在C++中,函数的名称就代表了该函数的指针。
指向函数的指针变量的一般定义形式为:
    数据类型标识符  (*指针变量名)( );
  在C++语言中,指针变量可以指向普通变量,它也可以指向函数。

#include "iostream.h"
int max(int x, int y);   //声明被调函数max
void main()
{       int a,b,c;
        cin>>a>>b;
        c=max(a,b);
        cout<<c;  }     
int  max(int x,int y)
{       int z;
        if(x>y)
           z=x;
        else
           z=y;
        return(z);  }

如果改用指向函数的指针变量的话,则main函数为:
 void   main()
    { int (*p)();   //定义了一个指向返回值为int型的函数的  
            指针变量p  
       int a,b,c;
       p=max;          //将函数max的首地址(即指针)赋  
                 给指针变量p
        cin>>a>>b;
        c=(*p)(a,b);
        cout<<c;
      }

说明:
(1)int (*p)() 说明了一个指向返回值为整型数据的函数的指针。
(2)p=max 表示把函数的入口地址赋给指针变量p,那么*p就是函数max.因此c=(*p)(a,b);和c=max(a,b)等价。
注意:
(1)函数的调用可以通过函数名调用,也可通过函数指针调用。
(2)int (*p)();只是表示定义了一个指向函数的指针变量。
(3)在函数指针变量赋值时,只须给出函数名,不必给出参数: 如:p=max; 因为只是传递函数的地址。
(4)对指向函数的指针做象p+n,p++,p—等算数运算是无意义的。



你可能感兴趣的:(linux 散知识点)