网上淘宝2

本文介绍了 Java 开发工具包(JDK)1.5 中的一些关键新特性,包括泛型、For-Each 循环、自动装箱/拆箱、枚举、可变参数、静态导入等,这些特性显著提升了 Java 的开发效率和代码质量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

————————————————————————  JDK一些不为我熟知的特性:

   1.泛型(Generic)
  C++通过模板技术可以指定集合的元素类型,而Java在1.5之前一直没有相对应的功能。一个集合可以放任何类型的对象,相应地从集合里面拿对象的时候我们也不得不对他们进行强制得类型转换。猛虎引入了泛型,它允许指定集合里元素的类型,这样你可以得到强类型在编译时刻进行类型检查的好处。

2.For-Each循环
  For-Each循环得加入简化了集合的遍历。

3.自动装包/拆包(Autoboxing/unboxing)
  自动装包/拆包大大方便了基本类型数据和它们包装类地使用。
  自动装包:基本类型自动转为包装类.(int >> Integer)
  自动拆包:包装类自动转为基本类型.(Integer >> int)

4.枚举(Enums)
  JDK1.5加入了一个全新类型的“类”-枚举类型。为此JDK1.5引入了一个新关键字enmu. 我们可以这样来定义一个枚举类型。 
public enum Color
{
   Red,
   White,
   Blue
}

  然后可以这样来使用Color myColor = Color.Red.
  枚举类型还提供了两个有用的静态方法values()和valueOf(). 我们可以很方便地使用它们,例如
for (Color c : Color.values())
            System.out.println©;

  5.可变参数(Varargs)
  可变参数使程序员可以声明一个接受可变数目参数的方法。注意,可变参数必须是函数声明中的最后一个参数。假设我们要写一个简单的方法打印一些对象,
util.write(obj1);
util.write(obj1,obj2);
util.write(obj1,obj2,obj3);

  在JDK1.5之前,我们可以用重载来实现,但是这样就需要写很多的重载函数,显得不是很有效。如果使用可变参数的话我们只需要一个函数就行了
public void write(Object... objs) {
   for (Object obj: objs)
      System.out.println(obj);
}
  在引入可变参数以后,Java的反射包也更加方便使用了。对于c.getMethod("test", new Object[0]).invoke(c.newInstance(), new Object[0])),现在我们可以这样写了c.getMethod("test").invoke(c.newInstance()),这样的代码比原来清楚了很多。 

6.静态导入(Static Imports)
  要使用用静态成员(方法和变量)我们必须给出提供这个方法的类。使用静态导入可以使被导入类的所有静态变量和静态方法在当前类直接可见,使用这些静态成员无需再给出他们的类名。
import static java.lang.Math.*;
…….
r = sin(PI * 2); //无需再写r = Math.sin(Math.PI);
  不过,过度使用这个特性也会一定程度上降低代码地可读性。

——————————————————————小习题————————————

1、 求出1111!中有多少个1
2.     求16的10次方

        6的10次方 就是2的40次方,左移39位就可以了

 ————————

    求大数阶乘的算法:
算出结果后通过移位法计算int数组中每个int的1的个数, 并求和

 #include<stdlib.h>
#include<iostream.h>
#include<iomanip.h>

const int N=1000;

int compute(unsigned int *s,int n)//s用来存储一次的计算结果,n为本次计算的乘数,函数返回结果中有效数据的节数
{
    unsigned long p;  //暂时存放一节的结果
    unsigned long more=0;//一次乘法的进位
    int i;  //循环变量

    static int m=1;//存放结果中的节数,三位一节
    static int q=0;//存放结果中最后为零的节数

    //计算本次的结果
    for(i=q;i<m;i++)
    {
        p=(long)s[i]*(long)n+more;
        more=p/N;
        s[i]=p-more*N;
    }

    //计算结果中最后为零的节数
    while(s[q]==0) q++;

    //处理最高位
    for(more=p/N;more;)
    {
        p=more;
        more=p/N;
        s[i++]=p-more*N;
        m++;    //有效节数增一
    }

    return m;  //返回有效节数
}

void main()
{
    unsigned int *s; //存放结果
    int i;           //循环变量
    int m;             //存放节数
    int n;           //求n的阶乘

    cout<<"请输入一个正整数<0----10000>:";
    cin>>n;

    if(n<0)
    {
        cout<<"输入数据错误!"<<endl;
        return;
    }
    else if(n==0)
    {
        cout<<"0!==1"<<endl;
        return;
    }

    //初始化s
    s=(unsigned int *)malloc(n*sizeof(s)*10);
    for(i=1;i<n;i++) s[i]=0;
    s[0]=1;

    //计算结果
    for(i=2;i<=n;i++) m=compute(s,i);

    while(s[m]==0) m--;//过滤掉前面的零

    //输出结果
    cout<<n<<"!=="<<s[m--];//最高一节
   
    int num=1;
    for(i=m;i>=0;i--)
    {  
        num++;
        cout<<','<<setw(3)<<setfill('0')<<s[i];
        if((num%10)==0) cout<<endl;
    }
    cout<<endl;

    //释放空间
    free(s);
}

——————
// 1.求出1111!中有多少个1
// vs2008上通过

// Test5.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"

// a[0]存储个位,a[1]存储十位,a[2]……
int a[10000]={0};
int end=0; // 最后一位数字位置

int OneCount(void)
{
int i=0;
int count=0;
while(i <end){
if(a[i]==1)
count++;
i++;
}
return count;
}

void multi(int n)
{
for(int k=0;k <end;k++){ // 每一位独立相乘结果存入数组
a[k]*=n;
}
int x=0;
int y=0;
for(int k=0;k <end;k++){ // 进位
x=a[k]%10;
y=a[k]/10;
a[k]=x;
a[k+1]+=y;
}
int j=end;
do{
x=a[j]%10;
y=a[j]/10;
a[j]=x;
j++;
a[j]=y;
}while(y>0);
end=j;
}

int _tmain(int argc, _TCHAR* argv[])
{
for(int i=0;i <4;i++){ // a=1111
a[i]=1;
}
end=4;
for(int i=1110;i>1;i--){
multi(i);
}
int n=OneCount();
printf("count of '1' is %d/n",n);

// 下边用于测试求阶层对不对 2!=2,3!=6,4!=24,5!=120;6!=720;7!=5040;
//a[0]=7; // 7!=?
//end=1;
//for(int i=6;i>1;i--){
// multi(i);
//}
//for(int i=end;i>0;i--){
// printf("%d",a[i-1]);  // 5040
//}
return 0;
}
 

——————————————————————-关于项目开发——————————————————

   为了做出的东西符合用户要求,需要和用户沟通,并写出大概的项目计划让用户确认
需要根据项目计划和功能结构设计数据库表结构
采用最熟悉的技术迅速的搭建程序框架
开发的每一个阶段都需要和用户沟通,听取改进意见,并针对意见做有效的修改,修改的工作量要控制在有限时间内的同时还需要符合用户要求
整个程序开发完成需要给用户演示整个程序的使用方法,并可以给用户其他相关人员培训
要写出使用手册和培训PPT等文档
和用户负责人商讨验收事宜并验收
想办法让用户遵守他之前的承诺把奖金要回来


    在这个过程中学习到了什么呢?
 
开发一个软件所应该具备的全局观
对软件的开发效率和应用满足程度的权衡能力
软件技术掌握更全面,从数据库到界面几乎面面俱到
对用户想法的理解,并将用户需求转化成软件的能力
和用户沟通,从而挖掘用户真实想法的能力
方案的编写以及文档的编写能力
做培训的演讲能力
取得用户认可的谈判技巧

   没有独立生存的能力不能有最佳团队合作

————————————————————CVS    和    SVN——————————————————

    CVS是目前比较流行与优秀的版本管理与控制工具,是用来管理其它日常文档(如word工作文档之类)的一个强有力的工具。WinCVS是CVS的一个客户端软件,它运行在Windows上,采用图形化方式登陆CVS服务器和CVS相关的操作与管理,不要学习复杂的cvs命令。企业内部都采用Linux/Unix做服务器,用Windows做客户端,所以WinCVS与CVS服务器是目前应用最广泛的版本控制与管理的组合。

  cvsnt是现在能在windows、mac os x、linux、solaris和hpux上运行的,被广泛支持的,富有特色和安全的cvs服务器和客户端。经过多年的不断开发、测试和产品发布, cvsnt得到持续的推进。cvsnt是开放源码的自由软件,基于gnu的gpl许可证。

  Subversion是新一代的版本控制工具,不仅可以管理程序源代码,也可以应用于其他协作管理数据的工作,例如使用Subversion来合作写乐谱,美工用来共同作图……看SVN的手册,说设计它是为了取代CVS……最主要的一点:它是开源免费的,并且有详细的使用手册。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值