}
acStr[i++] = Tmp;
}
}break;
case IntOrChar:
{
if((Tmp >= 'A' && Tmp <= 'Z') || (Tmp >='a' && Tmp <='z') || (Tmp >= '0' && Tmp <= '9'))
{
if(isPlaintext == NotPwd)
{
putchar(Tmp);
}
else
{
putchar('*');
}
acStr[i++] = Tmp;
}
}break;
}
}
}
if(flg == 1) break;
}
acStr[i] = '\0';
return 0;
}
/*******************************链表初始化函数********************************
名称:链表初始化函数
参数:
data:数据
head:链表头指针
功能:
链表初始化
**************************************************************************/
void* LinkInit(void *data)
{
struct NODE *head;
head = (struct NODE*)malloc(sizeof(struct NODE));
if(head == NULL)
{
perror("linkinit error");
return NULL;
}
head->data = data;
head->NEXT = NULL;
return head;
}
/*******************************增加链表节点函数********************************
名称:增加链表节点函数
参数:
phead:链表头节点
data:数据
len:要操作的链表节点数据结构的大小
功能:
增加链表节点
**************************************************************************/
void LinkAddNode(struct NODE *phead, void *data, int len)
{
struct NODE *pNew;
struct NODE *pTemp;
pTemp = phead;
while(pTemp->NEXT != NULL)
{
pTemp = pTemp->NEXT;
}
pNew = (struct NODE *)malloc(sizeof(struct NODE));
if(pNew == NULL)
{
perror("LindAddNode error");
return;
}
else
{
pNew->data = malloc(len);
if(pNew->data == NULL)
{
perror("LindAddNode error");
return;
}
}
memcpy(pNew->data, data, len);
pNew->NEXT = NULL;
pTemp->NEXT = pNew;
return;
}
/*int DataInit()
{
int i;
struct MAN m[] =
{
{"1001", "admin", "123456", 0, 1},
{"1002", "manager", "123456", 1, 1},
{"1003", "waiter", "123456", 2, 1}
};
i = 0;
myhead = (struct NODE*)LinkInit(NULL);
for(i = 0; i < 3; i++)
{
LinkAddNode(myhead, &m[i], sizeof(m[i]));
}
return 0;
}*/
/*******************************释放链表函数********************************
名称:释放链表函数
参数:
phead:链表头节点
功能:
释放链表
**************************************************************************/
void LinkFreeNode(struct NODE *phead)
{
struct NODE *pTemp = phead;
//static int aaa = 0;
while(pTemp != NULL)
{
phead = phead->NEXT;
free(pTemp->data);
free(pTemp);
pTemp = phead;
//printf("释放次数=%d\n", ++aaa);
}