zoukankan      html  css  js  c++  java
  • Java编程思想学习(一) 一切都是对象

    前言

    Java是基于C++的,但Java是一种更加纯粹的面向对象程序设计语言。

    C++和Java都是混合/杂合型语言。杂合型语言允许多种编程风格。

    用引用操纵对象

    每种编程语言都有自己操纵内存中元素的方式。

    • 直接操纵元素
    • 用某种基于特殊语法的间接表示(C和C++里的指针)
    • 用引用操纵对象(Java)

    在Java中,一切都被视为对象。操纵的标识符实际上是对象的一个引用

    • 类比为遥控器(引用)来操纵电视机(对象)
    • 只要把握这个遥控器,就能保持与电视机的连接
    • 改变频道或减小音量,实际操纵的是遥控器(引用),再由遥控器来调控电视机(对象)
    • 在房间四处走走,只要携带遥控器(引用)而不是电视机(对象)就能调控电视机
    • 即使没有电视机,遥控器也可以独立存在
    1      //创建的只是引用而不是对象
    2         String s1;
    3         //创建一个引用的同时便进行初始化
    4         //Java语言的特性:字符串可以用带引号的文本初始化
    5         String s2 = "abcd";
    6         //更通用的初始化方法
    7         //创建一个引用,并与一个新的对象相关联
    8         String s3 = new String("abcd");

    必须由我们创建所有对象

    存储到什么地方

    程序运行时,对象的放置安排,内存的分配都是我们必须了解的。
    有五个不同的地方可以存储数据:
    1.寄存器
    2.堆栈
    3.
    4.常量存储
    5.非RAM存储

    寄存器:位于数量极其有限的寄存器,是最快的存储区,寄存器会根据需求进行分配,不能直接控制,也不能在程序中感觉到寄存器存在的任何迹象

    堆栈:位于通用RAM(随机访问存储器)中,通过堆栈指针可以从处理器那里获得直接支持,堆栈指针向下移动,则分配新的内存,向上移动,则释放那些内存(这是一种快速有效的分配存储方法,仅次于寄存器)创建程序时,Java系统必须知道存储在堆栈内所有项的确切生命周期,以便上下移动堆栈指针。--->限制了程序的灵活性,所以某些Java数据(如对象引用)存储在堆栈中,但是Java对象并不存储在堆栈中

    :通用的内存池(位于RAM区)。用于存储所有java对象。编译器不需要知道存储的数据在堆中存活多长时间(灵活性,但分配和清理的时间较长)。

    常量存储:存放在程序代码内部。

    非RAM存储:数据完全存活于程序之外,不受程序的任何控制,在程序没有运行时也可以存在。如流对象持久化对象

    特例:基本类型

    new一个对象存储在堆里,因此用new创建一个对象——特别是小的,简单的变量往往不是很有效的。
    对于这些类型,Java采取不用new来创建变量,而是创建一个并非是引用的自动变量(直接存储值,并且存储在堆栈中)。

    Java语言对于每种基本类型所占存储空间大小是固定的,不像其他语言随机器硬件架构的变化而变化。(可移植性更高)

     1        /**
     2          * 基本类型创建的不是引用,而是一个自动变量,直接存储值,并且存储在堆栈中。
     3          * 基本类型都有相对应的包装器类,能在堆中创建一个非基本对象,用来表示相对应的基本类型。
     4          */
     5         //基本类型
     6         int i = 5;
     7         //包装类型
     8         Integer integer = new Integer(i);
     9         //Java SE5自动包装
    10         Integer integer1 = 4;
    11         //反向转换
    12         int i1 = integer1;

    转载:http://www.cnblogs.com/JohnTsai/p/4606365.html

     
  • 相关阅读:
    Restful API设计规范
    git merge 和 git merge --no-ff
    [Machine Learning & Algorithm] 朴素贝叶斯算法(Naive Bayes)
    TF-IDF与余弦相似性的应用(三):自动摘要
    TF-IDF与余弦相似性的应用(二):找出相似文章
    TF-IDF与余弦相似性的应用(一):自动提取关键词
    LeetCode 442. Find All Duplicates in an Array
    LeetCode 29. Divide Two Integers
    LeetCode 402. Remove K Digits
    LeetCode 406. Queue Reconstruction by Height
  • 原文地址:https://www.cnblogs.com/benchao/p/5262833.html
Copyright © 2011-2022 走看看