c语言基础笔试坑点

1、#define N 5 + 5

  求 k = N*N*5

  错误解法:10*10*5 = 500

  正解(重点:注意黄色部分):5 + 5 * 5 + 5 * 5 = 55

2、死锁的必要条件:

   1、相互排斥使用(资源独占)

     一个资源每次仅仅能给一个进程使用 

   2、不可强占(不可剥夺)
       资源申请者不能强行的从资源占有者手中夺取资源,资源仅仅能由占有者自愿释放 

   3、请求和保持(部分分配,占有申请)
     一个进程在申请新的资源的同一时候保持对原有资源的占有(仅仅有这样才是动态申请,动态分配) 

   4、循环等待
    存在一个进程等待队列
       {P1 , P2 , … , Pn},
       当中P1等待P2占有的资源,P2等待P3占有的资源,…,Pn等待P1占有的资源,形成一个进程等待环路

3、地址偏移:

   int arr[6] = { 1,2,3,4,5,9};

   偏移一个地址:     

    int *p = (int *)( &arr[0]+1);

   整体偏移:

    int *p = (int *)( &arr + 1);

  printf("%d %d\n", *(arr+1), *( p ) );

4、陷阱(进制间转换)

  unsigned long *p2;
  p2 = ( unsigned long *)0x709000;
  printf("  p2 +5 = %p , p2 = %p\n", p2 +5, p2 );

  答案: 0x709028, 0x709000 

  

猜你喜欢

转载自www.cnblogs.com/dcli-blog/p/11735499.html