eclipse,学生信息管理系统

做学生信息管理系统时用eclipse使用别人的文件包更改项目中的JAVA程序后,运行后没有变化的? 功能删除后界面没删除????

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
基于JAVA的学生信息管理系统
我有一个简单的学生信息管理系统的程序 可以运行程序 但是没有用户登录之类的界面 全部的操作都在一个界面里 ![图片说明](https://img-ask.csdn.net/upload/201506/01/1433139937_645726.png) 谁能帮我完善一下 做一个界面出来 能实现各个操作 若果繁琐的话 可以加一下QQ
java代码 写一个班级管理系统
在eclipse里面写一个班级信息管理系统的图形界面 首先显示主界面 课程信息管理系统和学生信息管理系统和退出 进入课程信息管理界面 可以进行课程信息的修改、增加、查询、删除、返回主界面、退出; 进入学生信息管理界面 可以进行学生信息的修改、增加、查询、删除、返回主界面、退出;
Java+Mysql学生信息管理系统
eclipse上运行时提示sql语句错误,但经过我的检查,并没有错误,也看了数据库,没有问题,怎么解决
Java 学生信息管理系统 求助 为什么会出现nullerror
nullError Exception in thread "main" java.lang.NullPointerException at Student.SQLFrame.getObject(SQLFrame.java:255) at Student.SQLFrame.setTable(SQLFrame.java:287) at Student.SQLFrame.init(SQLFrame.java:226) at Student.SQLFrame.<init>(SQLFrame.java:215) at Student.SQLFrame.main(SQLFrame.java:340) package Student; import java.awt.BorderLayout; import java.awt.Panel; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.awt.event.WindowAdapter; import java.awt.event.WindowEvent; import java.util.ArrayList; import javax.swing.DefaultCellEditor; import javax.swing.JButton; import javax.swing.JComboBox; import javax.swing.JFrame; import javax.swing.JOptionPane; import javax.swing.JScrollPane; import javax.swing.JTable; import javax.swing.table.DefaultTableModel; import javax.swing.table.TableColumn; import javax.swing.table.TableModel; import Student.Student; import Student.SQLTool; public class SQLFrame extends JFrame implements ActionListener { private JTable mainTab;// 显示学生记录的table private JButton allBtn;// 显示所有学生记/录 private JButton addBtn;// 添加新的学生记录 private JButton findBtn;// 根据姓名查询学生记录 private JButton delBtn;// 根据学号删除学生记录 private SQLTool tool;// 数据库操作类实例 private String[] tableName = { "学号", "姓名", "性别", "成绩", "备注" }; private int width[] = { 70, 60, 50, 80, 50, 140 }; public SQLFrame() { this.setVisible(true); this.setTitle("SimpleSMS"); this.setSize(500, 570); this.setResizable(false);// 设置窗口大小固定 this.setLocationRelativeTo(null);// 设置窗口居中 this.addWindowListener(new WindowAdapter() { public void windowClosing(WindowEvent e) { System.exit(0); } }); this.init(); initLayout(); } private void init() {// 组件初始化方法 tool = new SQLTool(); ArrayList<Student> stuList = tool.selectAll(); mainTab = new JTable(); setTable(stuList); mainTab.getTableHeader().setReorderingAllowed(false);// 设置Table列不可拖动 mainTab.setEnabled(false);// 设置Table不可编辑 allBtn = new JButton("所有记录"); addBtn.addActionListener(this); addBtn = new JButton("添加记录"); addBtn.addActionListener(this); findBtn = new JButton("查询记录"); findBtn.addActionListener(this); delBtn = new JButton("删除记录"); delBtn.addActionListener(this); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); } private void initLayout() { Panel btnPal = new Panel(); btnPal.add(allBtn); btnPal.add(addBtn); btnPal.add(findBtn); btnPal.add(delBtn); JScrollPane scroll = new JScrollPane(mainTab); add(scroll, BorderLayout.CENTER); add(btnPal, BorderLayout.SOUTH); } private Object[][] getObject(ArrayList<Student> stuList) { // 将stuList数组转变为Object的二维数组用于插入JTable Object[][] objects = new Object[stuList.size()][6]; for (int i = 0; i < stuList.size(); i++) { for (int j = 0; j < 6; j++) { switch (j) { case 0: objects[i][j] = stuList.get(i).getID(); break; case 1: objects[i][j] = stuList.get(i).getName(); break; case 2: objects[i][j] = stuList.get(i).getSex(); break; case 3: objects[i][j] = stuList.get(i).getClassStr(); break; case 4: objects[i][j] = stuList.get(i).getScore(); break; case 5: objects[i][j] = stuList.get(i).getRemarks(); break; default: break; } } } return objects; } private void setTable(ArrayList<Student> stuList) {// 更新Table数据 Object[][] objects = getObject(stuList); DefaultTableModel model = new DefaultTableModel(objects, tableName); mainTab.setModel(model); for (int i = 0; i < 6; i++) { mainTab.getColumnModel().getColumn(i).setPreferredWidth(width[i]); } } public void actionPerformed(ActionEvent e) { if (e.getSource().equals(allBtn)) { // 显示所有学生信息 setTable(tool.selectAll());// 查询所有学生信息,并在Table中显示出来 } else if (e.getSource().equals(addBtn)) { // 添加新的学生记录 InsertDialog insertDialog = new InsertDialog();// 自定义输入学生信息的对话框 // showInsertDialog方法显示对话框,并将输入的学生信息返回 Student stu = insertDialog.showInsertDialog(); if (stu != null) {// 判断是否有效 // 调用工具类的insert方法插入新的学生信息,并判断是否成功 if (tool.insert(stu)) { setTable(tool.selectAll()); } else { JOptionPane.showMessageDialog(null, "数据添加失败!"); } } } else if (e.getSource().equals(findBtn)) { // 通过姓名查询学生记录 // 弹出对话框让用户输入学生姓名 String nameStr = JOptionPane.showInputDialog("请输入查询学生的姓名:"); ArrayList<Student> stuList = tool.selectByName(nameStr); // 根据学生姓名查询学生记录,并将查询到的学生记录显示到Table中 setTable(stuList); } else { // 通过学号删除学生记录 try { // 若输入的不为纯数字将发生异常,通过显示错误提示解决异常 int id = Integer.parseInt(JOptionPane.showInputDialog("请输入删除学生的学号:")); // 调用工具类的deleteByID方法删除学生信息,并判断是否成功 if (tool.deleteByID(id)) { JOptionPane.showMessageDialog(null, id + "删除成功"); setTable(tool.selectAll()); } else { JOptionPane.showMessageDialog(null, "未找到学号:" + id); } } catch (Exception e2) { JOptionPane.showMessageDialog(null, "学号应为纯数字!"); } } } public static void main(String[] args){ SQLFrame frame = new SQLFrame(); frame.show(); } }
自己写的学生管理系统
![图片说明](https://img-ask.csdn.net/upload/201910/31/1572502335_787557.png) 问题:程序没有报错,但是执行功能部分有问题 添加功能没问题 所有功能针对存在的对象信息没有问题 但是针对未存在的信息有问题 比如添加了 李 174 18 男 80数据 完了要查询学号为77的就会报错(或者修改学号为177或者删除学号为177的) 因为信息不存在,不知道哪里出了问题,希望各位大佬帮忙看看,运行下,谢谢 ``` package student; import java.util.*; class Stu{ static Scanner sc=new Scanner(System.in); static Stu[] stu=new Stu[100]; static int number=0; private String name; private long num; private int age; private String sex; private double sore; public Stu(){ super(); } public void setName(String name) { this.name=name; } public void setNum(long num) { this.num=num; } public void setAge(int age) { this.age=age; } public void setSex(String sex) { this.sex=sex; } public void setSore(double sore) { this.sore=sore; } public String getName() { return this.name; } public long getNum() { return this.num; } public int getAge() { return this.age; } public String getSex() { return this.sex; } public double getSore() { return this.sore; } public static void add(Stu stu[]) { while(true) { System.out.println("按任意键输入0键退出"); if(sc.nextInt()==0)break; System.out.println("请添加姓名-学号-年龄-性别-成绩"); stu[number]=new Stu(); stu[number].setName(sc.next()); stu[number].setNum(sc.nextLong()); stu[number].setAge(sc.nextInt()); stu[number].setSex(sc.next()); stu[number].setSore(sc.nextDouble()); number++; System.out.println("添加成功"); } } public static void delete(Stu stu[]) { System.out.println("请输入删除学生学号"); long num1=sc.nextLong(); int i; for(i=0;i<number;i++) { if(num1==stu[i].num) { for(;i<number-1;i++) { stu[i]=stu[i+1]; } number--; } } if(i==number)System.out.println("未找到"); } public static void update(Stu stu[]) { System.out.println("请输入修改的学生信息学号"); long num2=sc.nextLong(); int i; for(i=0;i<number;i++) { if(num2==stu[i].num) { System.out.println("请输入修改内容选项及修改内容"); System.out.println("1-修改姓名 2-修改学号 3-修改年龄 4-修改性别 5-修改成绩"); int choice1=sc.nextInt(); switch(choice1) { case 1:stu[i].setName(sc.next());break; case 2:stu[i].setNum(sc.nextLong());break; case 3:stu[i].setAge(sc.nextInt());break; case 4:stu[i].setSex(sc.next());break; case 5:stu[i].setSore(sc.nextDouble());;break; } break; } if(i==number) System.out.println("信息错误"); } } public static void select(Stu stu[]) { System.out.println("请输入查询学生的学号"); long num3=sc.nextLong(); int i; for(i=0;i<number;i++) { if(num3==stu[i].num) { System.out.println("姓名"+stu[i].getName()+"学号"+stu[i].getNum()+"年龄"+stu[i].getAge()+"性别"+stu[i].getSex()+"成绩"+stu[i].getSore()); break; } if(i==number) System.out.println("信息错误"); } } public static void selectall(Stu stu[]) { System.out.println("全体学生信息"); int i; for(i=0;i<number;i++) { System.out.println("姓名"+stu[i].getName()+"学号"+stu[i].getNum()+"年龄"+stu[i].getAge()+"性别"+stu[i].getSex()+"成绩"+stu[i].getSore()); } } public static void show() { int choice; System.out.println("这是一个学生信息管理系统,欢迎您对本系统的使用"); while(true){ System.out.println("1.信息添加"); System.out.println("2.信息删除"); System.out.println("3.信息修改"); System.out.println("4.指定信息查询"); System.out.println("5.总体信息查询"); System.out.println("6.退出"); System.out.println("请输入你要进行的操作"); choice=sc.nextInt(); if(choice==6)break; switch(choice){ case 1: add(stu); break;//添加学生信息 case 2: delete(stu);break;//删除学生信息 case 3: update(stu);break;//修改学生信息 case 4: select(stu);break;//指定查询学生信息 case 5: selectall(stu);break;//总体信息查询 } } } } public class student{ public static void main(String[] args){ Stu stu=new Stu(); stu.show(); } } ![图片说明](https://img-ask.csdn.net/upload/201910/31/1572502290_217135.png) ```
Java课程设计-学生成绩管理系统
功能实现:单科排名,总分排名,添加删除修改学生信息,存储信息。 要求:SQL和eclipse完成。
Java web 设计一个学生学籍管理系统。
用户类型——学生类用户和管理员类用户,学生类用户只能查询和修改自己的基本信息;而管理员用户可以操作系统的所有功能 信息查看和浏览模块 查询模块 学籍管理:包括输入、修改、删除、查询学生名单及档案资料 5.权限控制模块 使用My Eclipse设计,链接的是Microsoft Office Access 2003数据库。我调试的时候用的是记事本。tomcat6.0但是它总是显示我有错误。我实在是编译不出来了。求好心人帮帮我。
帮忙看下导入导出 和排序有问题 没有 本人新手也看不出啥问题,就运行不出来 ,学生类我放在后面的。
package xuejiguanli; import jxl.*; import jxl.Workbook; import jxl.format.Colour; import jxl.format.UnderlineStyle; import jxl.format.VerticalAlignment; import jxl.read.biff.BiffException; import jxl.write.WritableSheet; import jxl.write.WritableWorkbook; import jxl.write.WriteException; import jxl.write.biff.RowsExceededException; import jxl.write.Label; import jxl.write.WritableCellFormat; import jxl.write.WritableFont; import java.util.ArrayList; import java.util.Arrays; import java.util.Iterator; import java.util.List; import java.util.Scanner; import javax.swing.GroupLayout.Alignment; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; //-------------------------------------------------------------------这是成绩管理系统的主界面 public class xueshengdei{ public static void main(String[] args) { List<Student> Students = new ArrayList<>(); while(true) { //----------------------------------------------------------------------菜单 System.out.println("-----------------学生管理系统----------------"); System.out.println("-------欢迎使用重庆工程学院学籍管理系统-------"); System.out.println("你可以使用的功能如下:^_^"); System.out.println(" 1-------------增加学生信息"); System.out.println(" 2-------------删除学生信息"); System.out.println(" 3-------------修改学生信息"); System.out.println(" 4-------------查看单独学生信息"); System.out.println(" 5-------------查看所有学生的信息"); System.out.println(" 6-------------对当前所有学生进行升序排序"); System.out.println(" 7-------------查看学校通知"); System.out.println(" 8-------------导入学生信息"); System.out.println(" 9-------------导出学生信息"); System.out.println(" 10------------退出该系统"); Scanner sc =new Scanner(System.in); System.out.println("请输入序号选择其对应的功能:"); String j = sc.nextLine(); switch (j) { case "1": //增加学生 addstudent(Students); break; case "2": //删除学生 deletestudent(Students); break; case "3": //修改学生 changestudent(Students); break; case "4": //单独查找 singlefind(Students); break; case "5": //查看所有学生 findstudent(Students); break; case "6": //排序 System.out.println("请输入你要是实现的排序功能:"); Scanner s =new Scanner(System.in); System.out.println("1---------------成绩排序:"); System.out.println("2---------------年龄排序:"); System.out.println("3---------------学号排序:"); String second=s.nextLine(); switch(second) { case "1": paixu(Students);break; case "2": paixu3(Students); break; case "3": paixu2(Students); break; } break; case "7": tongzhi(Students); //查看学校通知 break; case "8": exceldaoru(Students); //导入学生信息 break; case "9": daochu(Students); //导出学生信息 break; case "10": System.out.println("谢谢你的使用!"); System.exit(0);//退出 default: System.out.println("输入错误请重新输入!"); break; } } } //--------------------------------------------------------------导出 public static void daochu(List<Student> Students) { String excelpath; Scanner scanner=new Scanner(System.in); System.out.println("操作:导出数据"); System.out.println("请输入导出Excel文件路径:"); excelpath = scanner.next(); try { FileOutputStream fos = new FileOutputStream(excelpath); WritableWorkbook wwb = Workbook.createWorkbook(fos); // 创建工作表 WritableSheet ws = wwb.createSheet("学生学籍表", 10); // 设置单元格的文字格式 WritableFont wf = new WritableFont(WritableFont.ARIAL, 12, WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE, Colour.BLACK); WritableCellFormat wcf = new WritableCellFormat(wf); wcf.setVerticalAlignment(VerticalAlignment.CENTRE); ws.setColumnView(4, 10); ws.setColumnView(5, 16); ws.setColumnView(0, 14); ws.addCell(new Label(0, 0, "学号", wcf)); ws.addCell(new Label(1, 0, "姓名", wcf)); ws.addCell(new Label(2, 0, "年龄", wcf)); ws.addCell(new Label(3, 0, "性别", wcf)); ws.addCell(new Label(4, 0, "成绩", wcf)); // 填充数据的内容 // 匹配学生学号 System.out.println("所有学生学籍信息如下:"); int cnt = 1; while (cnt <= Students.size()) { Student s = (Student) Students.get(cnt - 1); ws.addCell(new Label(4, cnt, String.valueOf(s.getId()), wcf)); ws.addCell(new Label(1, cnt, String.valueOf(s.getName()), wcf)); ws.addCell(new Label(2, cnt, String.valueOf(s.getAge()), wcf)); ws.addCell(new Label(3, cnt, String.valueOf(s.getSex()), wcf)); ws.addCell(new Label(4, cnt, String.valueOf(s.getScore()), wcf)); cnt++; if (cnt == 0) wcf = new WritableCellFormat(); } wwb.write(); wwb.close(); System.out.println("学生信息导出成功!"); } catch (IOException e) { e.printStackTrace(); } catch (RowsExceededException e) { e.printStackTrace(); } catch (WriteException e) { e.printStackTrace(); } } //---------------------------------------------------------------导入 public static void exceldaoru(List<Student> Students) { Scanner scanner=new Scanner(System.in); String excelpath; excelpath = scanner.next(); WritableWorkbook book = null; try { // 创建一个Excel文件对象 FileOutputStream fos = new FileOutputStream(excelpath); // 创建Excel第一个选项卡对象 WritableWorkbook book1 = Workbook.createWorkbook(new File(excelpath)); WritableSheet sheet = book1.createSheet("第一页", 0); // 设置表头,第一行内容 // Label参数说明:第一个是列,第二个是行,第三个是要写入的数据值,索引值都是从0开始 Label label1 = new Label(0, 0, "学号");// 对应为第1列第1行的数据 Label label2 = new Label(1, 0, "姓名");// 对应为第2列第1行的数据 Label label3 = new Label(2, 0, "年龄");// 对应为第3列第1行的数据 Label label4 = new Label(3, 0, "性别");// 对应为第4列第1行的数据 // 添加单元格到选项卡中 sheet.addCell(label1); sheet.addCell(label2); sheet.addCell(label3); sheet.addCell(label4); // 遍历集合并添加数据到行,每行对应一个对象 for (int i = 0; i < Students.size(); i++) { Student s = Students.get(i); // 表头占据第一行,所以下面行数是索引值+1 // 跟上面添加表头一样添加单元格数据,这里为了方便直接使用链式编程 sheet.addCell(new Label(0, i + 1, s.getId()+"")); sheet.addCell(new Label(1, i + 1, s.getName())); sheet.addCell(new Label(2, i + 1, s.getAge()+"")); sheet.addCell(new Label(3, i + 1, s.getSex())); sheet.addCell(new Label(4, i + 1, s.getScore()+"")); } // 写入数据到目标文件 book.write(); } catch (Exception e) { e.printStackTrace(); } finally { try { // 关闭 book.close(); } catch (Exception e) { e.printStackTrace(); } } } //----------------------------------------------------------------------------------通知 public static void tongzhi(List<Student> Students) { int index = -1; if(Students.size()==0) { System.out.println("请你输入学生后再来查看通知,谢谢!"); return; } int[] point = new int[100]; for (int i = 0; i < Students.size(); i++) { Student s = Students.get(i); point[i] = s.getScore(); } for (int i = 0; i < Students.size(); i++) { if (point[i]<60){ Student s = Students.get(i); System.out.println(s.getName()+"同学,你收到的通知如下:"); System.out.println("恭喜你挂科了"); System.out.println("恭喜你挂科了"); System.out.println("恭喜你挂科了"); System.out.println("重要的事情说三遍"); } else { Student s = Students.get(i); System.out.println(s.getName()+"同学,你收到的通知如下:"); System.out.println("哎呦不错哟"); System.out.println("恭喜你没有挂科"); } } } //-----------------------------------------------------------------------------------成绩排序 public static void paixu(List<Student> Students) { if(Students.size()==0) { System.out.println("不好意思,目前还没有学生的信息可供排序,请返回重新操作!"); return; } int[] point = new int[100]; for (int i = 0; i < Students.size(); i++) { Student s = Students.get(i); point[i] = s.getScore(); Arrays.sort(point); } for (int j = 0; j < point.length; j++) { for (int i = 0; i < Students.size(); i++) { if (point[j]==Students.get(i).getScore()){ Student s = Students.get(i); System.out.println("学号\t姓名\t年龄\t性别\t成绩"); System.out.println(s.getId()+"\t"+s.getName()+"\t"+s.getAge()+"\t"+s.getSex()+"\t"+s.getScore()); } } } } //--------------------------------------------------------------------学号排序 public static void paixu2(List<Student> Students) { if(Students.size()==0) { System.out.println("不好意思,目前还没有学生的信息可供排序,请返回重新操作!"); return; } int[] point = new int[10000000]; for (int i = 0; i < Students.size(); i++) { Student s = Students.get(i); point[i] = s.getId(); Arrays.sort(point); } for (int j = 0; j < point.length; j++) { for (int i = 0; i < Students.size(); i++) { if (point[j]==Students.get(i).getId()){ Student s = Students.get(i); System.out.println("学号\t姓名\t年龄\t性别\t成绩"); System.out.println(s.getId()+"\t"+s.getName()+"\t"+s.getAge()+"\t"+s.getSex()+"\t"+s.getScore()); } } } } //---------------------------------------------------------------------------------------年龄排序 public static void paixu3(List<Student> Students) { if(Students.size()==0) { System.out.println("不好意思,目前还没有学生的信息可供排序,请返回重新操作!"); return; } int[] point = new int[100]; for (int i = 0; i < Students.size(); i++) { Student s = Students.get(i); point[i] = s.getAge(); Arrays.sort(point); } for (int j = 0; j < point.length; j++) { for (int i = 0; i < Students.size(); i++) { if (point[j]==Students.get(i).getAge()){ Student s = Students.get(i); System.out.println("学号\t姓名\t年龄\t性别\t成绩"); System.out.println(s.getId()+"\t"+s.getName()+"\t"+s.getAge()+"\t"+s.getSex()+"\t"+s.getScore()); } } } } //-------------------------------------------------------------------------------------------添加 public static void addstudent(List<Student> Students) { //创建键盘录入对象 Scanner sc= new Scanner(System.in); while(true) { System.out.println("请输入学号:"); int id= sc.nextInt(); System.out.println("请输入姓名:"); String name = sc.nextLine(); System.out.println("请输入年龄:"); int age = sc.nextInt(); System.out.println("请输入性别:"); String sex = sc.nextLine(); System.out.println("请输入成绩:"); int score = sc.nextInt(); //创建学生对象 Student s = new Student(); s.setId(id); s.setName(name); s.setAge(age); s.setSex(sex); s.setScore(score); //把学生对象添加到集合 Students.add(s); break; } System.out.println("添加学生成功!"); } //-----------------------------------------------------------------------------------------(查找所有学生) public static void findstudent(List<Student> Students) { if(Students.size()==0) { System.out.println("不好意思,目前还没有学生的信息可供查询,请返回重新操作!"); return; } for(int i=0;i<Students.size();i++) { Student s = Students.get(i); System.out.println("学号:"+s.getId()+"\n姓名:"+s.getName()+"\n性别:"+s.getSex()+"\n年龄:"+s.getAge()+"\n成绩:"+s.getScore()); } } //----------------------------------------------单独查找----------------------------------------------- public static void singlefind(List<Student> students) { Scanner sc=new Scanner(System.in); System.out.println("请输入要查找的学号"); int findId=sc.nextInt(); int index = -1; for(int i=0;i<students.size();i++) { Student s = students.get(i); if(s.getId()==findId) { index=i; } if (index == -1) { System.out.println("你要查找的学生不存在,请重新选择!"); }else { System.out.println("学号:"+s.getId()+"\n姓名:"+s.getName()+"\n性别:"+s.getSex()+"\n年龄:"+s.getAge()+"\n成绩:"+s.getScore()); } } } //------------------------------------------------------------------------------------------------删除 public static void deletestudent(List<Student> Students) { Scanner sc= new Scanner(System.in); System.out.print("请输入要删除的学号:"); int deleId = sc.nextInt(); int index = -1; for(int i=0;i<Students.size();i++) { Student s = Students.get(i); if(s.getId()==deleId) { index=i; } if (index == -1) { System.out.println("你要删除的学生不存在,请重新选择!"); } else { Students.remove(index); System.out.println("删除学生成功!!"); } } } //---------------------------------------------------------------------------------------修改 public static void changestudent(List<Student> students) { Scanner sc= new Scanner(System.in); System.out.print("请输入要改变的学号:"); int changeId = sc.nextInt(); int index = -1; for(int i=0;i<students.size();i++) { Student s = students.get(i); if(s.getId()==changeId) { index = i; } } if (index == -1) { System.out.println("您要改变的学生不存在,请重新操作!"); } else { System.out.println("请输入新的姓名:"); String name = sc.nextLine(); System.out.println("请输入新的年龄:"); int age = sc.nextInt(); System.out.println("请输入新的性别:"); String sex = sc.nextLine(); System.out.println("请输入新的成绩:"); int score = sc.nextInt(); //创建学生对象 Student s = new Student(); s.setId(changeId); s.setName(name); s.setAge(age); s.setSex(sex); s.setScore(score); //修改学生对象 students.set(index,s); System.out.println("修改学生成功!!!"); } } } //学生类 package xuejiguanli; public class Student { private String name; private int Id; private int age; private String sex; private int score; public Student() { } public Student(String name, int Id, int age, String sex,int score) { super(); this.name = name; this.Id = Id; this.age = age; this.sex = sex; this.score =score; } public String getName() { return name; }//姓名 public int getId() { return Id; }//学号 public int getAge() { return age; }//年龄 public String getSex() { return sex; }//性别 public int getScore() { return score; }//成绩 public void setName(String name) { this.name = name; } public void setId(int Id) { this.Id = Id; } public void setAge(int age) { this.age = age; } public void setSex(String sex) { this.sex = sex; } public void setScore(int score) { this.score = score; } }
程序执行没问题,结果也显示出来,功能也都可以执行,就是执行完2个查询功能,会有送色报错出现(命令行方式执行没有错误完全可以执行)不知道是不是eclipse的问题 麻烦各位大佬指点下
![图片说明](https://img-ask.csdn.net/upload/201910/31/1572500105_389131.png) ``` package student; import java.util.*; class Stu{ static Scanner sc=new Scanner(System.in); static Stu[] stu=new Stu[100]; static int number=0; private String name; private long num; private int age; private String sex; private double sore; public Stu(){ super(); } public void setName(String name) { this.name=name; } public void setNum(long num) { this.num=num; } public void setAge(int age) { this.age=age; } public void setSex(String sex) { this.sex=sex; } public void setSore(double sore) { this.sore=sore; } public String getName() { return this.name; } public long getNum() { return this.num; } public int getAge() { return this.age; } public String getSex() { return this.sex; } public double getSore() { return this.sore; } public static void add(Stu stu[]) { while(true) { System.out.println("按任意键输入0键退出"); if(sc.nextInt()==0)break; System.out.println("请添加姓名-学号-年龄-性别-成绩"); stu[number]=new Stu(); stu[number].setName(sc.next()); stu[number].setNum(sc.nextLong()); stu[number].setAge(sc.nextInt()); stu[number].setSex(sc.next()); stu[number].setSore(sc.nextDouble()); number++; System.out.println("添加成功"); } } public static void delete(Stu stu[]) { System.out.println("请输入删除学生学号"); long num1=sc.nextLong(); int i; for(i=0;i<stu.length;i++) { if(num1==stu[i].num) break; if(i==stu.length)System.out.println("未找到"); } for(;i<stu.length-1;i++) { stu[i]=stu[i+1]; } number--; } public static void update(Stu stu[]) { System.out.println("请输入修改的学生信息学号"); long num2=sc.nextLong(); int i; for(i=0;i<stu.length;i++) { if(num2==stu[i].num) { System.out.println("请输入修改内容选项及修改内容"); System.out.println("1-修改姓名 2-修改学号 3-修改年龄 4-修改性别 5-修改成绩"); int choice1=sc.nextInt(); switch(choice1) { case 1:stu[i].setName(sc.next());break; case 2:stu[i].setNum(sc.nextLong());break; case 3:stu[i].setAge(sc.nextInt());break; case 4:stu[i].setSex(sc.next());break; case 5:stu[i].setSore(sc.nextDouble());;break; } break; } if(i==stu.length) System.out.println("信息错误"); } } public static void select(Stu stu[]) { System.out.println("请输入查询学生的学号"); long num3=sc.nextLong(); int i; for(i=0;i<stu.length;i++) { if(num3==stu[i].num) System.out.println("姓名"+stu[i].getName()+"学号"+stu[i].getNum()+"年龄"+stu[i].getAge()+"性别"+stu[i].getSex()+"成绩"+stu[i].getSore()); if(i==stu.length) System.out.println("信息错误"); } } public static void selectall(Stu stu[]) { System.out.println("全体学生信息"); int i; for(i=0;i<stu.length;i++) { System.out.println("姓名"+stu[i].getName()+"学号"+stu[i].getNum()+"年龄"+stu[i].getAge()+"性别"+stu[i].getSex()+"成绩"+stu[i].getSore()); } } public static void show() { int choice; System.out.println("这是一个学生信息管理系统,欢迎您对本系统的使用"); while(true){ System.out.println("1.信息添加"); System.out.println("2.信息删除"); System.out.println("3.信息修改"); System.out.println("4.指定信息查询"); System.out.println("5.总体信息查询"); System.out.println("6.退出"); System.out.println("请输入你要进行的操作"); choice=sc.nextInt(); if(choice==6)break; switch(choice){ case 1: add(stu); break;//添加学生信息 case 2: delete(stu);break;//删除学生信息 case 3: update(stu);break;//修改学生信息 case 4: select(stu);break;//指定查询学生信息 case 5: selectall(stu);break;//总体信息查询 } } } } public class student{ public static void main(String[] args){ Stu stu=new Stu(); stu.show(); } } ![图片说明](https://img-ask.csdn.net/upload/201910/31/1572497739_506965.png) ```
萌新java连接MySQL数据库出现java.lang.NullPointerException错误是为什么,求大佬看一下代码解答
package Stu; import java.util.*; public class StuManage { public void menu(){ connectSQL s=new connectSQL(); int xuhao; String b1 = null,c1=null,b111=null; int a = 0,a1=0,b11=0,c11=0; Scanner scanner=new Scanner(System.in); System.out.println("欢迎来到学生信息管理系统"); System.out.println("1.新增学生"); System.out.println("2.修改学生"); System.out.println("3.删除学生"); System.out.println("4.查询学生"); System.out.println("5.显示所有学生信息"); System.out.println("6.退出该系统"); System.out.println("请选择(1-5):"); xuhao=scanner.nextInt(); switch (xuhao) { case 1: s.open(); stuadd(); s.down(); break; case 2: update(); break; case 3: studel(); s.open(); s.shanchu(a); s.down(); break; case 4: stuList(); s.open(); s.chaxun(b11); s.down(); break; case 5: xianshi(); s.open(); s.xianshi(); s.down(); break; case 6: System.exit(0); break; default: System.out.println("输入有误:程序自动退出,请重启程序"); break; } } public void stuadd(){ connectSQL x=new connectSQL(); Scanner s=new Scanner(System.in); String select,jieshou,name=null; int no=0,phone=0; System.out.println("====新增学生===="); System.out.println("学号:"); no=s.nextInt(); jieshou=s.nextLine(); System.out.println("姓名:"); name=s.nextLine(); System.out.println("手机号:"); phone=s.nextInt(); System.out.println("您输入的信息为:学号:"+no+" "+"姓名:"+name+" "+"手机号:"+phone); System.out.println("是否保存?y/n"); jieshou=s.nextLine(); select=s.nextLine(); if(select.equals("y")){ x.tianjia(no,name,phone); System.out.println("保存成功!"); } else if(select.equals("n")){ System.out.println("请重新输入"); } } package Stu; import java.sql.*; public class connectSQL { Connection con=null; PreparedStatement st=null; ResultSet rs=null; public void open(){ try { Class.forName("com.mysql.jdbc.Driver"); } catch (ClassNotFoundException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } String uri="jdbc:mysql://localhost:3306/qinyewei?user=root&password=123456&userSSL=ture"; try{ con=DriverManager.getConnection(uri); } catch(SQLException e){ System.out.println(e); } } public void down(){ try { con.close(); } catch (SQLException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } } void xianshi(){ try{ st=con.prepareStatement("select * from stu"); rs=st.executeQuery(); while(rs.next()) { String a=rs.getString(1); String b=rs.getString(2); String c=rs.getString(3); System.out.printf("%s\t",a); System.out.printf("%5s\t",b); System.out.println(c); } } catch (SQLException e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } } void tianjia(int a1,String b1,int c1) { try { System.out.println(a1); System.out.println(b1); System.out.println(c1); st=con.prepareStatement("insert stu values(?,?,?)"); st.setInt(1,a1); st.setString(2,b1); st.setInt(3,c1); int i=st.executeUpdate(); System.out.println("添加了"+i+"条记录"); this.xianshi(); } catch (Exception e) { // TODO 自动生成的 catch 块 e.printStackTrace(); } } 运行后输入1、学号、姓名、手机号以后出现错误是为什么呢? 欢迎来到学生信息管理系统 1.新增学生 2.修改学生 3.删除学生 4.查询学生 5.显示所有学生信息 6.退出该系统 请选择(1-5): 1 ====新增学生==== 学号: 123123 姓名: weqwe 手机号: 123123 您输入的信息为:学号:123123 姓名:weqwe 手机号:123123 是否保存?y/n y 123123 weqwe 123123 java.lang.NullPointerException保存成功! at Stu.connectSQL.tianjia(connectSQL.java:56) at Stu.StuManage.stuadd(StuManage.java:72) at Stu.StuManage.menu(StuManage.java:22) at Stu.Main.main(Main.java:7) 第56行代码是 st=con.prepareStatement("insert stu values(?,?,?)");
单个访问每个页面可以显示 但是从index.jsp的frame框架中链接其他页面就会报错,为什么呢?
<%@ page language="java" import="java.util.*" contentType="text/html; charset=utf-8"%> <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="<%=basePath%>"> <title>学生信息管理系统</title> ``` ``` </head> <frameset rows="90,*"> <frame src="../studentManage/top.jsp" scrolling="no"> <frameset cols="126,*"> <frame src="../studentManage/left.jsp" scrolling="no"> <frame src="../studentManage/bottom.jsp" name="main" scrolling="no"> </frameset> </frameset> </html> //以上是index.jsp页面代码,和其他页面一起放在webroot/studentManage目录下,从index页面浏览,整个框架结构可以显示 但每个区域链接的页面显示不出来,报错说**HTTP Status 404 – Not Found** **Type** Status Report **Message** /studentManage/bottom.jsp **Description** The origin server did not find a current representation for the target resource or is not willing to disclose that one exists. tomcat的webapps目录下可以找到该项目文件。不知道怎么回事,求帮忙啊
Servlet遇到java.lang.NullPointerException问题无法解决,恳求帮助
各位大佬,最近用Jsp+servlet写教务管理系统,其中servlet端有一个问题始终无法解决 ``` 严重: Servlet.service() for servlet [com.jwglxt.data.searchStudent] in context with path [/jwglxt] threw exception java.lang.NullPointerException ``` 目的是根据从前台传来的查询类型和查询关键词在数据库中进行检索,目前前后端数据传递正常,NullPointerException这个问题始终得不到解决,尝试了很多办法都不行,恳请各位大佬施以援手! 代码如下: ```java package com.jwglxt.data; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.ResultSetMetaData; import java.sql.SQLException; import java.sql.Statement; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.json.JSONArray; import org.json.JSONException; import org.json.JSONObject; //思路:绑定一个弹出框在“搜索”按钮上,弹出框里放置一个datagrid,url为searchStudent @WebServlet("/searchStudent") public class searchStudent extends HttpServlet { @SuppressWarnings({ "null", "null", "null" }) protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { //设置编码格式 request.setCharacterEncoding("UTF-8"); response.setCharacterEncoding("utf-8"); response.setContentType("text/json; charset=utf-8"); //获取学生信息主码-学号(sno) String name=request.getParameter("name"); System.out.println("搜索类型:"+name); String value=request.getParameter("value"); System.out.println("搜索值:"+value); //姑且赋值 /*String name="sno"; String value="990101";*/ //连接数据库 Connection connection=null; String driverName="com.microsoft.sqlserver.jdbc.SQLServerDriver";//SQL数据库引擎 String dbURL="jdbc:sqlserver://localhost:1433;DatabaseName=tjl";//数据源 !!!注意若出现加载或者连接数据库失败一般是这里出现问题 String Name="sa"; String Pwd="19990713"; ResultSet rs=null; String sql="sql"; //定义JSON数组,用于保存从数据库查出来的数据 JSONArray array = new JSONArray(); try { Class.forName(driverName); connection=DriverManager.getConnection(dbURL,Name,Pwd); System.out.println("搜索学生:连接数据库成功"); } catch (ClassNotFoundException e2) { e2.printStackTrace(); }catch (SQLException e) { e.printStackTrace(); } //处理搜索类型 尝试switch语句 /*switch(name) { case "sno":{ try { sql="select * from student where sno=?"; connection.prepareStatement(sql); pstmt.setString(1,value); //rs=pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); };break; }//case }//switch */ //处理搜索类型 尝试If语句 if(name!=null) { if("sno".equals(name)){ try { //仅构造SQL语句,暂不运行 sql="select * from student where sno=?"; PreparedStatement pstmt=connection.prepareStatement(sql); pstmt.setString(1,value); rs = pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } } else if("sname".equals(name)){ try { //仅构造SQL语句,暂不运行 sql="select * from student where sname=?"; PreparedStatement pstmt=connection.prepareStatement(sql); pstmt.setString(1,value); rs = pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } } else if("sex".equals(name)){ try { //仅构造SQL语句,暂不运行 sql="select * from student where sex=?"; PreparedStatement pstmt=connection.prepareStatement(sql); pstmt.setString(1,value); rs = pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } } else if("dno".equals(name)){ try { //仅构造SQL语句,暂不运行 sql="select * from student where dno=?"; PreparedStatement pstmt=connection.prepareStatement(sql); pstmt.setString(1,value); rs = pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } } else { try { //仅构造SQL语句,暂不运行 sql="select * from student where dormno=?"; PreparedStatement pstmt=connection.prepareStatement(sql); pstmt.setString(1,value); rs = pstmt.executeQuery(sql); } catch (SQLException e) { e.printStackTrace(); } } System.out.println(sql); } try { // 获取列数 ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); while (rs.next()) { JSONObject jsonObj = new JSONObject(); // 遍历每一列 for (int i = 1; i <= columnCount; i++) { String columnName =metaData.getColumnLabel(i); String value2 = rs.getString(columnName); try { jsonObj.put(columnName, value2); } catch (JSONException e) { // TODO Auto-generated catch block e.printStackTrace(); } } array.put(jsonObj); } } catch (SQLException e1) { e1.printStackTrace(); } //关闭 try { if(rs!=null) rs.close(); //pstmt.close(); connection.close(); } catch (SQLException e) { e.printStackTrace(); } //PrintWriter out = response.getWriter(); System.out.println(array); }//总类 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { doGet(request, response); } public static void main(String args[]) { searchStudent ss=new searchStudent(); try { ss.doGet(null, null); } catch (ServletException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } } ```
动态规划入门到熟悉,看不懂来打我啊
持续更新。。。。。。 2.1斐波那契系列问题 2.2矩阵系列问题 2.3跳跃系列问题 3.1 01背包 3.2 完全背包 3.3多重背包 3.4 一些变形选讲 2.1斐波那契系列问题 在数学上,斐波纳契数列以如下被以递归的方法定义:F(0)=0,F(1)=1, F(n)=F(n-1)+F(n-2)(n&gt;=2,n∈N*)根据定义,前十项为1, 1, 2, 3...
程序员,职场上请远离这种人!
对有些职场人来讲,甩锅就是一种生存手段。01.从大学打篮球说起上大学的时候喜欢打篮球,然后我又特别喜欢抢篮板,经常是跳起来的时候没事,落下来的时候偶尔会踩到别人的脚上,于...
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私...
对计算机专业来说学历真的重要吗?
我本科学校是渣渣二本,研究生学校是985,现在毕业五年,校招笔试、面试,社招面试参加了两年了,就我个人的经历来说下这个问题。 这篇文章很长,但绝对是精华,相信我,读完以后,你会知道学历不好的解决方案,记得帮我点赞哦。 先说结论,无论赞不赞同,它本质就是这样:对于技术类工作而言,学历五年以内非常重要,但有办法弥补。五年以后,不重要。 目录: 张雪峰讲述的事实 我看到的事实 为什么会这样 ...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
Python——画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)
最近翻到一篇知乎,上面有不少用Python(大多是turtle库)绘制的树图,感觉很漂亮,我整理了一下,挑了一些我觉得不错的代码分享给大家(这些我都测试过,确实可以生成) one 樱花树 动态生成樱花 效果图(这个是动态的): 实现代码 import turtle as T import random import time # 画樱花的躯干(60,t) def Tree(branch, ...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
一个读研让我损失了一百万的真实故事
关注我!只要10分钟,包你学会数据分析 毕业后,应该就业还是考研? 我刚出国留学那会儿,就惊讶的发现,外国local95%都不会选择读研 他们说,硕士学费很贵,时间宝贵,老板不认,所以很费 当几乎所有人都是本科学历时,硕士学历反而像个异类 在老板眼里,三年硕士远远不如3年的工作经验实用 他们甚至专门为拒绝高学历者发明了一个词,叫overoccupie...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给袈...
shell脚本:备份数据库、代码上线
备份MySQL数据库 场景: 一台MySQL服务器,跑着5个数据库,在没有做主从的情况下,需要对这5个库进行备份 需求: 1)每天备份一次,需要备份所有的库 2)把备份数据存放到/data/backup/下 3)备份文件名称格式示例:dbname-2019-11-23.sql 4)需要对1天以前的所有sql文件压缩,格式为gzip 5)本地数据保留1周 6)需要把备份的数据同步到远程备份中心,假如...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
为什么你学不过动态规划?告别动态规划,谈谈我的经验
动态规划难吗?说实话,我觉得很难,特别是对于初学者来说,我当时入门动态规划的时候,是看 0-1 背包问题,当时真的是一脸懵逼。后来,我遇到动态规划的题,看的懂答案,但就是自己不会做,不知道怎么下手。就像做递归的题,看的懂答案,但下不了手,关于递归的,我之前也写过一篇套路的文章,如果对递归不大懂的,强烈建议看一看:为什么你学不会递归,告别递归,谈谈我的经验 对于动态规划,春招秋招时好多题都会用到动态...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
如何安装 IntelliJ IDEA 最新版本——详细教程
IntelliJ IDEA 简称 IDEA,被业界公认为最好的 Java 集成开发工具,尤其在智能代码助手、代码自动提示、代码重构、代码版本管理(Git、SVN、Maven)、单元测试、代码分析等方面有着亮眼的发挥。IDEA 产于捷克,开发人员以严谨著称的东欧程序员为主。IDEA 分为社区版和付费版两个版本。 我呢,一直是 Eclipse 的忠实粉丝,差不多十年的老用户了。很早就接触到了 IDEA...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
为什么要推荐大家学习字节码?
配套视频: 为什么推荐大家学习Java字节码 https://www.bilibili.com/video/av77600176/ 一、背景 本文主要探讨:为什么要学习 JVM 字节码? 可能很多人会觉得没必要,因为平时开发用不到,而且不学这个也没耽误学习。 但是这里分享一点感悟,即人总是根据自己已经掌握的知识和技能来解决问题的。 这里有个悖论,有时候你觉得有些技术没用恰恰是...
【超详细分析】关于三次握手与四次挥手面试官想考我们什么?
在面试中,三次握手和四次挥手可以说是问的最频繁的一个知识点了,我相信大家也都看过很多关于三次握手与四次挥手的文章,今天的这篇文章,重点是围绕着面试,我们应该掌握哪些比较重要的点,哪些是比较被面试官给问到的,我觉得如果你能把我下面列举的一些点都记住、理解,我想就差不多了。 三次握手 当面试官问你为什么需要有三次握手、三次握手的作用、讲讲三次三次握手的时候,我想很多人会这样回答: 首先很多人会先讲下握...
压测学习总结(1)——高并发性能指标:QPS、TPS、RT、吞吐量详解
一、QPS,每秒查询 QPS:Queries Per Second意思是“每秒查询率”,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准。互联网中,作为域名系统服务器的机器的性能经常用每秒查询率来衡量。 二、TPS,每秒事务 TPS:是TransactionsPerSecond的缩写,也就是事务数/秒。它是软件测试结果的测量单位。一个事务是指一...
新程序员七宗罪
当我发表这篇文章《为什么每个工程师都应该开始考虑开发中的分析和编程技能呢?》时,我从未想到它会对读者产生如此积极的影响。那些想要开始探索编程和数据科学领域的人向我寻求建议;还有一些人问我下一篇文章的发布日期;还有许多人询问如何顺利过渡到这个职业。我非常鼓励大家继续分享我在这个旅程的经验,学习,成功和失败,以帮助尽可能多的人过渡到一个充满无数好处和机会的职业生涯。亲爱的读者,谢谢你。 -罗伯特。 ...
2019年Spring Boot面试都问了什么?快看看这22道面试题!
Spring Boot 面试题 1、什么是 Spring Boot? 2、Spring Boot 有哪些优点? 3、什么是 JavaConfig? 4、如何重新加载 Spring Boot 上的更改,而无需重新启动服务器? 5、Spring Boot 中的监视器是什么? 6、如何在 Spring Boot 中禁用 Actuator 端点安全性? 7、如何在自定义端口上运行 Sprin...
【图解】记一次手撕算法面试:字节跳动的面试官把我四连击了
字节跳动这家公司,应该是所有秋招的公司中,对算法最重视的一个了,每次面试基本都会让你手撕算法,今天这篇文章就记录下当时被问到的几个算法题,并且每个算法题我都详细着给出了最优解,下面再现当时的面试场景。看完一定让你有所收获 一、小牛试刀:有效括号 大部分情况下,面试官都会问一个不怎么难的问题,不过你千万别太开心,因为这道题往往可以拓展出更多有难度的问题,或者一道题看起来很简单,但是给出最优解,确实很...
面试官:关于Java性能优化,你有什么技巧
通过使用一些辅助性工具来找到程序中的瓶颈,然后就可以对瓶颈部分的代码进行优化。 一般有两种方案:即优化代码或更改设计方法。我们一般会选择后者,因为不去调用以下代码要比调用一些优化的代码更能提高程序的性能。而一个设计良好的程序能够精简代码,从而提高性能。 下面将提供一些在JAVA程序的设计和编码中,为了能够提高JAVA程序的性能,而经常采用的一些方法和技巧。 1.对象的生成和大小的调整。 J...
【图解算法面试】记一次面试:说说游戏中的敏感词过滤是如何实现的?
版权声明:本文为苦逼的码农原创。未经同意禁止任何形式转载,特别是那些复制粘贴到别的平台的,否则,必定追究。欢迎大家多多转发,谢谢。 小秋今天去面试了,面试官问了一个与敏感词过滤算法相关的问题,然而小秋对敏感词过滤算法一点也没听说过。于是,有了下下事情的发生… 面试官开怼 面试官:玩过王者荣耀吧?了解过敏感词过滤吗?,例如在游戏里,如果我们发送“你在干嘛?麻痹演员啊你?”,由于“麻痹”是一个敏感词,...
GitHub 标星 1.6w+,我发现了一个宝藏项目,作为编程新手有福了!
大家好,我是 Rocky0429,一个最近老在 GitHub 上闲逛的蒟蒻… 特别惭愧的是,虽然我很早就知道 GitHub,但是学会逛 GitHub 的时间特别晚。当时一方面是因为菜,看着这种全是英文的东西难受,不知道该怎么去玩,另一方面是一直在搞 ACM,没有做一些工程类的项目,所以想当然的以为和 GitHub 也没什么关系(当然这种想法是错误的)。 后来自己花了一个星期看完了 Pyt...
杭漂程序员2019的心路历程,还不起助学贷款,交不起房租,披荆斩棘终雨过天晴
一个杭漂2019的心酸历程,一路披荆斩棘终于还是雨过天晴。
我采访了同事,让他掏出了每天都会浏览的干货网站
前言只有光头才能变强。文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y在周六的晚上,我日常去到公司写文章。想写...
Java知识体系最强总结(2020版)
更新于2019-12-15 10:38:00 本人从事Java开发已多年,平时有记录问题解决方案和总结知识点的习惯,整理了一些有关Java的知识体系,这不是最终版,会不定期的更新。也算是记录自己在从事编程工作的成长足迹,通过博客可以促进博主与阅读者的共同进步,结交更多志同道合的朋友。特此分享给大家,本人见识有限,写的博客难免有错误或者疏忽的地方,还望各位大佬指点,在此表示感激不尽。 文章目录...
计算机专业的书普遍都这么贵,你们都是怎么获取资源的?
介绍几个可以下载编程电子书籍的网站。 1.Github Github上编程书资源很多,你可以根据类型和语言去搜索。推荐几个热门的: free-programming-books-zh_CN:58K 星的GitHub,编程语言、WEB、函数、大数据、操作系统、在线课程、数据库相关书籍应有尽有,共有几百本。 Go语言高级编程:涵盖CGO,Go汇编语言,RPC实现,Protobuf插件实现,Web框架实...
2020年一线城市程序员工资大调查
人才需求 一线城市共发布岗位38115个,招聘120827人。 其中 beijing 22805 guangzhou 25081 shanghai 39614 shenzhen 33327 工资分布 2020年中国一线城市程序员的平均工资为16285元,工资中位数为14583元,其中95%的人的工资位于5000到20000元之间。 和往年数据比较: yea...
毕业5年,我问遍了身边的大佬,总结了他们的学习方法
我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。
这些软件太强了,Windows必装!尤其程序员!
Windows可谓是大多数人的生产力工具,集娱乐办公于一体,虽然在程序员这个群体中都说苹果是信仰,但是大部分不都是从Windows过来的,而且现在依然有很多的程序员用Windows。 所以,今天我就把我私藏的Windows必装的软件分享给大家,如果有一个你没有用过甚至没有听过,那你就赚了????,这可都是提升你幸福感的高效率生产力工具哦! 走起!???? NO、1 ScreenToGif 屏幕,摄像头和白板...
大学四年因为知道了这32个网站,我成了别人眼中的大神!
依稀记得,毕业那天,我们导员发给我毕业证的时候对我说“你可是咱们系的风云人物啊”,哎呀,别提当时多开心啦????,嗯,我们导员是所有导员中最帅的一个,真的???? 不过,导员说的是实话,很多人都叫我大神的,为啥,因为我知道这32个网站啊,你说强不强????,这次是绝对的干货,看好啦,走起来! PS:每个网站都是学计算机混互联网必须知道的,真的牛杯,我就不过多介绍了,大家自行探索,觉得没用的,尽管留言吐槽吧???? 社...
史上最全的IDEA快捷键总结
现在Idea成了主流开发工具,这篇博客对其使用的快捷键做了总结,希望对大家的开发工作有所帮助。
相关热词 c#时间格式化 不带- c#替换字符串中指定位置 c# rdlc 动态报表 c# 获取txt编码格式 c#事件主动调用 c#抽象工厂模式 c# 如何添加类注释 c# static块 c#处理浮点数 c# 生成字母数字随机数
立即提问