Java 的两大数据类型:内置数据类型、引用数据类型
Java语言提供了八种基本类型。六种数字类型(四个整数型,两个浮点型),一种字符类型,还有一种布尔型。
byte、short、int、long、float、double、char、boolean
| 基本类型 | 范围 |
|---|---|
| byte: | (8位)-128~127 |
| short: | (26位)一个short变量是int型变量所占空间的二分之一 |
| int: | (32位)-2^31 ~ 2^31 - 1 |
| long: | (64位)、默认值是 0L |
| float: | (32位)、默认值是 0.0f |
| double: | (64 位)、默认值是 0.0d |
| boolean: | 默认值是 false |
| char: | (16 位)、【\u0000(十进制等效值为 0)~\uffff(即为 65535)】 |
在实际开发过程中,我们经常会遇到需要使用对象,而不是内置数据类型的情形。为了解决这个问题,Java 语言为每一个内置数据类型提供了对应的包装类
| 包装类 | 基本数据类型 |
|---|---|
| Byte | byte |
| Short | short |
| Integer | int |
| Long | long |
| Float | float |
| Double | double |
| Character | char |
| Boolean | boolean |
会自动装箱和拆箱:
Character ch = new Character('a');
//可以不用创建对象;会自动装箱
Character ch = 'a';// 原始字符 'a' 装箱到 Character 对象 ch 中
// 原始字符 'x' 用 test 方法装箱
char c = test('x');// 返回拆箱的值到 'c'

常用方法:
| 方法 | 描述 |
|---|---|
| isLetter() | 是否是一个字母 |
| isDigit() | 是否是一个数字字符 |
| isUpperCase() | 是否是大写字母 |
| isLowerCase() | 是否是小写字母 |
String str = "Runoob";// String 直接创建
String str2=new String("Runoob");// String 对象创建
String 创建的字符串存储在公共池中,而 new 创建的字符串对象在堆上:

| 方法 | 描述 |
|---|---|
| int length() | 返回字符串对象包含的字符数 |
| String concat(String str) | 连接字符串【更常用的是使用'+'操作符】 |
| char charAt(int index) | 返回指定索引处的 char 值 |
| boolean endsWith(String suffix) | 测试此字符串是否以指定的后缀结束 |
| boolean startsWith(String prefix) | 测试此字符串是否以指定的前缀开始 |
| boolean equalsIgnoreCase(String anotherString) | 将此 String 与另一个 String 比较,不考虑大小写。 |
| byte[] getBytes() | 使用平台的默认字符集将此 String 编码为 byte 序列,并将结果存储到一个新的 byte 数组中 |
| char[] toCharArray() | 将此字符串转换为一个新的字符数组 |
| int indexOf(String str/int ch) | 返回指定子字符串在此字符串中第一次出现处的索引 |
| int lastIndexOf(String str/int ch) | 返回指定字符在此字符串中最后一次出现处的索引 |
| String replace(char oldChar, char newChar) | 返回一个新的字符串,它是通过用 newChar 替换此字符串中出现的所有 oldChar 得到的 |
| String substring(int beginIndex, int endIndex) | 返回一个新字符串,它是此字符串的一个子字符串 |
| String toLowerCase()/toUpperCase() | 使用默认语言环境的规则将此 String 中的所有字符都转换为小/大写 |
| String trim() | 返回字符串的副本,忽略前导空白和尾部空白 |
| static String valueOf(primitive data type x) | 返回给定data type类型x参数的字符串表示形式 |
| valueOf(boolean b) | 返回 boolean 参数的字符串表示形式 |
| contains(CharSequence chars) | 判断是否包含指定的字符系列 |
| isEmpty() | 判断字符串是否为空 |
dataType[] arrayRefVar = new dataType[arraySize];
dataType[] arrayRefVar = {value0, value1, ..., valuek};
dataType[] arrayRefVar = new dataType{value0, value1, ..., valuek};//完整格式
dataType arrayRefVar[] = {value0, value1, ..., valuek};
//eg:
int[] myList = new int[8];
int[] myList = new int[]{3, 1, 2, 6, 4, 2}
int myList[] = {3,4,5,6,7,8,9,10};
java.util.Arrays 类能方便地操作数组,它提供的所有方法都是静态的。
| 说明 | 方法 | 函数 |
|---|---|---|
| 给数组赋值 | fill() | void fill(int[] a, int val) |
| 对数组排序 | sort(),按升序 | void sort(Object[] a) |
| 比较数组 | equals()比较数组中元素值是否相等 | boolean equals(long[] a, long[] a2) |
| 查找数组元素 | binarySearch()能对排序好的数组进行二分查找法操作 | int binarySearch(Object[] a, Object key) |
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我可以得到Infinity和NaNn=9.0/0#=>Infinityn.class#=>Floatm=0/0.0#=>NaNm.class#=>Float但是当我想直接访问Infinity或NaN时:Infinity#=>uninitializedconstantInfinity(NameError)NaN#=>uninitializedconstantNaN(NameError)什么是Infinity和NaN?它们是对象、关键字还是其他东西? 最佳答案 您看到打印为Infinity和NaN的只是Float类的两个特殊实例的字符串
我不确定传递给方法的对象的类型是否正确。我可能会将一个字符串传递给一个只能处理整数的函数。某种运行时保证怎么样?我看不到比以下更好的选择:defsomeFixNumMangler(input)raise"wrongtype:integerrequired"unlessinput.class==FixNumother_stuffend有更好的选择吗? 最佳答案 使用Kernel#Integer在使用之前转换输入的方法。当无法以任何合理的方式将输入转换为整数时,它将引发ArgumentError。defmy_method(number)
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
有时我需要处理键/值数据。我不喜欢使用数组,因为它们在大小上没有限制(很容易不小心添加超过2个项目,而且您最终需要稍后验证大小)。此外,0和1的索引变成了魔数(MagicNumber),并且在传达含义方面做得很差(“当我说0时,我的意思是head...”)。散列也不合适,因为可能会不小心添加额外的条目。我写了下面的类来解决这个问题:classPairattr_accessor:head,:taildefinitialize(h,t)@head,@tail=h,tendend它工作得很好并且解决了问题,但我很想知道:Ruby标准库是否已经带有这样一个类? 最佳
我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s
我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht