C控制台密码输入:输入一个字符显示一个星号
要在c控制台中输入一个字符显示一个星号, 则不能用"stdio.h'提供的库函数,因为它们都是带回显的,比如getchar()
getchar()用来接收输入的字符串,输入一个字符就回显一个,直到遇到回车键或空格才停止接收输入(C语言中判断是否键入回车键: if(presskey == '\r') printf("yes"); )
再如scanf()也是带回显的。要实现输入一个字符回显一个星号的结果,我们在这里采用kbhit()函数和getch()函数来做,先对这两个函数做个介绍:
kbhit()
函数名称: kbhit() (vc++6.0下为 _kbhit())
函数功能:检查当前是否有键盘输入,若有则返回一个非0值,否则返回0.
用法:int kbhit(void)
包含头文件:include<conio.h>
返回值说明: 当kbhit()函数检测到有键盘输入时,它会返回一个非0值,注意这个返回的非零值,并不是对应键位所对应的ASCII码值,所以这个值除了通过它为非零判断有键盘输入以外,不能用来做其它用途。实际上,只要有键盘输入它都返回一个固定的非零值。
getch()
函数名称:getch()
函数功能:在win平台下从控制台无回显地取一个字符,在Linux下是有回显的。
包含头文件:win平台下是 conio.h linux平台下 curses.h
用法:
int getch(void);
在linux下(需包含curses.h)还应该在使用函数之前使用initscr(),使用完毕之后调用endwin().否则的话不输入就会返回。
返回值:从键盘上读取到的字符。
Win Example:
#include <stdio.h>
#include <conio.h>
int main(void)
{
char ch;
printf("Input a character:");
ch = getch();
printf("\nYou input a '%c'\n",ch);
return 0;
}
.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }Linux Example:
#include <stdio.h>
#include <curses.h>
int main(void)
{
char ch;
initscr();
printw("Input a character:");
ch = getch();
printw("\nYou input a '%C'\n",ch);
endwin();
return (0);
}
char *getLine(char *buf,int len)
{
int i = 0;
char ch;
fflush(stdin);
while(i<len-1)
{
if(0 != kbhit()){//检测到有键盘输入
ch = getch();//读取键盘输入赋值给ch
//c中 \r 才是代表 回车符
if(ch == '\r') break; //如果是回车键则退出while循环结束密码输入
putchar('*');
buf[i] = ch;//存入接收密码的字符数组中
++i;
}
}
buf[i] = '\0';
return buf;
}
注:
C打印数组地址和字符数组的值 使用%s 会报内存访问错误!例如
char pwd[MAX_PWD] = {0};
//打印地址
int i = 0;
for(i = 0; i < MAX_PWD;i++)
{
//下面两句用 %s 打印的语句将报内存访问错误:OxC00000005 访问越界
printf("value: %s\n",pwd[i]);
printf("address: %s\n",&pwd[i]);
//换成用 %d 打印则可以正常打印出来,其中value显示为对应字符的ASCII码值,address 显示为16进制地址值
printf("value: %d\n",pwd[i]);
printf("address: %d\n",&pwd[i]);
//也可以通过%c 来打印value值, 这样它就直接显示存储的字符
printf("value : %c\n",pwd[i]);
}
此外注意在C语言中i变量的声明不能放在for循环中,如下声明则会报找不到变量j,
for(int j = 0; j<MAX_PWD;j++)
改成如下即可:
int j = 0;
for(j = 0; j<MAX_PWD;j++)
C控制台密码输入:输入一个字符显示一个星号的更多相关文章
- wordpress登录密码框明文显示最后一个输入的字符
wordpress登录密码框明文显示最后一个输入的字符 (function(a){a.fn.dPassword=function(c){var e={interval:200,duration:100 ...
- 创建一个欢迎 cookie 利用用户在提示框中输入的数据创建一个 JavaScript Cookie,当该用户再次访问该页面时,根据 cookie 中的信息发出欢迎信息。
创建一个欢迎 cookie 利用用户在提示框中输入的数据创建一个 JavaScript Cookie,当该用户再次访问该页面时,根据 cookie 中的信息发出欢迎信息. <html> & ...
- [SQL]当输入表达式得数为一个有效的整数、浮点数、money 或 decimal 类型,那么 ISNUMERIC 返回 1;否则返回 0
ISNUMERIC ( expression ) 当输入表达式得数为一个有效的整数.浮点数.money 或 :否则返回 .返回值为 确保可以将 expression 转换为上述数字类型中的一种. 注意 ...
- 华为oj-判断输入的字符串是不是一个有效的IP地址
题目标题: 判断输入的字符串是不是一个有效的IP地址 详细描述: 请实现如下接口 boolisIPAddressValid(constchar* pszIPAddr) 输入:pszIPAddr 字符串 ...
- spring boot 实现密码连续输入错误5次,限制十分钟内不能进行登录
我们要实现的就是,密码连续输入错误5次,就限制用户十分钟不能进行登录. 大致的流程图 数据库设计如下 DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ...
- java 中的控制台端口的输入
java 中基于控制台端的输入时最基本的操作. 第一步 导入Scanner类 import java.util.Scanner; 第二步 创建输入对象 input Scanner input=new ...
- nginx配置访问密码,输入用户名和密码才能访问
1. 安装 htpasswd 工具 yum install httpd-tools -y 设置用户名和密码,并把用户名.密码保存到指定文件中: [sandu@bogon conf]$ sudo mkd ...
- easyui-validatebox 验证两次密码是否输入一致
验证两次密码是否输入一致 $.extend($.fn.validatebox.defaults.rules, { /*必须和某个字段相等*/ equalTo: { vali ...
- Linux就这个范儿 第12章 一个网络一个世界
Linux就这个范儿 第12章 一个网络一个世界 与Linux有缘相识还得从一项开发任务说起.十八年前,我在Nucleus OS上开发无线网桥AP,需要加入STP生成树协议(SpanningTree ...
随机推荐
- python_random模块
random模块 import random print(random.random()) # 大于0且小于1之间的小数 print(random.randint(1, 6)) # 大于等于1且小于等 ...
- 洛谷 P3387 【模板】缩点 DAGdp学习记
我们以洛谷P3387 [模板]缩点 来学习DAGdp 1.这道题的流程 //伪代码 for i->n if(i未被遍历) tarjan(i) 缩点() DAGdp() 完成 首先tarjan这部 ...
- luogu2261 [CQOI2007]余数求和
除法分块. 猜想: 记 \(g(x)=\lfloor k / \lfloor k / x\rfloor \rfloor\),则对于 \(i \in [x,g(x)]\),\(\lfloor k / i ...
- 『NYIST』第八届河南省ACM竞赛训练赛[正式赛一]-CodeForces 237C,素数打表,二分查找
C. Primes on Interval time limit per test 1 second memory limit per test 256 megabytes input standar ...
- PTA 04-树6 Complete Binary Search Tree (30分)
题目地址 https://pta.patest.cn/pta/test/16/exam/4/question/669 5-7 Complete Binary Search Tree (30分) A ...
- nginx1.6.3
Nginx1.6.3安装配置 安装时关闭防火墙和selinuxservice iptables stopsed -i "s/selinux=enabled/selinux=disable/g ...
- hdu 1528 二分匹配
#include<stdio.h> #include<string.h> int map[100][100],mark[100],link[100],max2,k; int f ...
- [NOIP2001] 普及组
装箱问题 裸01背包,速刷过 #include<cstdio> #include<iostream> #include<cmath> using namespace ...
- php中memcache与memcached的区别 【收藏】
说法一: 两个不同版本的php的memcached的客户端 new memcache是pecl扩展库版本new memcached是libmemcached版本功能差不多 说法二: Mem ...
- PHP 常见问题3
1,Http 和 Https 的区别 第一:http 是超文本传输协议,信息是明文传输,https 是具有安全性的 ssl 加密传输协议 第二:http 和 https 使用的是完全不同的连接方式,端 ...