各位老铁们好,相信很多人对java空指针引用都不是特别的了解,因此呢,今天就来为大家分享下关于java空指针引用以及long类型空指针解决办法的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!
本文目录
单片机指针类型
单片机C语言变量分别有char型,int型,long型,float型等,它们分别占用内存为1个单元,2单元,4单元,4单元等,另外数组和字符串则占用了内存某段连续的单元。这些变量的共同特征是它们都装的数值。那如果一个变量里面装的不是数值,而是地址,这个变量则称为指针变量。所以指针变量用于存储器的地址号。
GG指针是什么
GG指针是C语言的一个概念,也是C语言中比较困难的部分。
GG指针也就是内存地址,指针变量是用来存放内存地址的变量,可对存储数据的变量地址进行操作。
不同类型的指针变量所占用的存储单元长度是相同的。
在32位游戏中,指针地址的存储是longint类型(4字节);
在64位游戏中,指针地址的存储是longlong类型(8字节)。
java空指针引用
空指针异常空指针异常产生的主要原因如下:(1)当一个对象不存在时又调用其方法会产生异常obj.method()//obj对象不存在(2)当访问或修改一个对象不存在的字段时会产生异常obj.method()//method方法不存在具体情况如下:空指针错误(Java.lang.NullPointerException)使用基本的Java数据类型,变量的值要么已经是默认值,如果没有对其正常赋值,程序便不能通过编译,因此使用基本的Java数据类型(double,float,boolean,char,int,long)一般不会引起空指针异常。由此可见,空指针异常主要跟与对象的操作相关。下面先列出了可能发生空指针异常的几种情况及相应解决方案:情况一:不管对象是否为空就直接开始使用。(JSP)代码段1:out.println(request.getParameter("username"));描述:代码段1的功能十分简单,就是输出用户输入的表域"username"的值。说明:看上去,上面的语句找不出什么语法错误,而且在大多数情况下也遇不到什么问题。但是,如果某个用户在输入数据时并没有提供表单域"username"的值,或通过某种途径绕过表单直接输入时,此时request.getParameter("username")的值为空(不是空字符串,是空对象null。),out对象的println方法是无法直接对空对象操作,因此代码段1所在的JSP页面将会抛出"Java.lang.NullPointerException"异常。情况二:即使对象可能为空时,也调用Java.lang.Object或Object对象本身的一些方法如toString(),equals(Objectobj)等操作。(JSP)代码段2:StringuserName=request.getParameter("username");If(userName.equals("root")){....}描述:代码段2的功能是检测用户提供的用户名,如果是用户名称为"root"的用户时,就执行一些特别的操作。说明:在代码段2中,如果有用户没有提供表单域"username"的值时,字符串对象userName为null值,不能够将一个null的对象与另一个对象直接比较,同样,代码段2所在的JSP页面就会抛出(Java.lang.NullPointerException)空指针错误。(JSP)代码段3:StringuserName=session.getAttribute("session.username").toString();描述:代码段3的功能是将session中session.username的值取出,并将该值赋给字符串对象userName。说明:在一般情况下,如果在用户已经进行某个会话,则不会出现什么问题;但是,如果此时应用服务器重新启动,而用户还没有重新登录,(也可能是用户关闭浏览器,但是仍打开原来的页面。)那么,此时该session的值就会失效,同时导致session中的session.username的值为空。对一个为null的对象的直接执行toString()操作,就会导致系统抛出(Java.lang.NullPointerException)空指针异常。解决方案:为了确保进行操作或引用的对象非空,假若我们要对某对象进行操作或引用,我们首先去检查该对象是否已经实例化且不为空;并且在系统中加入针对对象为空时情况的处理。如:采用String对象保存用户提交的结果;在如果涉及对象的操作时,先检测其是否为空后,检查到对象为空后,可再选择进行以下任一种处理方式:处理方式1)检查到对象为空时,设置对象值为空字符串或一个默认值;处理方式2)检测到对象为空时,根本不执行某操作,直接跳转到其他处理中。处理方式3)检查到对象为空时,提示用户操作有错误。将代码段2按以上方式进行改写,得到:方式1:StringuserName=request.getParameter("username");//该变量值为空时,转化为默认空字符串If(userName==null)userName="";If(userName.equals("root")){..........}方式2:StringuserName=request.getParameter("username");//该变量值为空时,转化为默认空字符串,不执行有关操作。If(usreName!=null){If(userName.equals("root")){..........}}方式3:StringuserName=request.getParameter("username");//该变量值为空时,转化为默认空字符串,不执行有关操作。If(usreName==null){//提示用户输入信息为空}实际中,上面提供到三种处理方式也同样适用于其他异常的处理:异常处理方式1)检查到异常出现,设置对象值为空字符串或一个默认值;异常处理方式2)检测到异常出现,根本不执行某操作,直接跳转到其他处理中。异常处理方式3)检查到异常出现,提示用户操作有错误。
c51特有的数据类型有哪些
类型如下:
1、char:字符型;
2、short=shortint:短整型
3、int:整型
4、long=longint:长整型
5、float:单精度浮点型
6、double:双精度浮点型
而面向51单片机的KeiluVision4对此进行了简化,因此,可以理解为只存在如下四种基本数据类型:
1、char:字符型
2、int=short=shortint:整型
3、long=longint:长整型
4、float=double:单精度浮点型
其中,基本整型数据类型又可以通过signed关键词扩展为有符号的signedchar、signedint、signedlong类型,或通过unsigned关键词扩展为无符号的unsignedchar、unsignedint、unsignedlong类型;而对于不加关键词扩展的char、int、long本身,KeiluVision4则一律认为是signed类型。
应对51单片机硬件的一些特点,KeiluVision4还扩展了bit、sbit、sfr、sfr16等四种特殊基本数据类型,它们都是标准C中所没有的。其中:
1、bit:声明一个普通的位变量。例如:"bitflag;"。
2、sbit:声明特殊功能寄存器中的某一位。例如,使用"sbitTI=SCON^0;",就声明了TI为特殊功能寄存器SCON的第0位。
3、sfr:声明一个8位寄存器为特殊功能寄存器。例如,将51单片机内存地址0x98处的存储单元声明为8位特殊功能寄存器SCON,可以使用"sfrSCON=0x98;"语句。
4、sfr16:声明一个16位的寄存器为特殊功能寄存器。为了将51单片机内存地址0xCC处开始的连续两个存储单元声明为一个统一的16位特殊功能寄存器T2,可以使用"sfr16T2=0xCC;"语句。
需要注意的是,在KeiluVision4中,用sbit、sfr、sfr16声明特殊功能寄存器变量或特殊功能寄存器位变量时,其声明语句都只能放在函数外,而不能放在函数内,否则出现语法错误;而用bit声明普通位变量时,声明语句既可放在函数外,也可放在函数内。此外,bit、sbit、sfr、sfr16都不支持指针和数组扩展,因此,不能定义bit、sbit、sfr、sfr16型指针和数组。当然,根据C语言标准,无论是sbit、sfr、sfr16还是bit,变量必须在使用之前(至少在使用之时)声明:这一点是显然的。
对于初学者来说,其实没有必要深究sbit、sfr、sfr16的用法,它们通常用在51单片机的系统自带头文件中,一般情况下无需用户关心。
END,本文到此结束,如果可以帮助到大家,还望关注本站哦!