「java对象指针怎么设置」java 函数指针调用
今天给各位分享java对象指针怎么设置的知识,其中也会对java 函数指针调用进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
JAVA 子类对象赋给父类指针
在java中一般不称指针。对于你这个问题,我的理解是这样的:
在面向对象编程中,有个基本原则,就是要面向接口编程,不要面向实现编程。
InputStream in = new FileInputStream(value); // 面向接口
FileInputStream in = new FileInputStream(value); // 面向实现
面向接口编程的好处是,在有新需求时,只需要变换相应的实现类就可以了,就比如上面那句,如果你不想使用FileInputStream了,而是想使用其他的如ByteArrayInputStream、BufferedInputStream了,其他地方的调用不需要改变,改变这里就可以李。而如果你面向的是实现编程,那么在遇到类似的改动时,就非常的被动,改动面比较大。这也是常说的扩展性。
另外,这里还带出了一个面向对象原则,叫 里氏代换,即在可以使用父类的时候,子类都可以使用,也就在使用InputStream时,都可以使用FileInputStream了~
java中指针怎么理解?
实际上,java力图使程序员忘记指针,这包括2个方面:
第一,java限制指针,去除了指针运算。
第二,java从语法上努力隐藏指针,让指向某对象的指针看起来更像那个对象本身!
是的,所有的java书籍都让人忘记了指针这回事,我们仿佛只跟对象打交道。偶尔,会被迫分清引用和
对象的关系。这就是目前的情形。多么好的想法!对象可比那些个不知所以的指针亲和多了!这是一种伟大的抽象!
这里,我们也更愿意把引用和对象混淆。是的,为什么不呢?那样,整个世界都是对象,太好理解了!
可事实上,为了节省内存,java不能把引用(指针)完全废除。要知道,复制一个引用(指针)要比
复制整个对象有效得多!所以我们不得不面对引用和对象共存的事实。
下面我就好好分析分析:
指针已经被抽象成了引用,现在指针不能够随心所欲的运算,并且看起来就像个对象,完全没有了指针
的模样。但它毕竟和对象还是不同的,还要经过一层“转换”(从指向的那个对象里取数据)。如果我们
在引用满天飞的时候总想着这样一层转换,真的是很不舒服。比如:
String key="name";
String value="hyq";
HashMap map=new HashMap();
map.put(key,value);
你得想着:key只是个引用,value也是个引用,map还是个引用,我们刚刚做的是把key和value
这2个引用放进了map(也是个HashMap对象的引用)中,到时候我就可以通过map这个引用取得
里面的对应于key引用的value引用!
你不晕我就服了。
一旦你这样想,你每时每刻都要面对这样的绕口令。因为我们对对象的操作全部要通过引用!java没有提供语法让你直接得到对象!(指的是直接寻址)这一点通过比较原始类型很好理解,int i=8,那么
i就是8,不是什么指针,要先找到放着8那块内存的地址再把8拿出来。这样多直接,多方便啊!
所以,我们对引用最好也这么来理解,就轻松多了。
还是上面的例子,key就是个String,value也是个String,map是个HashMap,我们把key和value
放进map里,将来可以按key取出value。——多简单!
其实,这样的理解是很符合人的思维习惯的,我相信大多数人刚学java时都会自然而然的这么理解,
但是我们一定要注意在什么时候不能这么理解。只要记住什么时候不能这么理解,我们就不会因为
这种“近似”的理解方式而犯错,而同时从这种理解方式里得到了方便和好处。
把引用直接当作对象本身的好处是简单直接,容易理解,而“误差”的地方就在于,假设只有这个引用
可以修改此对象。换句话说,当别的引用修改了对象的时候,我们毫不知情并很感费解。比如:
String name=null;
HashMap map=new HashMap();
map.put("name",name);
//do a lot of things
name="hyq";
当我们再从map里取出name的时候,发现它已经被赋值为hyq了!放进去的时候明明是啥都没有啊!
咋就变了讷?
引用到name那个对象的不只你map一个阿!
在同一个函数里出现这种情况还不是很常见,我们一般也不必这么写,更多的是出现在函数调用、传参的时候,这样更加隐蔽,不易发现,也让代码可读性下降。比如:
String name=null;
HashMap map=new HashMap();
map.put("name",name);
alterName(name);
在alterName函数里我们修改了name对象,这会直接影响到函数外的map。
所以,当我们把引用和对象故意混淆时,一定要记住什么时候应该分清楚。
对象的使用不外乎以下几种情况:
1
String name=new String("hyq");
然后使用name,引用生命周期一结束,对象失效(无法被取用)了事。这里只有name一个引用指向此对象,随便怎么弄都不会出事。
2
String name=new String("hyq");
String anotherName=name;
这里假设只有name会修改对象,并且在anotherName引用此对象前做完所有修改,anotherName只是取用这个对象调用方法。在这种情况下,也不会出事。这也是我们经常遇到的情况,并且一般都是在函数调用传参时出现。注意传参实际上就是String anotherName=name;
这里尤其要注意的是2个引用的生命周期:name修改对象的时候另一个引用还没出世,而等它出世后
发现它又不会修改对象,怎一个爽字了得!
3
String name=new String("hyq");
String anotherName=name;
代码和上面一样,但是这里要么2个引用都会修改对象,要么只有一个修改但会影响到另一个。这个时候无论如何你不能再把引用当对象了,你必须分清楚它们。你必须小心仔细,不能有丝毫疏忽。
当然,这种写法和风格无论如何是不值得提倡的,若非必要(没办法)请勿模仿!因为必然有一个引用
在不知情的情况下被人修改了对象,等它用的时候会大吃一惊,而这个对象是在什么时候被什么人修改的,极难排查。
(上面例子举得不好,String类是不变类,汗!)
StringBuffer name=new StringBuffer("hyq");
StringBuffer anotherName=name;
//do a lot of things
anotherName.append("is my gf");
你可能写得爽,一时痛快就这么写了,你也知道是什么人在什么时候修改了对象,但是别人呢?
要知道,这里可能不是相隔几行代码这么简单,可能是嵌套了好几层函数调用!你把那个anotherName传到第5层函数里面,然后丧心病狂的修改了那个对象,除了天知地知你知,鬼
都看不出来!
java指针怎么定义
java程序中会出现空指针的错误,那是因为对象为空,然后从中取值就会报空指针错误。 这就是空指针错误
java 中指针是怎么定义的?
Java语言的一个优点就是取消了指针的概念,但也导致了许多程序员在编程中常常忽略了对象与引用的区别,本文会试图澄清这一概念。并且由于Java不能通过简单的赋值来解决对象复制的问题,在开发过程中,也常常要要应用clone()方法来复制对象。本文会让你了解什么是影子clone与深度clone,认识它们的区别、优点及缺点。
看到这个标题,是不是有点困惑:Java语言明确说明取消了指针,因为指针往往是在带来方便的同时也是导致代码不安全的根源,同时也会使程序的变得非常复杂难以理解,滥用指针写成的代码不亚于使用早已臭名昭著的GOTO语句。Java放弃指针的概念绝对是极其明智的。但这只是在Java语言中没有明确的指针定义,实质上每一个new语句返回的都是一个指针的引用,只不过在大多时候Java中不用关心如何操作这个指针,更不用象在操作C++的指针那样胆战心惊。唯一要多多关心的是在给函数传递对象的时候。如下例程:
package reference;
c2.strBuff.append( change strBuff clone);
改成下面这样:
c2.str.substring(0,5);
c2.strBuff.append( change strBuff clone);
去掉了重新赋值的过程,c2.str也就不能有变化了,我们的把戏也就露馅了。但在编程过程中只调用
c2.str.substring(0,5);
语句是没有任何意义的。
应该知道的是在Java中所有的基本数据类型都有一个相对应的类,象Integer类对应int类型,Double类对应double类型等等,这些类也与String类相同,都是不可以改变的类。也就是说,这些的类中的所有方法都是不能改变其自身的值的。这也让我们在编clone类的时候有了一个更多的选择。同时我们也可以把自己的类编成不可更改的类。
java中如何定义指针变量
java对指针进行了封装,虽然存在指针,但是不允许程序员对指针进行定义或操作
Java对象怎么调用
java对象中,除了基本类型,其他对象传递都是地址传递,虽然java取消了指针的设定,但是其内部还是使用指针操作的,定义一个对象就相当于定义了一个对象类型的指针,这个指针的值为null,如果不进行初始化的话自然会报空指针异常,也就是NullPointerException。即使是基本类型,如果不初始化直接调用的话一样会报异常的。
上面的main方法中,map对象只是被创建并没有初始化,只是在前面创建了一个Map类的指针但并没有告诉系统具体指向,也就是map的值为null。
如以下方式:
static Map map;
public static void main(String[] args)
{
map=new Map();
map.seach();
}
程序就可以正常运行。
这两种创建对象的方法都是可以的。第一种在方法外创建就是作为一个类的属性,这个时候这个对象的生存周期是相当长的,你可以在一个方法中初始化后在其他方法中继续调用,其他方法对其造成的修改会都会影响到下一次调用的结果。甚至可以在其他类中调用这个变量。当然如果调用到的是没有初始化的对象一样会报空指针。
后一种方式是在方法中创建对象进行操作,这时候这个对象的生存周期只限制于这个方法。每次调用这个方法的时候都会重新创建一个这样的对象。想将这个对象拿出去只有在创建后用set方法或者是使用return 返回。
例如:
Map map=new Map();
map.seach();
//假设OtherObj对象有setMap方法,使用set方法取出map对象
OtherObj.setMap(map);
或者就写成:
public Map getMap(){
Map map = new Map();
return map;
}
此外,static标记表示这个对象是类共有的,调用的时候甚至不需要创建你这个类的对象直接通过类名就可以调用出来。例如jdk中的java.awt.Color类里面可以直接取出一些特定的颜色,只需要调用Color.RED等方法即可。不需要另外创建Color对象
关于java对象指针怎么设置和java 函数指针调用的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
发布于:2022-12-28,除非注明,否则均为
原创文章,转载请注明出处。