本文目錄一覽:
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互斥鎖把改變變數鎖住,其他的線程在讀寫該變數前先獲取該鎖,這樣如果主線程在使用了該鎖,那其他線程就要等該鎖被釋放了,才能獲取到該鎖,才能對變數操作
原創文章,作者:ODSU,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/149059.html