java试题01

1、请说出八种基本数据类型和范围,默认值
类型 范围 存储空间大小 默认值
byte -2^7 ~ +2^7 1字节(8bit ) (byte)0
char(16bit) '/u0000' ~ '/uffff' 2字节(16bit) '/u0000'(null)
short(16bit) -2^15 ~ +2^15 -1 2字节 (short)0
int(32bit) -2^15 ~ +2^15 -1 4字节 0
long(64bit) -2^15 ~ +2^15 -1 8字节 0l
float(32bit) IEEE 4字节 0.0f
double IEEE 8字节 0.0d
boolean 没有明确指定 false

2、request.getParameter()和request.getAttribute()的区别?

两者都是HTTPServletReuest类的方法,用于传递数据的。

getParameter():当web客户端向web服务端发送请求并传递参数时,服务端可用该方法获取参数,返回String类型数据。

getAttribute():它与setAttribute()方法成对,能获得request域内的共享数据,既在请求处理阶段通过setAttribute()存数据,可以通过getAttribute()取数据。

3、我们在web应用开发过程中经常遇到输出某种编码的字符,如iso-8859-1等,如何输出一个UTF-8的字符串?

public String translate(String str){
        String trsl = "";
        try {
            trsl = new String(str.getBytes("ISO-8859-1"), "UTF-8");
            trsl.trim();
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return trsl;
    }

4、

class Cal{
     void show(String s){
         String ns="";
          for(int i=0;i<s.length();i++)
               ns=s.charAt(i)+ns;
          System.out.println(ns);
     }
     void show(int s){
          int i,ns=0;
          while(s!=0){
               ns=ns+s%10;
               s=s/10;
          }
          System.out.println(ns);
     }
}
public class T{
     public static void main(String[] args){
          Cal c1 = new Cal();
          c1.show(args[0]);
     }
} 

写出命令行输入12345后的程序运行结果。

15

5、什么是事务和它的特性?

事务就是用户定义的一系列操作,这些操作要么都执行,要么都不执行,它是一个不可分割的单位。

事务特性(ACID):

6、sleep 和 wait 的区别。

7、请你说下死锁的产生,该怎么防止死锁的产生?

8、使用redis优点和缺点是什么?

  1. 为什么我们调用start()方法时会执行run()方法,直接调用run()方法跟调用start()区别?

10、什么是锁的粒度,如何通过降低锁的粒度来提升并发性能?

对于数据库和线程:
1.数据库
数据库引擎具有多粒度锁定,允许一个事务锁定不同类型的资源。 为了尽量减少锁定的开销,数据库引擎自动将资源锁定在适合任务的级别。 锁定在较小的粒度(例如行)可以提高并发度,但开销较高,因为如果锁定了许多行,则需要持有更多的锁。 锁定在较大的粒度(例如表)会降低了并发度,因为锁定整个表限制了其他事务对表中任意部分的访问。 但其开销较低,因为需要维护的锁较少。
数据库引擎通常必须获取多粒度级别上的锁才能完整地保护资源。 这组多粒度级别上的锁称为锁层次结构。 例如,为了完整地保护对索引的读取,数据库引擎实例可能必须获取行上的共享锁以及页和表上的意向共享锁。
MySQL有三种锁的级别:页级、表级、行级。
MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking);BDB存储引擎采用的是页面锁(page-level
locking),但也支持表级锁;InnoDB存储引擎既支持行级锁(row-level locking),也支持表级锁,但默认情况下是采用行级锁。
MySQL这3种锁的特性可大致归纳如下:
表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。
行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。
页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。
每种锁可以在网上查询详细说明。主要看你用什么存储引擎。

简单算法题目:
11.猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,
又多吃了一个 第二天早上又将剩下的桃子吃掉一半,又多吃了一个。
以后每天早上都吃了前一天剩下 的一半零一个。到第10天早上想再吃时,
见只剩下一个桃子了。求第一天共摘了多少(编程)。

public static int eat(int day){
        int sum;
        if (day == 1) {
            return 1;
        }
        sum = eat(day-1);
        sum = (sum + 1)*2;
        return sum;
    }

12、打印出如下图案(菱形)
*






*
@Test
    public void printStart(){
        int space;
        int start;
        for (int i = 1; i < 5; i++) {
            space = 4 - i;
            start = 2*i - 1;
            while (space > 0) {
                System.out.print(" ");
                space--;
            }
            while (start > 0) {
                System.out.print("*");
                if (start == 1) {
                    System.out.println("");
                }
                start--;
            }
        }
        
        for (int ii = 3; ii > 0; ii--) {
            space = 4 - ii;
            start = 2*ii - 1;
            while (space > 0) {
                System.out.print(" ");
                space--;
            }
            while (start > 0) {
                System.out.print("*");
                if (start == 1) {
                    System.out.println("");
                }
                start--;
            }
        }
    }

13.请编程实现函数:接受一个小写的英文字母为参数,输出参数的后三位英文字母。例如参数'd'则输出'g',参数'y'则输出'b'。

public static Character character(char ch){
        char x = 'x';
        if (ch >= x) {
            ch -= 23;
        }
        else {
            ch += 3;
        }
        return ch;
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,864评论 6 494
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,175评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,401评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,170评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,276评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,364评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,401评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,179评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,604评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,902评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,070评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,751评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,380评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,077评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,312评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,924评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,957评论 2 351

推荐阅读更多精彩内容