本文目录一览:
C语言queue如何加锁和解锁
有两种办法:
重载一个queue模板,把锁封装到重载的函数里
每次使用queue的函数的时候加锁,使用完毕后,解锁
c语言根据条件解锁3位密码锁?
根据你的代码修改,正确的逻辑如下:
#includestdio.h
int check1(int i,int j,int k)
{
if(i==2j!=4k!=6) return 1;
if(i!=2j==4k!=6) return 1;
if(i!=2j!=4k==6) return 1;
return 0;
}
int check2(int i,int j,int k)
{
if((i==5||i==8)j!=2j!=5j!=8k!=2k!=5k!=8) return 1;
if((j==2||j==8)i!=2i!=5i!=8k!=2k!=5k!=8) return 1;
if((k==2||k==5)i!=2i!=5i!=8j!=2j!=5j!=8) return 1;
return 0;
}
int check3(int i,int j,int k)
{
if(i==9(j==6||j==2)k!=6k!=9k!=2) return 1;
if(i==2j==6k!=6k!=9k!=2) return 1;
if(k==6(i==9||i==2)j!=6j!=9j!=2) return 1;
if(k==9i==2j!=6j!=9j!=2) return 1;
return 0;
}
int check4(int i,int j,int k)
{
if(i!=1i!=7i!=4j!=1j!=7j!=4k!=1k!=7k!=4)
{
return 1;
}
return 0;
}
int check5(int i,int j,int k)
{
if((i==1||i==9)j!=4j!=1j!=9k!=4k!=1k!=9) return 1;
if((j==4||j==9)i!=4i!=1i!=9k!=4k!=1k!=9) return 1;
if((k==4||k==1)i!=4i!=1i!=9j!=4j!=1j!=9) return 1;
return 0;
}
int main()
{
int i,j,k;
for(i=0;i10;i++)
for(j=0;j10;j++)
for(k=0;k10;k++)
{
if(check1(i,j,k))
{
if(check2(i,j,k))
{
if(check3(i,j,k))
{
if(check4(i,j,k))
{
if(check5(i,j,k))
{
printf("%d%d%d\n",i,j,k);
}
}
}
}
}
}
}
51单片机4*4矩阵键盘用C语言如何设置成密码开锁键?
#includestdio.h
#includereg51.h
#define uchar unsigned char
uchar key;
int i=0;
char b[4]={'0','0','0','0'};//输入的密码放这里和初始的比较来判断是否密码正确
void keyscan() //扫描按键是否按下
{
uchar temp;
P3=0xfe; //扫描第一行
temp=P3;
temp=temp0xf0;
if(temp!=0xf0) //判断按键是否按下
{
delayms(10);//去抖动
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)//确认按键按下
{
temp=P3;
switch(temp)
{
case 0xee:key='0';break;
case 0xde:key='1';break;
case 0xbe:key='2';break;
case 0x7e:key='3';break;
}
while(temp!=0xf0) //判断按键是否松开
{
temp=P3;
temp=temp0xf0;
}
b[i]=key;i++;if(i==3)i=0;
}
}
P3=0xfd; //扫描第二行
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)
{
delayms(10);
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xed:key='4';break;
case 0xdd:key='5';break;
case 0xbd:key='6';break;
case 0x7d:key='7';break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp0xf0;
}
b[i]=key;i++;if(i==3)i=0;
}
}
P3=0xfb; //扫描第三行
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)
{
delayms(10);
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xeb:key='8' ;break;
case 0xdb:key='9' ;break;
case 0xbb:key='A';break;
case 0x7b:key='B';break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp0xf0;
}
b[i]=key;i++;if(i==3)i=0;
}
}
P3=0xf7; //扫描第四行
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)
{
delayms(10);
temp=P3;
temp=temp0xf0;
if(temp!=0xf0)
{
temp=P3;
switch(temp)
{
case 0xe7:key='C';break;
case 0xd7:key='D';break;
case 0xb7:key='E';break;
case 0x77:key='F';break;
}
while(temp!=0xf0)
{
temp=P3;
temp=temp0xf0;
}
b[i]=key;i++;if(i==3)i=0;
}
}
}
main()
{
char a[4]={'3','5','A','C'}; //这个做初始密码
while(1)//无限循环,保证了b 0-3 四个数有值
{
keyscan();
if(a[0]==b[0]a[1]==b[1]a[2]==b[2]a[3]==b[3])
{
//这里写密码正确程序要怎么处理
}
}
}
代码应该可以。。 我没板子,只是想着写。你main里面加上你要的功能试试,顺便把结果告诉我下。。。 我只是给每个按键做标记,然后根据按键按下的顺序,和预定的标记相同则判断密码正确。 按键是低电平选通。
(C语言中)互斥锁的死锁问题
如果你将mutex_c换成mutex_p,则不会死锁,因为,你第一个线程锁上后,切换到第二个线程,因为mutex_p未释放,第二个线程无法获取mutex_p,进入等待状态,此时OS将再次调度第一个线程,直到第一个线程释放mutex_p之后,第二个线程才会被激活,然后调试第二线程,获取mutex_p.
使用OS提供的互斥量来保护公共资源还是比较安全的,但如果用二值信号量的话,就可能会有优先级反转的情况.
C语言变量锁
在当前线程用mutex互斥锁把改变变量锁住,其他的线程在读写该变量前先获取该锁,这样如果主线程在使用了该锁,那其他线程就要等该锁被释放了,才能获取到该锁,才能对变量操作