JAVA中数组的创建,以及数组在内存中的分配

int[] arr = new int[3];

int[] arr1 = {1,2,3};

int[] arr2 = new int[] {1,2,3};
这三种方式都会在堆内存中创建一个数组对象的实体吗?还是只有第一种方式能创建实体?

3个回答

这三种方式都是在堆上分配的内存。其中2 3两个方式等价。

  几乎所有的程序设计语言都支持数组。Java也不例外。当我们需要多个类型相同的变量的时候,就考虑定义一个数组。在Java中,数组变量是引用类型的变量,同时因为Java是典型的静态语言,因此它的数组也是静态的,所以想要使用就必须先初始化(为数组对象的元素分配空间)。

对与Java数组的初始化,有以下两种方式,这也是面试中经常考到的经常题目:

静态初始化:初始化时由程序员显式指定......
答案就在这里:Java数组及其内存分配
----------------------Hi,地球人,我是问答机器人小S,上面的内容就是我狂拽酷炫叼炸天的答案,除了赞同,你还有别的选择吗?

这三种方式都是在堆上分配的内存。其中2 3两个方式等价。

caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 请管理员注意封杀这个胡乱抄袭的。
3 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
java中创建数组时内存怎么分配????
int[] arr=new int[3]; 问题: 上面创建int数组时,怎么分配内存的?arr是一个引用变量,是通过指针指向new int[3](存在堆里面)对吧,那么,栈里面为arr分配几个指针,是3个还是1个? >>>>>>>>>>>>>>>>>>>> 补充: 疑问1****: 其实我就是想知道java中创建数组时,栈中分配几个指针,是一个还是“数组长度”个? 疑问2****: 如果是一个,那么,这个指正指向谁???? 疑问3****: 如果指向的是第一个元素,那么,该指针怎么索引数组的其它元素???? 疑问4****: 如果疑问3中索引方式是通过指针值加上数组元素所占内存大小的来索引下一个元素,那么,当元素不是基本数据类型,而是摸个对象的实例时,又是怎么索引的???(实例对象数组的元素在元素创建时可是null的,对吧。而且在数组使用过程中数组元素指向的对象是可以变的,这不就意味着内存在变吗!!) >>>>>>>>>>>>>>>>>>>>>>>>>>>> 综合上述:我觉得数组创建时(我指的是被new出来时),栈中会为数组创建数组长度个指针分别指向每个元素。 但是,问题又来了。 问题5****: int[] arr;//这里分配几个指针(栈)?? arr=new int[3]; 还请大神来解答我的疑惑,能解答一个是一个。。。谢谢。。
Java数组边界,验证,存储问题!
在Java中如何完成边界检查?如何创建一个对象数组?数组在内存分配是如何造成的?
Java对象中的对象如何分配内存?
在Java中,比如A a=new A ();是在堆内存中创建了一个对象,然后把这个对象的引用传递给栈内存中的对象变量a。那如果a对象拥有一个字符串对象,那a对象中保存的是这个字符串对象的引用吗?
Java中静态方法在内存的位置?
最近在复习JAVA的内存知识。静态变量是加载在方法区的,内存分配即在方法区,当创建类的时候堆里有静态变量的指向地址,然后栈内的对象可以通过堆内地址找到该静态变量,为大家共用。 那静态方法呢?也是在方法区中分配内存吗?是随着类的加载而初始化的吗?但是我测试的如下运行代码,却并没有运行此静态方法。 package com.learn.java.cc; class Static1{ static void sys1(){ System.out.println("hello!"); } } public class StaticDemo { public static void main(String[] args){ Static1 s = new Static1(); } } 求解? 原因:感谢各位的回答,在类中还有一个叫做静态代码块和构造代码块(即没有静态修饰的只被{}的代码),创建对象的时候会默认先加载静态代码块和构造代码块,这里的print会被打印出来,然后加载构造方法,而本类中的静态方法只是在调用的时候才被使用。 package com.learn.java.cc; class Static1{ { System.out.println("hello2!"); } static{ System.out.println("hello1!"); } static void sys1(){ System.out.println("hello3!"); } } public class StaticDemo { public static void main(String[] args){ Static1 s = new Static1(); } } 结果: hello1! hello2!
有关java语句在内存中的分配
如:int[] a=new int[]{1,2,3} 我知道new关键字会在堆中创建int类型数组对象 那么 int[] a={1,2,3}没有关键字new会不会创建对象
java初始化堆内存为8g,操作系统真的会立即分配8g的内存吗
最近看了一个问题,说是 java在创建子进程的时候,由于会申请和父进程相似大小的 内存空间,导致内存使用量翻倍,所以想验证一下. 代码如下所示 ```java public class ProcessDemo { public static void main(String[] args) throws Exception{ Thread.sleep(20000); ProcessBuilder pb = new ProcessBuilder("/bin/sh", "-c","ifconfig"); Process process = pb.start(); Scanner scanner = new Scanner(process.getInputStream()); while (scanner.hasNextLine()) { System.out.println(scanner.nextLine()); } Thread.sleep(20000); scanner.close(); } } ``` 第一个sleep20秒 是为了使用ps -ef | grep ProcessDemo 查看进程号 然后使用top -p pid 来观察内存使用情况 如下所示 我设置初始化堆内存为8g,但是这个java进程并没有占用8g的内存空间 ![图片说明](https://img-ask.csdn.net/upload/201909/27/1569551954_815263.png)
java gc负责堆的内存释放,那栈的内存如果一个栈帧导致其满了,怎么办?
在其他人在哪里看到了这个答复: ``` Java中是通过栈帧来维护的,每调用方法的时候,就会创建栈帧,然后栈帧中有一个局部变量表,当函数调用结束的时候,这个栈帧就会自动释放,局部变量也被释放了 所以栈的内存都是随着函数的开始执行和结束自动分配,释放的 ``` 这个能理解,但是如果满了呢,会怎么办呢
java类实现继承时,内存中父类和子类是怎样分配的?
我觉得java的一些特性与对象在内存中的分配方式是密切相关的。 比如说:Java的多态,正是因为new出的对象是在堆中分配的,而这种内存分配方式在编译期无需知道此对象所需要的空间和生存周期。 现在我很困惑的是,java类实现继承时,内存中父类和子类是怎样分配的?或者说有着怎样的联系呢。 例如: 父类:Father [code="java"] public class Father { protected String classname = "Father"; public Father(){ } public Father(String cn){ setClassName(cn); } protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } } [/code] 子类:Child [code="java"] public class Child extends Father{ public Child(){ } public Child(String cn){ super(cn); } private String cname = "Child"; public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } }[/code] 此时,我写测试代码: [code="java"] public class FatherChildTest { public static void main(String args[]){ System.out.println(new Child().getClassName()); System.out.println(new Child("be changed in constructor!").getClassName()); } } [/code] 输出内容很明显: Father be changed in constructor! 想问的是,测试代码中,[code="java"]new Child().getClassName()[/code]动作时, 我创建的是Child对象,而它有父类的方法,且可以返回父类中定义的变量。 那Child继承Father,是不是相当于JVM加载类时,保存的类信息中不仅仅是Child的信息,还包括Father的那些对子类可见的信息? 比如,其实JVM加载类Child时,保存的类信息其实是这样的一个类的信息: [code="java"] public class Child{ public Child(){ } public Child(String cn){ setClassName(cn); } private String cname = "Child"; //-------------来自父类 begin---------------- protected String classname = "Father"; protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } //-------------来自父类 End---------------- public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } } [/code] 此类留有父类对子类可见的信息。 还是说,有另外一种方式,可以把子类与父类联系起来。 请指点! 我想知道原理,但可能表达的不太清楚,见谅! [b]问题补充:[/b] 我觉得java的一些特性与对象在内存中的分配方式是密切相关的。 比如说:Java的多态,正是因为new出的对象是在堆中分配的,而这种内存分配方式在编译期无需知道此对象所需要的空间和生存周期。 现在我很困惑的是,java类实现继承时,内存中父类和子类是怎样分配的?或者说有着怎样的联系呢。 例如: 父类:Father <pre name="code" class="java"> public class Father { protected String classname = "Father"; public Father(){ } public Father(String cn){ setClassName(cn); } protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } } </pre> 子类:Child <pre name="code" class="java"> public class Child extends Father{ public Child(){ } public Child(String cn){ super(cn); } private String cname = "Child"; public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } }</pre> 此时,我写测试代码: <pre name="code" class="java"> public class FatherChildTest { public static void main(String args[]){ System.out.println(new Child().getClassName()); System.out.println(new Child("be changed in constructor!").getClassName()); } } </pre> 输出内容很明显: Father be changed in constructor! 想问的是,测试代码中,<pre name="code" class="java">new Child().getClassName()</pre>动作时, 我创建的是Child对象,而它有父类的方法,且可以返回父类中定义的变量。 那Child继承Father,是不是相当于JVM加载类时,保存的类信息中不仅仅是Child的信息,还包括Father的那些对子类可见的信息? 比如,其实JVM加载类Child时,保存的类信息其实是这样的一个类的信息: <pre name="code" class="java"> public class Child{ public Child(){ } public Child(String cn){ setClassName(cn); } private String cname = "Child"; //-------------来自父类 begin---------------- protected String classname = "Father"; protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } //-------------来自父类 End---------------- public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } } </pre> 此类留有父类对子类可见的信息。 还是说,有另外一种方式,可以把子类与父类联系起来。 请指点! 我想知道原理,但可能表达的不太清楚,见谅! -------------------补充------------------ 以下是mccxj所说,我没太懂: 【子类里有一个区域放的父类的实例,子类内存区里有一个this指针,指向了这个内存区里包括的父类实例区,当把引用付给父类时,是把子类内存区里面的父类实例区域的引用给了父类的实例.】 子类内存区里this指针不是指向它自己的吗? 而super指针才是指向了父类的实例? 后面那句 【当把引用付给父类时,是把子类内存区里面的父类实例区域的引用给了父类的实例.】,同样不太懂,感觉很模糊。 是不是说,当把引用付给父类时,这个引用体现的其实是子类中父类实例的属性? [b]问题补充:[/b] 我觉得java的一些特性与对象在内存中的分配方式是密切相关的。 比如说:Java的多态,正是因为new出的对象是在堆中分配的,而这种内存分配方式在编译期无需知道此对象所需要的空间和生存周期。 现在我很困惑的是,java类实现继承时,内存中父类和子类是怎样分配的?或者说有着怎样的联系呢。 例如: 父类:Father <pre name="code" class="java"> public class Father { protected String classname = "Father"; public Father(){ } public Father(String cn){ setClassName(cn); } protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } } </pre> 子类:Child <pre name="code" class="java"> public class Child extends Father{ public Child(){ } public Child(String cn){ super(cn); } private String cname = "Child"; public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } }</pre> 此时,我写测试代码: <pre name="code" class="java"> public class FatherChildTest { public static void main(String args[]){ System.out.println(new Child().getClassName()); System.out.println(new Child("be changed in constructor!").getClassName()); } } </pre> 输出内容很明显: Father be changed in constructor! 想问的是,测试代码中,<pre name="code" class="java">new Child().getClassName()</pre>动作时, 我创建的是Child对象,而它有父类的方法,且可以返回父类中定义的变量。 那Child继承Father,是不是相当于JVM加载类时,保存的类信息中不仅仅是Child的信息,还包括Father的那些对子类可见的信息? 比如,其实JVM加载类Child时,保存的类信息其实是这样的一个类的信息: <pre name="code" class="java"> public class Child{ public Child(){ } public Child(String cn){ setClassName(cn); } private String cname = "Child"; //-------------来自父类 begin---------------- protected String classname = "Father"; protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } //-------------来自父类 End---------------- public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } } </pre> 此类留有父类对子类可见的信息。 还是说,有另外一种方式,可以把子类与父类联系起来。 请指点! 我想知道原理,但可能表达的不太清楚,见谅! <strong>问题补充:</strong> 我觉得java的一些特性与对象在内存中的分配方式是密切相关的。 比如说:Java的多态,正是因为new出的对象是在堆中分配的,而这种内存分配方式在编译期无需知道此对象所需要的空间和生存周期。 现在我很困惑的是,java类实现继承时,内存中父类和子类是怎样分配的?或者说有着怎样的联系呢。 例如: 父类:Father &lt;pre name="code" class="java"> public class Father { protected String classname = "Father"; public Father(){ } public Father(String cn){ setClassName(cn); } protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } } &lt;/pre> 子类:Child &lt;pre name="code" class="java"> public class Child extends Father{ public Child(){ } public Child(String cn){ super(cn); } private String cname = "Child"; public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } }&lt;/pre> 此时,我写测试代码: &lt;pre name="code" class="java"> public class FatherChildTest { public static void main(String args[]){ System.out.println(new Child().getClassName()); System.out.println(new Child("be changed in constructor!").getClassName()); } } &lt;/pre> 输出内容很明显: Father be changed in constructor! 想问的是,测试代码中,&lt;pre name="code" class="java">new Child().getClassName()&lt;/pre>动作时, 我创建的是Child对象,而它有父类的方法,且可以返回父类中定义的变量。 那Child继承Father,是不是相当于JVM加载类时,保存的类信息中不仅仅是Child的信息,还包括Father的那些对子类可见的信息? 比如,其实JVM加载类Child时,保存的类信息其实是这样的一个类的信息: &lt;pre name="code" class="java"> public class Child{ public Child(){ } public Child(String cn){ setClassName(cn); } private String cname = "Child"; //-------------来自父类 begin---------------- protected String classname = "Father"; protected String getClassName(){ return classname; } protected void setClassName(String cn){ classname = cn; } //-------------来自父类 End---------------- public String getCname() { return cname; } public void setCname(String cname) { this.cname = cname; } } &lt;/pre> 此类留有父类对子类可见的信息。 还是说,有另外一种方式,可以把子类与父类联系起来。 请指点! 我想知道原理,但可能表达的不太清楚,见谅! -------------------补充------------------ 以下是mccxj所说,我没太懂: 【子类里有一个区域放的父类的实例,子类内存区里有一个this指针,指向了这个内存区里包括的父类实例区,当把引用付给父类时,是把子类内存区里面的父类实例区域的引用给了父类的实例.】 子类内存区里this指针不是指向它自己的吗? 而super指针才是指向了父类的实例? 后面那句 【当把引用付给父类时,是把子类内存区里面的父类实例区域的引用给了父类的实例.】,同样不太懂,感觉很模糊。 是不是说,当把引用付给父类时,这个引用体现的其实是子类中父类实例的属性? -------------------------再补充-------------------------- 一下为bohemia 所说: 【super相当于指向父类示例的一个指针; 子类只保存子类的信息和super指针; 具体调用,先查找当前子类,然后查找父类是否有实现; 】 既然先查找子类,为何变量会找到父类呢? (我查了,跟java的编译期绑定和运行时绑定有关) 想听听大家的理解。 [b]问题补充:[/b] -------------------补充------------------ 以下是mccxj所说,我没太懂: 【子类里有一个区域放的父类的实例,子类内存区里有一个this指针,指向了这个内存区里包括的父类实例区,当把引用付给父类时,是把子类内存区里面的父类实例区域的引用给了父类的实例.】 子类内存区里this指针不是指向它自己的吗? 而super指针才是指向了父类的实例? 后面那句 【当把引用付给父类时,是把子类内存区里面的父类实例区域的引用给了父类的实例.】,同样不太懂,感觉很模糊。 是不是说,当把引用付给父类时,这个引用体现的其实是子类中父类实例的属性? -------------------------再补充-------------------------- 一下为bohemia 所说: 【super相当于指向父类示例的一个指针; 子类只保存子类的信息和super指针; 具体调用,先查找当前子类,然后查找父类是否有实现; 】 既然先查找子类,为何变量会找到父类呢? (我查了,跟java的编译期绑定和运行时绑定有关) 想听听大家的理解。
关于c++堆栈与java堆的区别
最近看java编程思想 看到这样一句话:“在Java中,所有对象都必须在内存“堆”里创建。而在C++中,对象是在堆栈中创建的。这样可达到更快的速度,”这句话不能理解。c++的堆栈和java的堆有啥区别啊。 PS:原文“最重要的一种情况是C和C++对内存的管理方式,它是某些人觉得Java速度肯定慢的重要依据:在Java中,所有对象都必须在内存“堆”里创建。而在C++中,对象是在堆栈中创建的。这样可达到更快的速度,因为当我们进入一个特定的作用域时,堆栈指针会向下移动一个单位,为那个作用域内创建的、以堆栈为基础的所有对象分配存储空间。”
Java里String str="abc";在堆中分配空间了吗
初学Java ,书上说 String str="abc"; 是把一个在堆中开辟的堆内存空间使用权给了栈中的str。 但我在网上看了一篇文章说,用双引号定义的字符串在编译期已经创建好,存储在常量池中。 那么谁说的对,还有运行时常量池是在堆中吗。
有关Java对象首地址的苦恼
大家好,Java在创建对象时,在堆内存中分配到一块内存存储对象,而栈内存中的引用变量存储Java对象的首地址,请问对象的首地址是如何分配的?对象的属性地址又是如何计算分配的?
Java多线程和其创建对象的内存使用机制?
1. ``` public void addActionRecord(Object oldEntity, Object newEntity,String applicationName) { try { ActionVo actionVo = BorpUtil.getActionRecord(oldEntity, newEntity,applicationName); Executors.newFixedThreadPool(1).submit(() -> { try { addAction(actionVo); } catch (Exception var3) { System.out.println(var3.getMessage()); } }); } catch (Exception var4) { System.out.println(var4.getMessage()); } } ``` 主要问题是:是不是每次执行上面这段代码的时候都会创建一个线程?然后用这种线程池创建出的核心线程是不是一直不会被回收?如果这里执行多次的话是不是会创建出许多回收不掉的线程。 PS:addAction(actionVo);这里只是一个业务方法 2.在Linux环境下,每个线程资源共享还是会给每个线程单独分配内存? 3.如果是单独分配内存,当非主线程空闲被回收时,这个线程之前创建的对象会立即被回收吗?还是等垃圾回收的时候才会去回收?
java中的引用和new的用法
初学java,有些问题很幼稚,还望各位大神能多扶持 首先,说说引用的问题, 我定义了一个A类。其中初始化属性name为A, 接下来: A a = new A;//创建一个对象 A a1 = a;//这里好像是一个引用,有点不懂,我把他理解为指针, a = new A; // 这是第二个问题,在创建对象的时候,一般不都是类 对象 = new 类吗?为什么这里可以直接new呢,而且看教程上是说又新分配了一个空间,我想问的是只要是new,都是分配存储空间吗,及即使不创建对象 // 还有补充一点,在第三行代码中,由于是新分配了一个空间,第一二条代码相当于a1指向原来a指向的空间,然后后来a又指向了一个新的内存,在这个时候,a指向了两个存储空间,教程上说a指向原来的空间这就作废了,然后这时,a1指向了两个空间, 教程上说这时a1指向了原来a指向的空间,这里我就不明白了,为什么, 还望各位指教
java中静态方法为什么无法调用非静态变量或者方法
我在网上搜到的回答都是类似下面这样: 静态方法是随着类的加载而加载的,对象是在类加载之后创建的,也就是说静态方法先于对象存在。当你创建一个对象时,程序为其在堆中分配内存,一般是通过this指针来指向该对象。静态方法不依赖于对象的调用,它是通过‘类名.静态方法名’这样的方式来调用的。而对于非静态方法,在对象创建的时候程序才会为其分配内存,然后通过类的对象去访问非静态方法/变量。因此在对象未存在时非静态方法/变量也不存在,静态方法自然不能调用一个不存在的方法。 这个解释我看完还是有一点不是很明白,想请教一下大家,以下面的代码为例: ``` public class D143Demo_Person3 { public static void main(String[] args) { Person p1 = new Person(); p1.name = "林青霞"; p1.speak(); } } class Person{ String name; //姓名 public static void speak() { System.out.println(name); } } ``` 当已经创建了一个p1的对象并为其变量name赋值后。此时的p1.name不是已经存在了吗,为什么还是使用静态方法p1.speak仍然会报错。 麻烦各位大神说说我的理解错在哪儿了。 我随后查阅资料,有一段是这么写的: 如果静态方法能调用动态方法的话,那如果别人通过类名调用静态方法时实例对象可能并不存在,但是方法内又调用了对象的方法,由于对象不存在,所以动态方法也不存在,程序肯定报错,所以java直接在编译阶段检查这种错误,避免运行时异常。这个解释我就懂了。
关于直接/非直接字节缓冲区的相关问题
对于ByteBuffer 可以通过allocateDirect()来创建缓冲区。那MappedByteBuffer 他应该也是直接字节缓冲区吧。 问题: 1. 他们两个的区别 2.ByteBuffer .allocateDirect(); 是不是也创建了映射文件。 3.他们在使用的时候创建的是什么内存(物理还是什么),这个内存会不会被GC回收或者被jvm去控制。() ``` static void reserveMemory(long size) { synchronized (Bits.class) { if (!memoryLimitSet && VM.isBooted()) { maxMemory = VM.maxDirectMemory(); memoryLimitSet = true; } if (size <= maxMemory - reservedMemory) {//如果创建直接缓冲区后的内存占用不超过最大内存限制 reservedMemory += size;//更新已分配的内存大小 return; } }    //如果超过最大内存限制,执行垃圾回收 System.gc(); try { Thread.sleep(100);//等待垃圾回收完成 } catch (InterruptedException x) { // Restore interrupt status Thread.currentThread().interrupt(); } synchronized (Bits.class) { if (reservedMemory + size > maxMemory)//如果依然超过最大内存限制,则抛出内存溢出异常 throw new OutOfMemoryError("Direct buffer memory"); reservedMemory += size; } ``` 这个是allocateDirect里调用的方法 他确实是对于内存不够是进行了GC。那MappedByteBuffer呢。 **我说的比较乱 因为我的理解也不是很好见谅**
做了一个小时的面试题(没有过 希望大家帮忙答下 虽然很幼稚 毕竟每个人都是这么过来的吗 感激了!)
XX软件工程师笔试试题 注:1、请参考人员将答案写在答题纸上,勿将答案写在此卷上。 2、请参考人员将编号与姓名填写在答题纸上。 1、 以下数据结构中不属于线性数据结构的是()。 A、队列 B、线性表 C、二叉树 D、栈 我的答案:C 2、 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是()。 A、 可行性分析 B、需求分析 C、详细设计 D、程序编码 我的答案:B 3、 结构化程序设计主要强调的是()。 A、 程序的规模 B、程序的易读性 C、程序的执行效率 D、程序的可移植性 我的答案:C 4、 在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段()。 A、 概要设计 B、详细设计 C、可行性分析 D、需求分析 我的答案:B 5、 下列关于栈的叙述中正确的是()。 A、 在栈中只能插入数据 B、在栈中只能删除数据 B、 栈是先进先出的线性表 D、栈是先进后出的线性表 我的答案:D 6、 下面不属于软件设计原则的是()。 A、 抽象 B、模块化 C、自底向上 D、信息隐蔽 我的答案:C 7、 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为()。 A、 N+1 B、N C、(N+1)/2 D、N/2 我的答案:C 8、 视图设计一般有3种设计次序,下列不属于视图设计的是()。 A、 自顶向下 B、由外向内 C、由内向外 D、自底向上 我的答案:C 9、下列有关数据库的描述,正确的是()。 A、数据库是一个DBF文件 B、数据库是一个关系 C、数据库是一个结构化的数据集合 D、数据库是一组文件 我的答案:C 10、下列说法中,不属于数据模型所描述的内容的是()。 A、数据结构 B、数据操作 C、数据查询 D、数据约束 我的答案:A 11、若按功能划分,软件测试的方法通常分为白盒测试方法和(黑盒测试方法)。 12、数据库系统的三级模式分别为(级联)模式、内部级模式与外部级模式。 13、在最坏情况下,冒泡排序的时间复杂度为(N+1/2)。 14、在面向对象方法中,信息隐蔽是通过对象的(封装)性来实现的。 15、关系模型的数据操纵既是建立在关系上的数据操纵,一般有(插入)、增加、删除、和修改四种操作。 16、TIME()的返回值的数据类型是(String)类型。 17、编写SQL语句 1)、创建一张学生表,包含以下信息,学号,姓名,年龄,性别,家庭住址,联系电话 我的答案: create table student( studentCardNo number(2) primary key, name char(10), age number(2), sex char(2) check(sex in (‘男’,’女’)), address varchar2(100), tel number(2) ) 2)、修改学生表的结构,添加一列信息,学历 我的答案: alter table student add(xueli varchar2(20)); 3)、修改学生表的结构,删除一列信息,家庭住址 我的答案: alter table student drop column address; 4)、向学生表添加如下信息: 学号 姓名 年龄 性别 联系电话 学历 1 A 22 男 123456 小学 2 B 21 男 119 中学 3 C 23 男 110 高中 4 D 18 女 114 大学 我的答案: insert into student values(‘&1’,’&2’,’&3’); 一次一次添加 5)修改学生表的数据,将电话号码以11开头的学员的学历改为“大专” 我的答案: update student set xueli=”大专” where tel like 11%; 6)删除学生表的数据,姓名以C开头,性别为‘男’的记录删除 我的答案: delete student where name like C% or sex=”男”; 7)查询学生表的数据,将所有年龄小于22岁的,学历为“大专”的,学生的姓名和学号显示出来 我的答案: select name,studentCardNo from student where age<22 and xueli=”大专”; 8)查询学生表的数据,查询所有信息,列出前25%的记录 我的答案: select top*0.25 from student; 9)查询出所有学生的姓名,性别,年龄降序排列 我的答案: select name,sex,age from student where age desc; 10)按照性别分组查询所有的平均年龄 我的答案: select avg(age) from student group by sex; 18、什么是存储过程?为什么存储过程要比单纯的SQL语句执行起来要快? 我的答案: 存储过程算是一种优化查询需要比单存SQL语句执行的要快 19、两张关联表,删除主表中已经在副表中没有的信息 我的答案 delete from fubiao a where a.fid not in(select id from zhubiao) 20、程序题: 用1、2、2、3、4、5这六个数字,用java或你熟悉的语言,打印出所有不同的排列,如:512234、412345等,要求:“4”不能再第三位,“3”与“5”不能相连。并将这些数据按从小到大输出。 我的答案 我的写的不好 没贴下 笔试的时候没写全 21、String 和 StringBuffer的区别 我的答案 String定长 StringBuffer 变长 22、&和&&的区别 我的答案 &短路与 &&逻辑与 网上答案: & 是位运算符,表示按位与运算, && 是逻辑运算符,表示逻辑与(and)。 23、final,finally,finalize的区别 我的答案 Final静变量关键字,finally异常关键字,finalize 网上答案 final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。 finally是异常处理语句结构的一部分,表示总是执行。 finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法, 可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。 24、数组有没有length()这个方法?String有没有length()这个方法? 我的答案: 数组没有length()这个方法,有length的属性。 String有length()这个方法。 25、是否可以继承String类? 我的答案: 不可以 解释的很乱 26、说出数据连接池的工作机制是什么? 我的答案: 反正解释的很乱我感觉 27、垃圾回收的优点和原理。并考虑2种回收机制。 我的答案: 动态回收 解释的很乱 网上答案: Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解, 它使得Java程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,Java中的对象不再有"作用域"的概念, 只有对象的引用才有"作用域"。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。 垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有 使用的对象进行清除和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。 回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。 28、你所知道的集合类都有哪些?区别?主要方法? 我的答案: Arraylist 非线性的、Vertor线性的 29、JSP的内置对象及方法。 我的答案: Page,exception,out,page content,application,request,reponse,session,config 30、页面间对象传递的方法。 我的答案: 那几个方法都写错了 31、你知道Request对象的主要方法有哪些? 32、J2EE是技术还是平台还是框架? 我的答案: J2EE是技术也是平台 网上答案: J2EE本身是一个标准,一个为企业分布式应用的开发提供的标准平台。 J2EE也是一个框架,包括JDBC、JNDI、RMI、JMS、EJB、JTA等技术。 33、我们在web应用开发过程中经常遇到输出某种编码的字符,如iso8859-1等,如何输出一个某种(例如GBK编码类型)编码的字符串? Request encording(“GBK”) 34、j2ee常用的设计模式?说明工厂模式。 Gof23种设计模式 工厂模式:Factory 网上答案: Java中的23种设计模式: Factory(工厂模式), Builder(建造模式), Factory Method(工厂方法模式), Prototype(原始模型模式),Singleton(单例模式), Facade(门面模式), Adapter(适配器模式), Bridge(桥梁模式), Composite(合成模式), Decorator(装饰模式), Flyweight(享元模式), Proxy(代理模式), Command(命令模式), Interpreter(解释器模式), Visitor(访问者模式), Iterator(迭代子模式), Mediator(调停者模式), Memento(备忘录模式), Observer(观察者模式), State(状态模式), Strategy(策略模式), Template Method(模板方法模式), Chain Of Responsibleity(责任链模式) 工厂模式:工厂模式是一种经常被使用到的模式,根据工厂模式实现的类可以根据提供的数据生成一组类中某一个类的实例, 通常这一组类有一个公共的抽象父类并且实现了相同的方法,但是这些方法针对不同的数据进行了不同的操作。 首先需要定义一个基类,该类的子类通过不同的方法实现了基类中的方法。 然后需要定义一个工厂类,工厂类可以根据条件生成不同的子类实例。 当得到子类的实例后,开发人员可以调用基类中的方法而不必考虑到底返回的是哪一个子类的实例。 35、JSP四种会话跟踪技术 我的答案: Application cookie session 36、排序都有哪几种方法?请举例 冒泡 选择 快序 二分查找 网上答案: 排序的方法有:插入排序(直接插入排序、希尔排序), 交换排序(冒泡排序、快速排序), 选择排序(直接选择排序、堆排序), 归并排序,分配排序(箱排序、基数排序) 快速排序的伪代码。 //使用快速排序方法对a[ 0 :n- 1 ]排序 从a[ 0 :n- 1 ]中选择一个元素作为m i d d l e,该元素为支点 把余下的元素分割为两段left 和r i g h t,使得l e f t中的元素都小于等于支点,而right 中的元素都大于等于支点 递归地使用快速排序方法对left 进行排序 递归地使用快速排序方法对right 进行排序 所得结果为l e f t + m i d d l e + r i g h t 37、关于模块间的设计原则? 规范要一样 38、项目过程一般是怎样的?你参加过几个项目开发?参加过的项目流程是怎样的?自己负责与人合作工作内容及自我评价? 从需求调研——设计开发——实施 参加过网站的实施 模板的制作 39、tomcat自动关闭常见原因? 我的答案: 现在没遇到过 40、如何设置TOMCAT内存和连接数? 我的答案: Tomcat群集 41、你如何理解Tomcat是什么? 我的答案: Tomcat是JSP Servlet 容器恰当的说 42、静态变量和实例变量的区别? 我的答案: 静态变量域用final修饰,每次都被调用 实例变量则不会 43、IE、FF下面CSS的解释区别 我的答案: 自己编的 44、web前端技术你了解哪些技术? 我的答案: JAVAScript,CSS,DIV,Ajax,Ajax框架,DWR,dojo,jguery 45、什么是报表?什么是报表控件,作用是什么?你了解哪些报表工具? 我的答案: 解释的很乱 46、你了解的那些统计图表类型? 我的答案: 自己编的 47、Flex与数据库连接的三种方式? 我的答案: 自己编的 ------------------------------------------------------- 我答错的、 错在哪里? 没答上的帮忙解答下? 感激了 !
单例模式中的DCL与Volatile
&nbsp;&nbsp;&nbsp; 在设计模式中,有用Double check lock来处理单例的经典模式。 <br />&nbsp;&nbsp;&nbsp; 但是我看了一些文章提到dcl失效的问题,主要是java2之前的版本,所以操作都是在主存储空间中执行,而对象创建操作又分为三部分:1.分配空间。2.复制对象。3.初始化对象。 这样多线程可能就会拿到尚未初始化完全的对象了。 <br />&nbsp;&nbsp;&nbsp; 而在java2之后,操作会先在工作存储空间中进行,完了之后才赋值给主存储空间(引用复制)。这样就不可能造成另一线程获取未完全初始化的对象了。不过单例对象中的属性和引用还可能会存在可见性的问题,所以使用volatile来进行修复。 <br />&nbsp;&nbsp;&nbsp; <br />&nbsp;&nbsp;&nbsp; 这里我有个疑问:volatile保证可见性是将操作直接放在主存储中进行,而不是在工作内存中操作,这样不是又变回了java2之前的工作模式了吗。那怎么样保证不会出现获取尚未初始化完全的对象呢?
Linux下Java程序多进程问题?
我们有一个Java项目是在linux下部署的。 <br />以前都没有发现什么问题,但是最近在某个客户Linux机器(RedHat4企业版)上运行java后出现了大量的java进程现象,而且很快就将内存耗尽了。 <br />查了相关资料,说是Java多线程在Linux环境下会采用多进程处理,但是也不至于每次都启动一个新的java进程吧,而且每次启动一个进程后都要耗掉不少内存。 <br /> <br />是不是Linux下需要修改什么配置? <br /> <br /> <br />谁能帮忙看下,谢谢~<br /><strong>问题补充:</strong><br />有没有什么办法让它不要启动那么多的进程?<br /><strong>问题补充:</strong><br />有没有什么办法让它不要启动那么多的进程?<br /><strong>问题补充:</strong><br />有没有办法不让它启动那么多的进程,太消耗资源了~<br /><strong>问题补充:</strong><br />也查了相关的一些资料。 <br />出现这种问题的资料都是很早以前的,说是跟Linux内核有关系,我查了,客户的Linux是2.6内核的,NPTL版本是2.3.4,照理应该不会有这样的问题。 <br /> <br />一楼说我创建了太多的线程,我在Redhat 4上面写了个创建线程的测试代码,Xmx500m的情况下到6000个线程,没有出现上述情况。 <br /> <br />真的是很头痛,不知是怎么回事? <br /> <br />现在连是什么问题都没有找到,只是在不停的试,就差换jre和操作系统了~ <br /> <br /><br /><strong>问题补充:</strong><br />活动线程: 336 <br />峰: 374 <br />守护线程: 60 <br />已启动的线程总数: 626 <br /> <br /> <br />当前类已装入: 9,007 <br />已装入类的总数: 9,044 <br />已卸载类的总数: 37 <br /> <br /> <br />当前堆大小: 129,259 Kb <br />堆大小的最大值: 986,112 Kb <br />分配的内存: 297,024 Kb <br /> <br /> <br />这是用jconsole观察的结果~ <br />线程一直保持在300-400之间~ <br /> <br />后台用:ps -ef|grep java <br />可以查看到有5个相同的进程存在 <br />CPU使用率比较高,保持在50%到90%之间~ <br /> <br />初步怀疑可能某个线程占用率很高或者请求阻塞了~ <br />线程列表里面看到有大量线程是http的~ <br /> <br />但是300-400的线程也不多吧~ <br /><br /><strong>问题补充:</strong><br />问题似乎已经找到了,还要在观察一下~ <br /> <br />初步估计是:Redhat 4与JRE1.6版本不兼容造成的,改用低版本的JRE1.5就OK了。 <br />真是比较郁闷,查了很久~ <br /> <br /> <br /> <br />谢谢各位的帮助~ <br />
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python 简易微信实现(注册登录+数据库存储+聊天+GUI+文件传输)
socket+tkinter详解+简易微信实现 历经多天的努力,查阅了许多大佬的博客后终于实现了一个简易的微信O(∩_∩)O~~ 简易数据库的实现 使用pands+CSV实现数据库框架搭建 import socket import threading from pandas import * import pymysql import csv # 创建DataFrame对象 # 存储用户数据的表(...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
开源并不是你认为的那些事
点击上方蓝字 关注我们开源之道导读所以 ————想要理清开源是什么?先要厘清开源不是什么,名正言顺是句中国的古代成语,概念本身的理解非常之重要。大部分生物多样性的起源,...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
相关热词 基于c#波形控件 c# 十进制转十六进制 对文件aes加密vc# c#读取栈中所有的值 c# rsa256加密 好 学c# 还是c++ c# 和java的差距 c# curl网络框架 c# https证书请求 c# 中崎
立即提问