大家好,今天小编关注到一个比较有意思的话题,就是关于java语言运算符教学的问题,于是小编就整理了2个相关介绍Java语言运算符教学的解答,让我们一起看看吧。
java自增操作符的加1在什么时候完成?
对于变量i来说都会在原来基础上加1的,重点区别于式子本身的值;i++式子值为i原来的值,二当遇到分号之后,再执行对i+1的操作,就是通俗说的“先赋值再加1”;而++i式子值为i变化后的值,也就是“先加1后赋值”;这个赋值就是给式子赋值之意,
按照语言习惯我们一般写i++,有时在循环中写++i也是一样的效果,因为对于变量i来说都实现自增1;
比如b=i++; 就是先将i赋值给b,在遇到分号的时候,i变量自增 i++2同理
java不支持无符号整数,作为一名C程序员怎么解?
问出这个问题来说明你这个C程序员是不合格的。
你只知道C里有"unsigned"类型,却不知道这种数据的存储方式。
事实上,不论unsigned还是signed,整型数据的存储方式都是完全一样的,都是补码表示法,是不是signed无关,跟±运算也无关。
比如简单一点,一个8位整数,unsigned是0-255,signed是-128~127。两者的存储方式完全相同,±运算也完全相同。区别是你看数据时的理解方式,比如8位全1,unsigned 理解为255(再+1变成0),而signed理解为-1(再+1也是0)。这就是补码表示法的精髓,有无符号无差别,甚至加减法也几乎无差别:补码表示下,减法就是取反+1。你可以在C或java代码里验证:a-b,和a+(~b)+1,二者是一样的。
回到题主的问题,当然先要明确程序员需要unsigned类型的原因和用途,不过据我的经验,通常都只是用来计数,也只涉及到加减法和比较(比大小就是减法)。一般来说,直接改成signed就好,加减法照常使用,唯一的,在做比较时,需要稍稍处理一下,比如:
两个整数a,b用int存储(实际是unsigned,可能超2³¹,此时int会理解为负数),两者比大小不要直接if(a<b),要改成:
int c=a-b;
if(c<0)
…
Java的主要设计目标之一是使代码在语言层面尽量减少隐患,规避业界已知的常见问题。体现在具体设计上,题主提到了两个例子。
第一个,Java的数据类型中没有无符号整数类型,是为了规避无符号整数类型带来的隐患。即便是C语言,长者常常告诫新学者,尽量别用无符号整数。经过几十年的实用经验,公认的看法是无符号整数类型弊大于利。所以,Java弃之不用。
第二,Java语言中不见指针。Java设计师决定将指针“隐藏”起来,不给编程者直接使用。取而代之是用建立了抽象层来间接使用“指针”。Java的动机是通过“消灭”指针来规避相当数量的常见程序错误和隐患。
既然用Java,那就用Java来思维,不能看着碗里,想着锅里。C语言纵有千般好,可你在用Java了,千万别试图去写C味的Java代码。
喜欢就点赞。 更多精彩,请关注我
今日头条号/西瓜视频/抖音:IT之州
理解了面向对象,就解了这个问题。你为什么需要一个无符号整数。记录年龄?那应该是个Age对象。计数器?那应该是个Counter对象。。C的无符号整型更多是在内存受限(C诞生的年代背景,以及在嵌入式开发的广泛使用)情况下提供更精细的空间控制。但对于Java来说这些就没有那么强烈。业务场景不能接受负值应该用封装来解决,数据范围不够换成long就好了。
到此,以上就是小编对于java语言运算符教学的问题就介绍到这了,希望介绍关于java语言运算符教学的2点解答对大家有用。