7.11

从逻辑角度来看:( 重要区别

多线程的意义在于一个应用程序中,有多个执行部分可以同时执行。但是,操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理及资源分配。

4、函数调用入栈出栈的过程

        函数调用过程中,第一个进栈的是(主函数中的)调用处的下一条指令(即函数调用语句的下一条可执行语句)的地址;然后是函数的各个参数,而在大多数C/C++编译器中,在函数调用的过程中,函数的参数是由右向左入栈的;然后是函数内部的局部变量(注意static变量是不入栈的);在函数调用结束(函数运行结束)后,局部变量最先出栈,然后是参数,最后栈顶指针指向最开始存的指令地址,程序由该点继续运行。

3、为什么要声明为虚函数?    
简单的说就是在实现多态时,如定义了一个指向派生类的基类指针,当delete该基类指针时,如果不将基类的析构函数声明为虚,只会调用基类的析构函数,而不会调用派生类的析构函数,为了保证同时调用派生类的析构函数,需要将析构函数声明为虚。                    

如果不需要基类对派生类及对象进行操作,则不能定义虚函数,因为这样会增加内存开销.当类里面有定义虚函数的时候,编译器会给类添加一个虚函数表,里面来存放虚函数指针,这样就会增加类的存储空间.所以,只有当一个类被用来作为基类的时候,才把析构函数写成虚函数.

2、inline 和#define的如何定义MAX ,区别是什么。
         define成为“宏”,它在程序编译时只是在预处理的过程中实施简单的替换操作而已,但是在替换过程中可能出现各种不安全性问题,不进行参数有效性检查。1宏不能访问对象的私有成员。2、.宏的定义很容易产生二意性。
         内联函数和普通函数相比可以加快程序的运行速度,但它是以增加程序存储空间为代价的,由于不需要中断调用,在编译内联函数的时候内联函数可以直接被嵌入目标代码中。对于短小的代码,inline可以带来一定效率的提升,且与C时代的define(宏)相比,它更安全可靠。

宏和内联函数的主要区别如下:
    1. 宏是代码处不加任何验证的简单替代,而内联函数是将代码直接插入调用处,而减少了普通函数调用时的资源消耗。
    2. 宏不是函数,只是在编译前预处理阶段将程序中有关字符串替换成宏体。
    3. inline是函数,但在编译中不单独产生代码,而是将有关代码嵌入到调用处。
总结如下:
    对于一般常量,最好用const和enum替换#define;

    对于类似函数的宏,最好改用inline函数替换#define。

7.        使用const的一些建议 
1 要大胆的使用const,这将给你带来无尽的益处,但前提是你必须搞清楚原委; 
2 要避免最一般的赋值操作错误,如将const变量赋值,具体可见思考题; 
3 在参数中使用const应该使用引用或指针,而不是一般的对象实例,原因同上; 
4 const在成员函数中的三种用法(参数、返回值、函数)要很好的使用; 
5 不要轻易的将函数的返回值类型定为const; 

6除了重载操作符外一般不要将返回值类型定为对某个对象的const引用;

在几千条记录里,存在着些相同的记录,如何能用SQL语句,删除掉重复的呢
1、查找表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断 
select * from people 
where peopleId in (select peopleId from people group by peopleId having count(peopleId) > 1) 


2、删除表中多余的重复记录,重复记录是根据单个字段(peopleId)来判断,只留有rowid最小的记录 
delete from people 
where   peopleName in (select peopleName    from people group by peopleName      having count(peopleName) > 1) 
and   peopleId not in (select min(peopleId) from people group by peopleName     having count(peopleName)>1) 


3、查找表中多余的重复记录(多个字段) 
select * from vitae a 
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1) 


4、删除表中多余的重复记录(多个字段),只留有rowid最小的记录 
delete from vitae a 
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1) 
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1) 


5、查找表中多余的重复记录(多个字段),不包含rowid最小的记录 
select * from vitae a 
where (a.peopleId,a.seq) in (select peopleId,seq from vitae group by peopleId,seq having count(*) > 1) 
and rowid not in (select min(rowid) from vitae group by peopleId,seq having count(*)>1)   


6.消除一个字段的左边的第一位:


update tableName set [Title]=Right([Title],(len([Title])-1)) where Title like '村%'


7.消除一个字段的右边的第一位:


update tableName set [Title]=left([Title],(len([Title])-1)) where Title like '%村'


8.假删除表中多余的重复记录(多个字段),不包含rowid最小的记录 
update vitae set ispass=-1

where peopleId in (select peopleId from vitae group by peopleId

  source 是内置命令,用途是读取文件中的内容,并在当前shell中逐条执行。这种方式执行的脚本无须执行权限。source命令可以缩写为一个小数点



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值