数字还可以这样表示?100_000 == 100000?

本文介绍Java及JavaScript中使用下划线增强数字可读性的特性,包括其合法性和限制条件。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    今天偶然的看到一个代码,表示int类型,竟然用到了这样的表示方式:

    

    我一开始还有些懵逼,下划线还能用在数字表示中?

    今天又在浏览器开发者模式下试了一下:

    

    看来,java和javascript似乎对于下划线连接数字,都表示默许了。好在这种表示方法并不具有可推导性,就是说100_000能够表示100000,但是字符串形式的100_000并不能直接转为100000。否则,我们曾经判断数字的正则表达式可能统统要失效,各种场景下的数字校验需要重新设计。

    下划线表示数字,好像是jdk1.7以后引入到java中的,它也遵循一定的规则,并不是任意位置的下划线都是合法的,比如下面的表示都是非法的:

    

    数字开头和结尾是不能使用下划线的,一些特殊的表示,比如double,long,float会在结尾使用d,l,f在这类表示前面也是无法使用下滑线的,还有一类,小数点前后也是无法使用下划线的。

    如下的下划线表示数字都是正确的:

    

    数字表示使用下划线隔开,可读性增加了,但是却容易引起误解,个人感觉还是慎用,但是有的人说提倡大家使用。

def format_amount(amount): """格式化金额为带有千位分隔符和两位小数的字符串""" return "{:,.2f}".format(amount) def calculate_simple_interest(principal, annual_rate, years): """ 单利计算函数 :param principal: 本金(元) :param annual_rate: 年利率 :param years: 存款年限 :return: 每期数据列表 """ results = [] total_interest = 0 for year in range(1, years + 1): interest = principal * annual_rate # 每年利息相同 total_interest += interest total = principal + total_interest results.append({ "期数": year, "本金": principal, "利息": interest, "总额": total }) return results def calculate_compound_interest(principal, annual_rate, years, periods_per_year): """ 复利计算函数 :param periods_per_year: 每年计息次数(1=年,4=季,12=月) """ results = [] current_total = principal period_interest_rate = annual_rate / periods_per_year # 每期利率 for period in range(1, years * periods_per_year + 1): interest = current_total * period_interest_rate new_total = current_total + interest results.append({ "期数": period, "本金": current_total, "利息": interest, "总额": new_total }) current_total = new_total # 更新本金为最新总额 return results def print_interest_table(data, title, period_type="年"): """打印利息结果表格""" print(f"\n{title}") print("-" * 75) # 统一表头格式 print(f"{'期数':<8}{'本金(元)':<20}{'利息(元)':<20}{'总额(元)':<20}") for entry in data: # 根据周期类型显示不同的期数标签 if "复利" in title: period_label = f"第{entry['期数']}期" else: period_label = f"第{entry['期数']}年" print(f"{period_label:<8}" f"{format_amount(entry['本金']):<20}" f"{format_amount(entry['利息']):<20}" f"{format_amount(entry['总额']):<20}") def main(): try: # 输入处理(万元转元,百分比转小数) principal = float(input("请输入本金(万元): ")) * 10000 annual_rate =
03-31
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luffy5459

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值