JavaScript 编程题
下面两个函数的返回值是一样的吗?为什么?
function foo1() {
return {
bar:"hello"
};
}
function foo2() {
return
{
bar:"hello"
};
}
在编程语言中,基本都是使用分号(;)将语句分隔开,这可以增加代码的可读性和整洁性。而在 JS 中,如若语句各占独立一行,通常可以省略语句间的分号(;),JS 解析器会根据能否正常编译来决定是否自动填充分号:
var test = 1 + 2;
console.log(test); //3
在上述情况中,为了正确解析代码,就不会自动填充分号了,但是对于 return 、break、continue 等语句,如果后面紧跟换行,解析器一定会自动在后面填充分号(;),所以上面的第二个函数就变成了这样:
function foo2() {
return;
{
bar:"hello"
};
}
所以第二个函数是返回 undefined。
DROP TABLE IF EXISTS student_score;
CREATE TABLE student_score(
name varchar(255) DEFAULT NULL,
course VARCHAR(11),
score VARCHAR(20)
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
INSERT INTO student_score VALUES('张三','语文',81);
INSERT INTO student_score VALUES('张三','数学',75);
INSERT INTO student_score VALUES('李四','语文',76);
INSERT INTO student_score VALUES('李四','数学',90);
INSERT INTO student_score VALUES('王五','语文',81);
INSERT INTO student_score VALUES('王五','数学',100);
INSERT INTO student_score VALUES('王五','英语',90);
-- 用一条 SQL 语句,查询出每门课都大于 80 分的学生姓名。
-- having 和where 都是用来筛选用的 having 是筛选组 而where是筛选记录
-- 他们有各自的区别 1》当分组筛选的时候 用having 2》其它情况用where用having就一定要和group by连用,
-- 用group by不一有having (它只是一个筛选条件用的)
SELECT name FROM student_score GROUP BYname HAVING MIN(score)>80;
-- 或者 关键词 DISTINCT 用于返回唯一不同的值
SELECT DISTINCT name FROM student_score
WHERE name NOT in (
SELECT DISTINCT name from student_scoreWHERE score<=80);
packageDaily_practice;
/**
* 一球从 100 米高度自由落下,每次落地后反跳回原高度的一半;
* 再落下,求它在第 10 次落地时,共经过多少米?第 10 次反弹多高?
* @author pc
* @param h 距离
* @param n 次数
* @return第n次反弹的高度
*/
publicclass Day2 {
publicstaticdouble sum(doubleh,intn) {
if (n==1)
returnh/2;
else
return sum(h/2,n-1);
}
publicstaticvoid main(String[] args) {
System.out.println(sum(100,10));
}
}