首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    牛客网刷题记 | 零散知识点汇总——Java(ing)

    A.vector是线程安全的ArrayList,在内存中占用连续的空间。 初始时有一个初始大小, 当数据条数大于这个初始大小后会重写分配一个更大的连续空间。 如果Vector定义为保存Object则可以存放任意类型, 无需事先知道!!! B.选项说的情况就是我们自定义异常的情况, 我们可以用违例(Exception)来抛出一些并非错误的消息, 可以,并非错误的消息。 比如我自定义一个异常,若一个变量大于10就抛出一个异常, 这样就对应了B选项说的情况, 我用抛出异常说明这个变量大于10, 而不是用一个函数体(函数体内判断是否大于10,然后返回true或false)判断, 因为函数调用是入栈出栈, 栈是在寄存器之下的速度最快,且占的空间少, 而自定义异常是存在堆中,肯定异常的内存开销大! C选项是错误的,因为接口中不能声明变量,只有常量! 接口中只有常量定义,没有变量声明。 接口中方法默认是abstract public, 所以在接口只写函数声明是符合语法规则。 但是变量默认是用public final static 修饰的, 意思它是静态常量,不是变量! 另外, 常量不管在接口中还是类中必须在声明时初始化。 D.子类可以访问父类受保护的成员 访问修饰符 访问范围 继承性 private 本类内部 不可继承 私有的 (default) 本类+同包 同包子类可以继承 默认的 protected 本类+同包+子类 可以继承 受保护的 public 公开 可以继承 公开的

    03

    Java标识符与关键字

    1.Java注释 ☞编码加上注释!!!!  ● 单行注释:// 注释内容 (最常用)  ● 多行注释:/* 注释内容 / (不推荐)  ● 文档注释:/* 文档注释 */ (常见于方法和类之上描述方法和类的作用),可自动生成文档 2.Java标识符 Java中,对于变量、常量、函数、语句块都有名字,统称为Java标识符。 ◆对标识符的三点要求:  ●标识符由字母、数字、_(下划线)、$组成,不能以数字开头,不能用Java中的关键字  ●标识符采用有意义的简单命名  ●“$”不要在代码中出现 ◆驼峰命名法: 大驼峰:定义类、接口时使用   单词以大写字母开头,若有多个单词,每个单词首字母大写      public class FirstClass 小驼峰:定义变量、函数时使用   若标识符只有一个单词,全小写;若标识符由多个单词组成,从第二个单词开始首字母大写     int mathScore = 10 常量:所有单词全部大写,多个单词间以 - 分隔 3.关键字 注意:  ●Java中有两个未使用的保留字:goto、const  ●Java中有三个特殊含义的单词:null、ture、false  ●JDK1.4后追加了 assert关键字;JDK1.5以后追加了enum关键字  4.数据类型划分 注意:对数据类型的选择  ●在程序开发之中,整数就用int,描述小数用double。  ●long一般用于描述日期、时间、内存或文件大小(字节)  ●如果要进行编码转换或者进行二进制流的操作,使用byte(-127~128)  ●char一般在描述中文中会用到(基本忽略)   4.1 基本数据类型(八大基本类型) 4.1.1 数值型 整型:默认值0 byte(-128~127)<short < int(-231~231) < long 在Java中,任何一个整型常量都是int类型 当数据类型达到最大值时,换一个保存范围更大的类型来解决数据溢出问题 Java中声明long常量,需要在数字后加 l 或 L 在进行数学计算时,小的数据类型自动转为大的数据类型,大的数据类型变为小的数据类型必须强制类型转换,可能会溢出。(最高位取反) byte(-128~127)与int类型: 当整型常量在byte保存范围中,可以直接赋值给byte变量;常量大小超出byte范围,int变量赋值给byte变量,所有赋值必须强转。

    02

    深入解析CUDA内存溢出: OutOfMemoryError: CUDA out of memory. Tried to allocate 3.21 GiB (GPU 0; 8.00 GiB tota

    在深度学习项目中,CUDA内存溢出(OutOfMemoryError)是一个常见的难题,尤其在使用PyTorch框架进行大规模数据处理时。本文详细讨论了CUDA内存溢出的原因、解决方案,并提供了实用的代码示例。我们将围绕OutOfMemoryError: CUDA out of memory错误进行深入分析,探讨内存管理、优化技巧,以及如何有效利用PYTORCH_CUDA_ALLOC_CONF环境变量来避免内存碎片化。本文内容丰富,结构清晰,旨在帮助广大AI开发者,无论是深度学习的初学者还是资深研究者,有效解决CUDA内存溢出问题。关键词包括CUDA内存溢出、PyTorch、内存管理、内存碎片化、深度学习优化等,确保容易被搜索引擎检索到。

    01

    java JVM内存模型解析

    程序计数器就是记录当前线程执行程序的位置,改变计数器的值来确定执行的下一条指令,比如循环、分支、方法跳转、异常处理,线程恢复都是依赖程序计数器来完成。     Java虚拟机多线程是通过线程轮流切换并分配处理器执行时间的方式实现的。为了线程切换能恢复到正确的位置,每条线程都需要一个独立的程序计数器,所以它是线程私有的。     如果线程正在执行的是一个Java方法,这个计数器记录的是正在执行的虚拟机字节码指令的地址;如果正在执行的是Native方法,这个计数器值则为空(Undefined)。此内存区域是唯一一个在Java虚拟机规范中没有规定任何OutOfMemoryError情况的区域。

    04
    领券