当前位置: 首页 > news >正文

日期类的实现

文章目录

  • 1. 日期类的具体实现
    • 1.查询当前月份的天数
    • 2. 构造函数的实现(注意)
    • 3.d1==d2
    • 4. d1!=d2
    • 5. d1<d2
    • 6. d1<=d2
    • 7. d1>d2
    • 8. d1>=d2
    • 9. 日期+=天数
    • 10.日期+天数
    • 11.日期-=天数
    • 12. 日期-天数
    • 13. ++d和 d++
    • 14. --d 和 d--
    • 15.日期=日期 返回天数
  • 2. 函数的声明——date.h
  • 3. 函数的定义——date.cpp
  • 4.函数调用——main.cpp

由于拆分了函数的声明和定义,所以在函数前面要加上date类,找到函数

1. 日期类的具体实现

1.查询当前月份的天数

int date::getmonthday(int year, int month)
{int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0) )){//是闰年并且是2月份return 29;}return arr[month];
}
  • 设置一个数组,下标对应月份,并把2月闰年的情况单拉出来

2. 构造函数的实现(注意)

date::date(int year, int month, int day)
{//判断日期是否合法if ( month>0 && month < 13 && ( day>0&&day<=getmonthday(year,month) )  ){_year = year;_month = month;_day = day;}else{cout << "日期不合法" << endl;}
}
  • 一定要注意日期传过来是否合法存在

3.d1==d2

bool date::operator==(const date& d)
{return (_year == d._year) && (_month == d._month) && (_day == d._day);
}
  • 判断 年 月 日依次是否相等

4. d1!=d2

bool date::operator!=(const date & d)
{return !(*this == d);//复用d1==d2的相反逻辑
}

如果我们再次自己写就会有很多情况考虑,所以直接复用 d1==d2的取反

5. d1<d2

bool date::operator<(const date& d)
{if (_year < d._year)//年小为小{return true;}else if (_year == d._year && _month < d._month)//年相等 月小为小{return true;}else if (_year == d._year && _month == d._month && _day < d._day)// 年月相等 天小为小{return true;}else{return false;}
}

年小的为小,
年相等,月小为小
年 月相等,天小为小
其他情况都为false

6. d1<=d2

bool date::operator<=(const date& d)
{return (* this < d) || (*this == d);//复用 d1<d2 和d1==d2的情况
}

d1<=d2是由 d1==d2 和d1<d2 组成,分别复用两者即可实现

7. d1>d2

bool date::operator>(const date& d)
{return !(*this < d) && (*this != d);//复用 d1<d2的逻辑反 以及d1!=d2
}

d1>d2的逻辑取反是 d1<=d2 ,由于d1<d2我们已经实现过了,只需要加上d1!=d2即可

8. d1>=d2

bool date::operator>=(const date& d)
{return !(* this < d);//复用d1<d2的逻辑反 
}

复用d1<d2的逻辑取反即可实现 d1>=d2

9. 日期+=天数

date& date::operator+=(int day)
{if (day < 0)//+= -等价于 -={*this -= -day;//复用-=return *this;}//由于是+=改变本身,所以返回*thisint getday = _day + day;//判断当前加上的天数是否大于当前月份的天数while (getday > getmonthday(_year, _month)){getday -= getmonthday(_year, _month);_month++;if (_month == 13){_year++;_month = 1;}}//最后注意剩余的getday就为当前月份的天数_day = getday;//除了作用域 *this 还在所以可以使用引用返回return *this;
}

当day为负时,+= - 等价于-= ,所以调用-=的复用即可(-=实现在后面)
同样由于+=是对于本身操作,除了作用域还存在,所以使用引用返回

10.日期+天数

date date::operator+(int day)
{//注释的为第一种方法//由于不改变日期本身,所以用一个临时变量代替//date ret = *this;//int getday = ret._day + day;判断当前加上的天数是否大于当前月份的天数//while (getday > getmonthday(ret._year, ret._month))//{//	getday -= getmonthday(ret._year, ret._month);//	ret._month++;//	if (ret._month == 13)//	{//		ret._year++;//		ret._month = 1;//	}//}最后注意剩余的getday就为当前月份的天数//ret._day = getday;除了作用域 ret不在了,所以使用传值返回//return ret;//方法二date tmp = *this;tmp += day;return tmp;//复用 日期+=天数的功能
}

这里用了两种方法实现,但是可以发现第一种过于繁琐,只需复用上述+=,返回临时变量tmp即可
同样由于临时变量出了作用域就不存在了,所以使用传值返回

11.日期-=天数

date& date::operator-=(int day)
{if (day < 0){*this += -day;//复用+=return *this;}_day -= day;//当day 小于 当前月份的天数 直接return//当 day大于等于 当前月份的天数 进入循环while (_day <= 0){//返回到上一个月份_month--;//当月份为1时 --为0if (_month == 0){_year--;_month = 12;}_day += getmonthday(_year, _month);}return *this;
}

这里不太好想,如果当前日期月份的天数_day大于day,则直接return,若小于则会使_day为负进入循环,同时向上一个月借天数直到 _day<=0
若day为负,-=-等价于+= ,直接复用+=即可

12. 日期-天数

date date::operator-(int day)
{date ret = *this;ret -= day;return ret;
}

复用上面的-=即可,返回临时变量ret

13. ++d和 d++

date& date::operator++()//++d
{*this += 1;//复用+=return *this;
}
  • 前置++是正常调用operator++,并且返回本身,因为除了作用域还存在,所以用引用返回
date date::operator++(int)//d++
{date ret = *this;*this += 1;//复用+=return ret;
}

后置++因为同样是operator++,为了区分所以加上参数int(用于占位没有实际作用),构成函数重载
因为返回临时变量ret,所以用传值返回

14. --d 和 d–

date& date::operator--()//--d
{*this -= 1;//复用-=return *this;
}
  • 前置- -是正常调用operator- -,并且返回本身,因为除了作用域还存在,所以用引用返回
date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}

后置- -因为同样是operator- -,为了区分所以加上参数int(用于占位没有实际作用),构成函数重载
因为返回临时变量ret,所以用传值返回

15.日期=日期 返回天数


date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}int date::operator-(date& d){date max = *this;date min = d;if (*this < d)//复用<{max = d;min = *this;}int n = 0;while (min != max)//复用!={n++;if (min._day < getmonthday(min._year, min._month)){min._day++;}else{min._month++;min._day = 1;}if (min._month == 13){min._year++;min._month = 1;}}return n;}

主要使用max和min两个临时变量,使min._day不断++,最终使max==min 结束返回计数n值

2. 函数的声明——date.h

#include<iostream>
using namespace std;
class date
{
public://函数声明int getmonthday(int year, int month);//查询当前月份的天数date(int year=1, int month=1, int day=1);//构造void print();//输出bool operator==(const date& d);//d1==d2bool operator!=(const date& d);//d1!=d2bool operator<(const date& d);//d1<d2bool operator<=(const date& d);//d1<=d2bool operator>(const date& d);//d1>d2bool operator>=(const date& d);//d1>=d2date operator+(int day);//日期+天数date& operator+=(int day);//日期+=天数date operator-(int day);//日期-天数date& operator-=(int day);//日期-=天数date& operator++();//++d//int 参数仅是为了占位,构成函数重载 区分前置date operator++(int);//d++date& operator--();   //--ddate operator--(int);//d--int  operator-( date& d);//日期-日期 返回天数
private:int _year;int _month;int _day;
};

3. 函数的定义——date.cpp

#include"date.h"
//函数实现
int date::getmonthday(int year, int month)
{int arr[13] = { 0,31,28,31,30,31,30,31,31,30,31,30,31 };if (month == 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0) )){//是闰年并且是2月份return 29;}return arr[month];
}
date::date(int year, int month, int day)
{//判断日期是否合法if ( month>0 && month < 13 && ( day>0&&day<=getmonthday(year,month) )  ){_year = year;_month = month;_day = day;}else{cout << "日期不合法" << endl;}}
void date::print()
{cout << _year << "-" << _month << "-" << _day << endl;
}
bool date::operator==(const date& d)
{return (_year == d._year) && (_month == d._month) && (_day == d._day);
}
bool date::operator!=(const date & d)
{return !(*this == d);//复用d1==d2的相反逻辑
}
bool date::operator<(const date& d)
{if (_year < d._year)//年小为小{return true;}else if (_year == d._year && _month < d._month)//年相等 月小为小{return true;}else if (_year == d._year && _month == d._month && _day < d._day)// 年月相等 天小为小{return true;}else{return false;}
}
bool date::operator<=(const date& d)
{return (* this < d) || (*this == d);//复用 d1<d2 和d1==d2的情况
}
bool date::operator>(const date& d)
{return !(*this < d) && (*this != d);//复用 d1<d2的逻辑反 以及d1!=d2
}
bool date::operator>=(const date& d)
{return !(* this < d);//复用d1<d2的逻辑反 
}date& date::operator+=(int day)
{if (day < 0)//+= -等价于 -={*this -= -day;//复用-=return *this;}//由于是+=改变本身,所以返回*thisint getday = _day + day;//判断当前加上的天数是否大于当前月份的天数while (getday > getmonthday(_year, _month)){getday -= getmonthday(_year, _month);_month++;if (_month == 13){_year++;_month = 1;}}//最后注意剩余的getday就为当前月份的天数_day = getday;//除了作用域 *this 还在所以可以使用引用返回return *this;
}
date date::operator+(int day)
{由于不改变日期本身,所以用一个临时变量代替//date ret = *this;//int getday = ret._day + day;判断当前加上的天数是否大于当前月份的天数//while (getday > getmonthday(ret._year, ret._month))//{//	getday -= getmonthday(ret._year, ret._month);//	ret._month++;//	if (ret._month == 13)//	{//		ret._year++;//		ret._month = 1;//	}//}最后注意剩余的getday就为当前月份的天数//ret._day = getday;除了作用域 ret不在了,所以使用传值返回//return ret;date tmp = *this;tmp += day;return tmp;//复用 日期+=天数的功能
}date& date::operator-=(int day)
{if (day < 0){*this += -day;//复用+=return *this;	}_day -= day;//当day 小于 当前月份的天数 直接return//当 day大于等于 当前月份的天数 进入循环while (_day <= 0){//返回到上一个月份_month--;//当月份为1时 --为0if (_month == 0){_year--;_month = 12;}_day += getmonthday(_year, _month);}return *this;
}
date date::operator-(int day)
{date ret = *this;ret -= day;return ret;
}
date& date::operator++()//++d
{*this += 1;return *this;
}
date date::operator++(int)//d++
{date ret = *this;*this += 1;return ret;
}date& date::operator--()//--d
{*this -= 1;//复用-=return *this;
}date date::operator--(int)//d--
{date ret = *this;*this -= 1;//复用-=return ret;
}int date::operator-(date& d){date max = *this;date min = d;if (*this < d){max = d;min = *this;}int n = 0;while (min != max){n++;if (min._day < getmonthday(min._year, min._month)){min._day++;}else{min._month++;min._day = 1;}if (min._month == 13){min._year++;min._month = 1;}}return n;}

4.函数调用——main.cpp

#include"date.h"
int main()
{date d1(2023, 2, 9);date d2(2023, 2, 1);cout << (d1==d2) << endl;cout << (d1 < d2) << endl;cout << (d1 - d2) << endl;return 0;
}

相关文章:

日期类的实现

文章目录1. 日期类的具体实现1.查询当前月份的天数2. 构造函数的实现(注意)3.d1d24. d1!d25. d1<d26. d1<d27. d1>d28. d1>d29. 日期天数10.日期天数11.日期-天数12. 日期-天数13. d和 d14. --d 和 d--15.日期日期 返回天数2. 函数的声明——date.h3. 函数的定义—…...

2022年这5款熟悉的软件退出了历史舞台

在过去的一年里&#xff0c;有很多新产品发布&#xff0c;当然也有很多产品与我们就此别过。这些产品曾陪伴我们的生活&#xff0c;给我们带来欢乐&#xff0c;帮助我们成长。所以本文将盘点一下在2022年和我们告别的产品。1.微软IE浏览器IE浏览器1995年8月16日正式上线&#x…...

用Nginx打包部署vue3项目及404和500解决

打包vue3 npm run build安装Nginx 这里安装步骤比较繁琐&#xff0c;现在服务器比较便宜&#xff0c;如果想用Nginx&#xff0c;可以去菜鸟教程https://www.runoob.com/linux/nginx-install-setup.html 配置安装一下找到安装路径下的 conf 文件夹 下 nginx.conf文件&#xff0…...

Java面试——多线程并发篇

✅作者简介&#xff1a;2022年博客新星 第八。热爱国学的Java后端开发者&#xff0c;修心和技术同步精进。 &#x1f34e;个人主页&#xff1a;Java Fans的博客 &#x1f34a;个人信条&#xff1a;不迁怒&#xff0c;不贰过。小知识&#xff0c;大智慧。 &#x1f49e;当前专栏…...

维基百科数据抽取

1. 数据路径 https://dumps.wikimedia.org/enwiki/latest/ ----英文 https://dumps.wikimedia.org/zhwiki/latest/ ----中文 https://dumps.wikimedia.org/enwiki/latest/enwiki-latest-pages-articles.xml.bz2 --下载最新的 https://dumps.wikimedia.org/wikidatawiki/2023…...

2020年因果推断综述《A Survey on Causal Inference》

最近阅读了TKDD2020年的《A Survey on Causal Inference》&#xff0c;传送门&#xff0c;自己对文章按照顺序做了整理&#xff0c;同时对优秀的内容进行融合&#xff0c;如有不当之处&#xff0c;请多多指教。 文章对因果推理方法进行了全面的回顾&#xff0c;根据传统因果框…...

嵌入式linux系统测试程序编写

文章目录 网络CPU load监测性能设定开源测试工具iozone —— 文件系统测试工具iperf —— 网络性能测试工具LMbench —— 系统性能评测LTP —— linux功能/性能压力测试memtester —— 内存测试,坏位检测stressapptest —— 内存流量压力测试stream —— 内存性能测试fio ——…...

力扣SQL刷题5

目录597. 好友申请 I&#xff1a;总体通过率602. 好友申请 II &#xff1a;谁有最多的好友603. 连续空余座位1045. 买下所有产品的客户597. 好友申请 I&#xff1a;总体通过率 官方讲的题目太繁琐了&#xff0c;大概就是&#xff08;表2中列1列2不全相同的行数&#xff09;/&a…...

动态规划详解(完结篇)——如何抽象出动态规划算法?以及解题思路

今天直接开始讲解FIRST&#xff1a;如何抽象出动态规划算法&#xff1f;这个问题&#xff0c;困扰了无数代OIER&#xff0c;包括本蒟蒻在比赛的时候&#xff0c;看一道题&#xff0c;怎么想到他是什么算法的呢&#xff1f;这就需要抽象能力而不同的算法&#xff0c;往往有着不同…...

C语言一维数组篇【下】——每日刷题经验分享

一维数组篇——每日刷题经验分享~&#x1f60e;前言&#x1f64c;有序序列插入一个整数 &#x1f60a;序列中删除指定数字 &#x1f60a;序列中整数去重小乐乐查找数字筛选法求素数总结撒花&#x1f49e;&#x1f60e;博客昵称&#xff1a;博客小梦~ &#x1f60a;最喜欢的座右…...

VHDL语言基础-组合逻辑电路-其它组合逻辑模块

目录 多路选择器&#xff1a; 逻辑功能&#xff1a; 常用的类型&#xff1a; 4选1多路选择器的实现&#xff1a; 求补器&#xff1a; 求补器的实现&#xff1a; 三态门&#xff1a; 三态门的应用实例&#xff1a; 三态门的实现&#xff1a; 缓冲器&#xff1a; 什么是…...

初识Vue

文章目录1. 前言2. Vue 的特点3. 安装 Vue4. HelloWord1. 前言 vue是什么 &#xff1f; 引用 &#xff1a; vue.js 文档   Vue (读音 /vjuː/&#xff0c;类似于 view) 是一套用于构建用户界面的渐进式框架。与其它大型框架不同的是&#xff0c;Vue 被设计为可以自底向上逐层…...

TOUGH系列软件建模实践方法及在地下水、CO2地质封存、水文地球化学、地热等多相多组分系统多过程耦合

查看原文>>> https://mp.weixin.qq.com/s?__bizMzAxNzcxMzc5MQ&mid2247578057&idx7&sn75f8d2c1c6edb28af76a8db4bb773de3&chksm9be2aed9ac9527cf0081082cdcf781e6c37f9f3ba383332ed1116abcbee0f05c0593187e964d&token2070450548&langzh_CN#r…...

Codeforces Round #699 (Div. 2)

E. 题意:n本书,每本书有颜色a[i],一次操作可以将其中一本书放在末尾,求满足:相同颜色的书都是相邻的 的最小操作次数. 显然最多只需要n次,考虑能节省多少次.倒着考虑,记f[i]为i~n最多能节约的次数.先预处理出每种颜色的出现的位置范围l[i],r[i]. 1.不节约这本书f[i] f[i 1]…...

MySQL存储过程的传参和流程控制

目录 一.存储过程传参—in 演示 二.存储过程传参—out 演示 三.存储过程传参—inout 演示 四.流程控制—判断 格式 演示 五.流程控制—case 语法 演示 六.流程控制—循环 循环—while 循环—repeat 循环—loop 一.存储过程传参—in in表示传入的参数&#xff0c;可以传…...

MySQl学习(从入门到精通11)

MySQl学习&#xff08;从入门到精通11&#xff09;第 14 章_视图1. 常见的数据库对象2. 视图概述2. 1 为什么使用视图&#xff1f;2. 2 视图的理解3. 创建视图3. 1 创建单表视图3. 2 创建多表联合视图3. 3 基于视图创建视图4. 查看视图5. 更新视图的数据5. 1 一般情况5. 2 不可…...

关于ThreadLocal

弱引用 1.1 java中的各种引用和测试: https://blog.csdn.net/thewindkee/article/details/102723838 1.2 treadlocal中的弱引用测试: https://blog.csdn.net/thewindkee/article/details/103726942 (这篇很重要) 内存泄露: https://zhuanlan.zhihu.com/p/523628871 综合考虑 …...

【C++】类和对象(中)

文章目录1. 类的6个默认成员函数2. 构造函数概念特性3. 析构函数概念特性4. 拷贝构造函数概念特征5. 运算符重载5.1 前置和后置重载5.2 赋值运算符重载6. 日期类的实现7. const成员8. 取地址及const取地址操作符重载1. 类的6个默认成员函数 如果一个类中什么成员都没有&#x…...

js下载文件

url为文件的src地址 url必须符合同源策略或者url的接口地址允许跨域&#xff0c;否则浏览器会报跨域错误 axios.get(data.url ,{ responseType: ‘blob’, }) .then( response>{ let blob new Blob([response.data]); let url window.URL.createObjectURL(blob); // 创建 …...

ESP8266 + STC15+ I2C OLED带网络校时功能的定时器时钟

ESP8266 + STC15+ I2C OLED带网络校时功能的定时器时钟 📍相关篇《ESP8266 + STC15基于AT指令通过TCP通讯协议获取时间》 📌ESP8266 AT固件基于安信可AT固件,相关刷AT固件可以参考《NodeMCU-刷写AT固件》 🔖STC15 单片机采用的是:STC15F2K60S2 晶振频率采用内部:22.11…...

计算机入门基础知识大全

♥️作者&#xff1a;小刘在C站 ♥️个人主页&#xff1a;小刘主页 ♥️每天分享云计算网络运维课堂笔记&#xff0c;努力不一定有收获&#xff0c;但一定会有收获加油&#xff01;一起努力&#xff0c;共赴美好人生&#xff01; ♥️夕阳下&#xff0c;是最美的&#xff0c;绽…...

Python程序出现错误怎么办?

Python 异常处理 python提供了两个非常重要的功能来处理python程序在运行中出现的异常和错误。你可以使用该功能来调试python程序。 异常处理: 本站Python教程会具体介绍。 断言(Assertions):本站Python教程会具体介绍。 python标准异常 异常名称 描述 BaseException 所有异常…...

【Vue3】v-if和v-for优先级

&#x1f388;博客主页&#xff1a;&#x1f308;我的主页&#x1f308; &#x1f388;欢迎点赞 &#x1f44d; 收藏 &#x1f31f;留言 &#x1f4dd; 欢迎讨论&#xff01;&#x1f44f; &#x1f388;本文由 【泠青沼~】 原创&#xff0c;首发于 CSDN&#x1f6a9;&#x1f…...

Windows上实现 IOS 自动化测试

本文介绍如何使用tideviceWDAairtest/facebook-wda实现在Windows上进行IOS APP自动化测试 环境准备 Windows Python环境 Python 3.6 WebDriverAgent安装 下载最新的项目到Mac&#xff1a;https://github.com/appium/WebDriverAgent $ git clone https://github.com/appiu…...

Linux云服务器下怎么重置MySQL8.0数据库密码

文章目录一、修改my.cnf配置文件为mysql免登陆二、免密登陆mysql三.给root用户重置密码1、首先查看当前root用户相关信息&#xff0c;在mysql数据库的user表中2、把root密码置为空3、退出mysql&#xff0c;删除/etc/my.cnf文件中添加进去的skip-grant-tables 重启mysql服务4、使…...

JVM调优

JVM调优-VisualVmVisualVm/ Jconsule远程连接第一种方式第二种方式&#xff1a;java 11开启远程GC连接如果还连不上考虑防火墙拦截了端口firewall-cmd --list-all,查看一下并暴露对应端口连接配置VisualVm界面简介采集GC信息的一些命令垃圾回收器切换VisualVm/ Jconsule远程连接…...

【配电网规划】SOCPR和基于线性离散最优潮流(OPF)模型的配电网规划( DNP )(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…...

锦正茂EM3电磁铁的技术参数

产品特点&#xff1a; ※U形结构、视野开阔、磁场强度高、磁场强度大小调节方便 ※体积小、重量轻、占空比小、结构紧凑、磁场性能更佳 ※电磁铁的工作气隙调节轻便灵活&#xff0c;极头处设有螺纹&#xff0c;更换极头装卸方便 ※可选配工作间隙刻度指示 ※小气隙时用于铁…...

Go最新版下载 Go1.20版新特性

Go官方正式发布了Go1.20稳定版 该版本依然保持 Go1 兼容性&#xff0c;可以升级到 Go1.20&#xff0c;而不需要做任何代码改动。 可以使用你任何喜欢的方式升级&#xff1a; 比如&#xff1a; go install golang.org/dl/go1.20latest 具体的可以参考官网教程&#xff1a; ht…...

Pywirt:一款基于Python的Windows安全应急响应工具

关于Pywirt Pywirt是一款基于Python开发的网络安全工具&#xff0c;该工具专门针对Windows操作系统设计&#xff0c;可以帮助广大研究人员使用winrm并通过在Windows操作系统上收集各种信息来加快安全事件应急响应的速度。 该工具已在Windows 10操作系统上进行过完整测试。 功…...

一键网站提交/seo 优化是什么

题目.用两个栈实现一个队列。队列的声明如下,请实现它的两个函数appendTail和deleteHead 分别完成在对尾插入节点和在队头删除节点。 该队列类模板如下: 1 template <typename T>2 class CQueue3 {4 public:5 void appendTail(const T& node);6 T deleteHead…...

网站seo优化/免费培训课程

文本文件操作读写文件在Python中&#xff0c;不必要调用外部的library用于读写文件。Python提供了内置的功能&#xff0c;能够创建、读写文件。内置功能 open()为了打开文件&#xff0c;需要使用内置的 open 功能。Open 功能返回一个文件对象&#xff0c;这个对象包含了多种 方…...

阳江网签/百度seo如何优化

前面简单地了解了一下IdleStateHandler&#xff0c;我们现在写一个简单的心跳demo&#xff1a; 1&#xff09;服务器端每隔5秒检测服务器端的读超时&#xff0c;如果5秒没有接受到客户端的写请求&#xff0c;也就说服务器端5秒没有收到读事件&#xff0c;则视为一次超时 2&…...

网站首页滚动图怎么做/抖音seo排名优化公司

第十三周 所花时间&#xff08;包括上课&#xff09; 9小时&#xff08;上课7小时&#xff09; 代码量&#xff08;行&#xff09; 360 博客量&#xff08;篇&#xff09; 3 了解到的知识点 数据库连接的复习&#xff0c;以及对增删改查的复习 转载于:https://www.cnbl…...

wordpress文章指定数量/上海优化外包

当前位置:我的异常网 Java Web开发 插入数据库错误插入数据库错误www.myexceptions.net 网友分享于&#xff1a;2013-08-03 浏览&#xff1a;6次插入数据库异常往mysql里面的表里插数据&#xff0c;表里的字段见下面定义的这一片&#xff0c;下面的代码是往数据库里插得jsp&…...

微信上wordpress/seo就业

SVG剪裁路径和遮罩jQuery幻灯片是一款基于SVG clipPath和mask遮罩元素实现的网站动画幻灯片代码特效。在线演示本地下载转载于:https://www.cnblogs.com/wwhhq/p/8283759.html...