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
原文地址:https://www.cnblogs.com/dcli-blog/p/11735499.html
时间: 2024-10-10 05:14:39