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

C++入门(有C语言基础)

string类

  1. string类初始化的方式大概有以下几种:
    string str1;string str2 = "hello str2";string str3("hello str3");string str4(5, 'B');string str5[3] = {"Xiaomi", "BYD", "XPeng"};string str6 = str5[2];str1 = "nihao str1";
  1. 通过size()length() 函数可以获取字符串的长度:
	// 获取长度,不会包含'\0'cout << str1.size() << endl;cout << str1.length() << endl;cout << str4.size() << endl;cout << str5[0].size() << endl;
  1. 两种访问字符的方式:通过 [] 运算符或 at() 方法来访问字符串中的某个字符。at() 具有边界检查,如果访问越界会抛出异常,而 [] 不会做边界检查[]导致的越界会产生未定义行为,越界后会访问到其他地址,系统不会报错;at()只要一越界就要抛出错误,程序终止。一个string占32个字节。
    cout << str2[7] << endl;cout << str2.at(7) << endl;cout << str5[0][2] << endl;cout << str5[0].at(2) << endl;
  1. 拼接字符串:
#include <stdio.h>
#include <iostream>
using namespace std;
int main(int argc, char const *argv[])
{string str1 = "成长是永远";string str2 = "离别是空悬";cout << str1 + str2 << endl;return 0;
}
  1. 比较字符串:可以直接使用 ==, !=, <, >, <=, >= 来比较两个字符串的字典顺序。对应ASCII码值大的就大,逻辑表达式为真返回1,为假返回0.
	string str1 = "abc";string str2 = "xyz";cout << (str1 <= str2) << endl;
  1. 子字符串提取:substr() 函数用于提取子字符串。它接受两个参数:起始索引和长度(可选)
    string str1 = "abcdefghijkl";string str2 = str1.substr(1, 10);cout << str2 << endl;
  1. 插入删除和替换操作:
string str1 = "hello"; 
str1.insert(5, " world");// 表示在第5个字符后插入字符串string str1 = "hello world";
str1.erase(5, 3);  // 删除第5个字符之后的3个字符string str1 = "hello world";
str1.replace(5, 6, "C++"); // 从第5个字符后开始替换,替换6个字符,替换为“C++”
  1. 查找字符串:find() 函数可以查找子字符串或字符的第一个出现位置,如果没有找到,find() 会返回 std::string::npos,这里因为我开头用了using namespace std;,所以不需要再用std::声明
	string str1 = "hello world";if (str1.find("world") != string::npos){cout << "I find it" << endl;}else{cout << "I can't find it" << endl;}
  1. C++风格字符串与C风格字符串转换:
	// `std::string` 转换为C风格字符串(`const char*`)string str1 = "hello world";const char *str2 = str1.c_str();cout << str2 << endl;// C风格字符串转换为 `std::string`const char *str1 = "hello world";string str2(str1);cout << str2 << endl;
  1. 内存管理:string会自动处理内存分配和释放,不需要手动管理内存。string通过深拷贝的方式处理赋值操作,确保每个字符串对象都有自己独立的内存。
  2. 什么是深拷贝?什么是浅拷贝?
    • 深拷贝:深拷贝是在拷贝的时候将内容申请内存,重新拷贝一份,放到内存中,指针指向这个新拷贝的部分,这样就不会出现析构的时候重复释放的问题了。
    • 浅拷贝:浅拷贝就是增加了一个指向相同堆区的指针,这将导致在析构的时候会重复释放。默认的拷贝构造和运算符重载都是浅拷贝。
  3. 什么是析构:析构(Destructor)是一个特殊的成员函数,用于在对象生命周期结束时清理资源并执行必要的清理工作。析构函数的主要目的包括释放对象在其生命周期内分配的动态内存、关闭文件句柄、释放网络连接等。简单理解就是清理资源的成员函数。

函数

  1. 函数可以设置默认参数,如果调用时不传入参数则使用默认参数值:
void nameCountry(string name = "China")
{cout << name << endl;
}
  1. 指针传递和引用传递:
    1. 指针传递在C语言和C++中都能使用,指针传递是通过传递变量的地址来间接修改变量的值。
    2. 引用传递,只能在C++中使用。如下第一种函数就是引用传递。即直接操作传入的变量的引用,传递给函数时,函数内部对引用变量的修改会直接反映到原始变量上。
void swap(int &a, int &b)
{int temp = a;a = b;b = temp;
}void swap(int *a, int *b)
{int temp = *a;*a = *b;*b = temp;
}
  1. 函数的重载:是一种允许在同一个作用域内定义多个具有相同名字但参数列表不同的函数的特性。
    1. 重载规则:
      1. 参数的类型不同
      2. 参数的个数不同
      3. 参数的顺序不同
    2. 不允许重载的情况:
      1. 仅有返回值不同(函数的返回类型不能作为函数重载的依据)
      2. 函数使用默认参数时,可能会导致重载冲突(默认参数的存在导致二义性)
    3. const 修饰符可以参与函数重载。
    4. 数组和指针的重载:数组类型会退化为指针。(在 C语言 中,数组作为函数参数时也会 退化为指针。)
// 原始参照  
int funcPlus(int x, double y)  
{  cout << "这是funcPlus1" << endl;  return x + (int)y;  
}  // 参数类型不同  
int funcPlus(double x, double y)  
{  cout << "这是funcPlus2" << endl;  return (int)(x + y);  
}  // 参数个数不同  
int funcPlus(int x)  
{  cout << "这是funcPlus3" << endl;  return x * x;  
}  // 参数顺序不同  
int funcPlus(double x, int y)  
{  cout << "这是funcPlus4" << endl;  return (int)(x + y);  
}// 以下这种重载也是不允许的
int func(int x, int y = 10)  
{  cout << "这是funcPlus5" << endl;  return x + (int)y;  
}  int func(int x)  
{  cout << "这是funcPlus6" << endl;  return x;  
}void func(int &x); // 非 const 引用 
void func(const int &x); // const 引用,允许重载// 下面这两种不允许重载,因为数组arr[]会退化为指针
void func(int arr[])  
{  cout << "arr[]" << endl;  cout << arr[0] << endl;  
}  void func(int *arr)  
{  cout << "*arr" << endl;  cout << arr[0] << endl;  
}

类与多态性

  1. OOP:面向对象编程
  2. 类在声明时是不申请内存的,只有在实例化时才会初始化(分配)内存
  3. C++支持类的多继承;Java不支持类的多继承(但支持接口的多继承)
class Person
{
private:int age;public:string name;Person(int a, string name);~Person();  // 析构函数
};// 类内声明,类外定义
Person::Person(int age, string name)
{cout << "构造函数执行:" << endl;this->age = age;this->name = name;
}Person::~Person()
{cout << "析构函数执行:" << endl;
}
  1. 析构函数的作用:主要作用是在对象的生命周期结束时执行清理工作
    1. 释放动态分配的内存:运行过程中通过 newmalloc 等函数动态分配了内存,析构函数负责调用 deletefree 来释放这些内存。
    2. 释放其他系统资源:对象可能持有除内存以外的系统资源,比如文件句柄、网络连接、数据库连接等。
    3. 执行其他清理工作:析构函数可以用于任何需要在对象销毁时执行的操作,比如保存数据、记录日志等。
    4. 析构函数不接受参数,不能重载
    5. 如果创建了多个实例,析构函数就会执行多次。
  2. 类的访问控制:
    1. public:公开的成员可以在类外部访问。
    2. private:私有的成员只能在类内部访问,不能直接在类外部使用,但可以通过类方法间接调用。
    3. protected:受保护的成员可以在类内部和派生类(如子类)中访问。
  3. 类的静态成员:
    1. 静态成员变量:属于类本身,而不是某个对象。它在所有对象中共享
    2. 静态成员函数:只能访问静态成员变量,不依赖于对象。静态成员可以通过类名直接调用,如:Person::getCount()其中Person是类名,getCount()是静态成员函数
  4. 继承:
    1. 继承 允许一个类(派生类)从另一个类(基类)继承属性和行为。
    2. C++支持单继承和多继承。
    3. 派生类可以直接使用基类的公有和受保护成员。
class Animals
{
public:void eat(){cout << "eating" << endl;}
};class Dog : public Animals
{
public:void bark(){cout << "wow wow" << endl;}
};
  1. 友元函数:友元函数不是类的成员函数,但可以访问类的私有和受保护成员。它是在类外定义的,但具有特殊权限。
class Person
{
private:int age;public:Person(int age){this->age = age;}friend void getAge(Person);
};void getAge(Person per)
{cout << "岁数是:" <<per.age << endl;
}
  1. 多态:
    1. 多态性允许同一个函数或方法在不同的对象上表现出不同的行为。
    2. C++ 中的多态性通过虚函数、继承和指针或引用实现。
    3. 基本概念:
      1. 编译时多态(静态多态):通过函数重载和运算符重载实现,编译时决定。
      2. 运行时多态(动态多态):通过继承和虚函数实现,运行时决定。
  2. 虚函数:
    1. sound() 是基类 Animal 中的虚函数,DogCat 类分别重写了这个函数。
    2. 在运行时,animalPtr 指向不同的派生类对象时,会根据实际对象的类型来调用相应的 sound() 方法,这就是 运行时多态
  3. 纯虚函数与抽象类:
    1. 纯虚函数 是在基类中声明但没有实现的虚函数。
    2. 通过定义纯虚函数,基类变为 抽象类,它不能被实例化,只能作为派生类的基类使用。
  4. 纯虚函数与抽象类的代码如下:
#include <iostream>
using namespace std;class Animal
{
public:virtual void sound() = 0;
};class Dog : public Animal
{
public:// override 关键字不是必须的,但它是一个强烈推荐使用的修饰符。void sound() override{cout << "Dog barks" << endl;}
};class Cat : public Animal
{
public:void sound() override{cout << "Cat meow" << endl;}
};int main(int argc, char const *argv[])
{Animal *animalptr;Dog dog;Cat cat;// 基类指针指向派生类对象animalptr = &dog;animalptr->sound();  // 输出Dog barksanimalptr = &cat;animalptr->sound();  // 输出Cat meowreturn 0;
}
  1. 多态与析构函数:
    1. 通过基类指针删除派生类对象时,如果基类的析构函数不是 virtual,则可能会发生 内存泄漏
    2. 因为如果基类指针的析构函数不是虚函数,那么通过基类指针删除派生类对象时,调用的是基类的析构函数,导致派生类的资源没有被正确释放
  2. 代码如下:
#include <iostream>
using namespace std;class Base
{
public:virtual ~Base(){ // 虚析构函数cout << "基类 析构函数执行" << endl;}
};class Derived : public Base
{
public:~Derived() override{cout << "派生类 析构函数执行" << endl;}
};int main()
{Base *basePtr = new Derived;delete basePtr; // 先调用派生类的析构函数,再调用基类的析构函数return 0;
}
  1. 对象切片
    1. 如果通过 值传递(而非指针或引用)传递对象,会发生 对象切片,即派生类对象的派生部分会被切掉,变成一个基类对象。
#include <iostream>
using namespace std;class Base
{
public:virtual void show(){cout << "Base show" << endl;}
};class Derived : public Base
{
public:void show() override{cout << "Derived show" << endl;}
};void display(Base &obj) // 通过引用传递对象不会导致“对象切片”
// void display(Base obj)  // 值传递会导致“对象切片”
{obj.show();
}int main()
{Derived d;display(d);return 0;
}
  1. 对象传递最好是传递指针或者引用,直接进行值传递会导致对象切片:
#include <iostream>using namespace std;class Animal
{
public:virtual void sound(){cout << "Animal sound" << endl;}
};class Dog : public Animal
{
public:void sound() override{cout << "Dog barks" << endl;}
};int main(int argc, char const *argv[])
{Dog dog;dog.sound();  // 输出是Dog barksAnimal *basePtr = &dog;basePtr->sound();  // 输出是Dog barksAnimal &baseRef = dog;baseRef.sound();  // 输出是Dog barksAnimal baseObj = dog;baseObj.sound();  // 输出是Animal sound(这里产生了对象切片)return 0;
}

相关文章:

C++入门(有C语言基础)

string类 string类初始化的方式大概有以下几种&#xff1a; string str1;string str2 "hello str2";string str3("hello str3");string str4(5, B);string str5[3] {"Xiaomi", "BYD", "XPeng"};string str6 str5[2];str…...

第四届高性能计算与通信工程国际学术会议(HPCCE 2024)

目录 大会简介 主办单位&#xff0c;承办单位 征稿主题 会议议程 参会方式 大会官网&#xff1a;www.hpcce.net 大会简介 第四届高性能计算与通信工程国际学术会议&#xff08;HPCCE 2024&#xff09;将于2024年11月22-24日在苏州召开。HPCCE 2024将围绕“高性能计算与通信工…...

负载均衡架构解说

负载均衡架构是一种设计模式&#xff0c;用于在多个服务器之间分配网络或应用流量&#xff0c;以提高资源利用率、最大化吞吐量、减少响应时间&#xff0c;并确保高可用性。 负载均衡架构的关键组件和概念&#xff1a; 关键组件 1.负载均衡器&#xff08;Load Balancer&…...

【异常数据检测】孤立森林算法异常数据检测算法(数据可视化 Matlab语言)

摘要 本文研究了基于孤立森林算法的异常数据检测方法&#xff0c;并在MATLAB中实现了该算法的可视化。孤立森林是一种无监督的异常检测算法&#xff0c;主要通过构建决策树来区分正常数据和异常数据。本文使用真实数据集&#xff0c;通过二维可视化展示了检测结果。实验结果表…...

MKV转MP4丨FFmpeg的简单命令使用——视频格式转换

MKV是一种视频封装格式&#xff0c;很好用&#xff0c;也是OBS的默认推荐录制格式&#xff0c;因为不会突然断电关机而导致整个视频录制文件丢失。 但是MKV无法直接导入PR中剪辑&#xff0c;最直接的方法是将MKV转换为MP4格式&#xff0c;最方便且安全无损的转换方法便是用FFmp…...

git使用“保姆级”教程4——版本回退及分支讲解

一、版本回退 1、历史回退(版本回退)——命令行git reset --hard 版本编号 注意&#xff1a;当前命令会让工作区的内容发生改变&#xff0c;可以理解成历史区(master分支)直接回到工作区比如&#xff1a;从版本4回到版本3&#xff0c;则工作区只会显示版本3的代码内容 1.1、指…...

spring cache,Spring data redis

本项目使用Redis存储缓存数据&#xff0c;如何通过Java去访问Redis&#xff1f; 常用的有Jedis和Lettuce两个访问redis的客户端类库 &#xff0c;Jedis和Lettuce都是redis提供的。其中Lettuce的性能和并发性要好一些&#xff0c;Spring Boot 默认使用的是 Lettuce 作为 Redis …...

10.数据结构与算法-线性表的应用(线性表与有序表的合并)

线性表的合并 有序表的合并 顺序表 链表...

GAN|对抗| 生成器更新|判别器更新过程

如上图所示&#xff0c;生成对抗网络存在上述内容&#xff1a; 真实数据集&#xff1b;生成器&#xff1b;生成器损失函数&#xff1b;判别器&#xff1b;判别器损失函数&#xff1b;生成器、判别器更新&#xff08;生成器和判别器就是小偷和警察的关系&#xff0c;他们共用的…...

day01——登录功能

逻辑&#xff1a; 前端将登录信息通过报文的形式&#xff0c;发送给后端。后端进行登陆验证 2.1 根据接受的用户名&#xff0c;查询数据表。 若不存在该用户的记录&#xff0c;返回用户不存在。 若用户存在&#xff0c;判断数据库中的密码和接收的是否一致&#xff0c;不一致则…...

Flutter中使用FFI的方式链接C/C++的so库(harmonyos)

Flutter中使用FFI的方式链接C/C库&#xff08;harmonyos&#xff09; FFI plugin创建和so的配置FFI插件对so库的使用 FFI plugin创建和so的配置 首先我们可以根据下面的链接生成FFI plugin插件&#xff1a;开发FFI plugin插件 然后在主项目中pubspec.yaml 添加插件的依赖路径&…...

【C++】二义性

在C中&#xff0c;二义性&#xff08;ambiguity&#xff09;通常指的是编译器无法确定使用哪个函数、变量或类成员的情况。这种不确定性通常是由于继承和多态特性导致的。下面是一些常见的产生二义性的场景以及如何解决它们的方法&#xff1a; 1. 多重继承中的二义性 当一个类…...

高并发内存池(五):ThreadCache、CentralCache和PageCache的内存回收机制、阶段性代码展示和释放内存过程的调试

目录 ThreadCache的内存回收机制 补充内容1 补充内容2 补充内容3 补充内容4 ListTooLong函数的实现 CentralCache的内存回收机制 MapObjectToSpan函数的实现 ReleaseListToSpans函数的实现 PageCache的内存回收机制 补充内容1 补充内容2 ReleaseSpanToPageCache函…...

STL之stackqueue篇(上)探索C++ STL中的Queue与Stack——构建数据处理的基础框架

文章目录 前言一、stack1.1 定义与基本概念1.2 底层容器1.3 成员函数1.4 使用示例1.5 注意事项1.6 应用场景 二、queue2.1 定义与基本概念2.2 底层容器2.3 成员函数2.4 使用示例2.5 注意事项2.6 应用场景 前言 本文旨在深入探讨C STL中的queue与stack容器&#xff0c;从它们的…...

代码随想录算法训练营Day13

110.平衡二叉树 力扣题目链接&#xff1a;. - 力扣&#xff08;LeetCode&#xff09; 后序迭代 class Solution {public boolean isBalanced(TreeNode root) {return getHeight(root)!-1;}public int getHeight(TreeNode root){if(rootnull){return 0;}int leftheightgetHei…...

基于STM32的智能门禁系统

目录 引言项目背景环境准备 硬件准备软件安装与配置系统设计 系统架构关键技术代码示例 RFID数据采集与处理门禁控制实现显示与报警功能应用场景结论 1. 引言 智能门禁系统在现代安防中占据重要地位&#xff0c;通常用于控制进入和离开特定区域的权限。通过基于STM32微控制器…...

[EBPF] 实时捕获DM数据库是否存在SQL阻塞

1. 介绍 eBPF&#xff08;extened Berkeley Packet Filter&#xff09;是一种内核技术&#xff0c;它允许开发人员在不修改内核代码的情况下运行特定的功能。eBPF 的概念源自于 Berkeley Packet Filter&#xff08;BPF&#xff09;&#xff0c;后者是由贝尔实验室开发的一种网…...

秋招内推--招联金融2025

【投递方式】 直接扫下方二维码&#xff0c;或点击内推官网https://wecruit.hotjob.cn/SU61025e262f9d247b98e0a2c2/mc/position/campus&#xff0c;使用内推码 igcefb 投递&#xff09; 【招聘岗位】 后台开发 前端开发 数据开发 数据运营 算法开发 技术运维 软件测试 产品策…...

Unity2022.3.x各个版本bug集合及推荐稳定版本

最近升级到Unity2022&#xff0c;发现以下问题&#xff0c;仅作参考 2022.3.0f1 - 2022.3.6f1 粒子渲染到RenderTexture闪屏 https://issuetracker.unity3d.com/issues/android-vulkan-visualisation-corruption-occurs-when-rendering-particles-to-render-texture 2022.3.…...

SparkSQL-性能调优

祝福 在这个举国同庆的时刻&#xff0c;我们首先献上对祖国的祝福&#xff1a; 第一&#xff0c;我们感谢您给我们和平的环境&#xff0c;让我们能快乐生活 第二&#xff0c;祝福我们国家未来的路越走越宽广&#xff0c;科技更发达&#xff0c;人民更幸福 第三&#xff0c;…...

leetcode-链表篇

leetcode-707 你可以选择使用单链表或者双链表&#xff0c;设计并实现自己的链表。 单链表中的节点应该具备两个属性&#xff1a;val 和 next 。val 是当前节点的值&#xff0c;next 是指向下一个节点的指针/引用。 如果是双向链表&#xff0c;则还需要属性 prev 以指示链表中的…...

JetLinks物联网平台微服务化系列文章介绍

橙蜂智能公司致力于提供先进的人工智能和物联网解决方案&#xff0c;帮助企业优化运营并实现技术潜能。公司主要服务包括AI数字人、AI翻译、AI知识库、大模型服务等。其核心价值观为创新、客户至上、质量、合作和可持续发展。 橙蜂智农的智慧农业产品涵盖了多方面的功能&#x…...

【QT Quick】基础语法:导入外部QML文件

在实际项目中&#xff0c;代码通常分为多个文件进行模块化管理&#xff0c;这样可以方便代码重用&#xff0c;例如统一风格或共享功能模块。我们将在此部分学习如何创建 QML 项目&#xff0c;并演示如何访问外部代码&#xff0c;包括其他 QML 文件、库文件以及 JS 代码。 准备…...

Llama 系列简介与 Llama3 预训练模型推理

1. Llama 系列简介 1.1 Llama1 由 Meta AI 发布&#xff0c;包含 7B、13B、33B 和 65B 四种参数规模的开源基座语言模型 数据集&#xff1a;模型训练数据集使用的都是开源的数据集&#xff0c;总共 1.4T token 模型结构&#xff1a;原始的 Transformer 由编码器&#xff08…...

【AIGC】ChatGPT提示词助力自媒体内容创作升级

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AIGC | ChatGPT 文章目录 &#x1f4af;前言&#x1f4af;高效仿写专家级文章提示词使用方法 &#x1f4af;CSDN博主账号分析提示词使用方法 &#x1f4af;自媒体爆款文案优化助手提示词使用方法 &#x1f4af;小结 &#x1f4af…...

SSTI基础

<aside> &#x1f4a1; 简介 </aside> 原理 又名&#xff1a;Flask模版注入 模版种类 **Twig{{7*7}}结果49 jinja2{{7*7}}结果为7777777 //jinja2的常见参数是name smarty7{*comment*}7为77**<aside> &#x1f4a1; flask实例 </aside> **from …...

10.1软件工程知识详解上

软件工程概述 软件开发生命周期 软件定义时期&#xff1a;包括可行性研究和详细需求分析过程&#xff0c;任务是确定软件开发工程必须完成的总目标&#xff0c;具体可分成问题定义、可行性研究、需求分析等。软件开发时期&#xff1a;就是软件的设计与实现&#xff0c;可分成…...

03Frenet与Cardesian坐标系(Frenet转Cardesian公式推导)

Frenet转Cardesian 1 明确目标 已知车辆质点在Frenet坐标系下的状态&#xff1a; Frenet 坐标系下的纵向坐标&#xff1a; s s s纵向速度&#xff1a; s ˙ \dot{s} s˙纵向加速度&#xff1a; s \ddot{s} s横向坐标&#xff1a; l l l横向速度&#xff1a; l ˙ \dot{l} l…...

knowLedge-Vue I18n 是 Vue.js 的国际化插件

1.简介 Vue I18n 是 Vue.js 的国际化插件&#xff0c;它允许开发者根据不同的语言环境显示不同的文本&#xff0c;支持多语言。 Vue I18n主要有两个版本&#xff1a;v8和v9。v8版本适用于Vue2框架。v9版本适用于Vue3框架。 2. 翻译实现原理 Vue I18n 插件通过在 Vue 实例中注…...

【开源免费】基于SpringBoot+Vue.JS微服务在线教育系统(JAVA毕业设计)

本文项目编号 T 060 &#xff0c;文末自助获取源码 \color{red}{T060&#xff0c;文末自助获取源码} T060&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…...

网站建设运营费用包括哪些/网络营销好找工作吗

阅读本文大概需要 3.5 分钟。 本篇是设计模式系列的开篇&#xff0c;虽然之前也写过相应的文章&#xff0c;但是因为种种原因后来断掉了&#xff0c;而且发现之前写的内容也很渣&#xff0c;不够系统。 所以现在打算重写&#xff0c;加上距离现在也有一段时间了&#xff0c;也算…...

广州疫情 高位平台/安卓优化大师2021

当用浏览器浏览网页的时候&#xff0c;当我们点击一个连接的时候&#xff0c;浏览器就会转到新的页面去。整个过程如下&#xff1a; 1&#xff09;用户在当前页面点击->2&#xff09;浏览器获取新的URL->3)浏览器转到新的URL。现在&#xff0c;假设我们有一个pdf的阅读程…...

海南手机网站建设/天津seo渠道代理

本博文使用的数据库是MySQL和MongoDB数据库。安装MySQL可以参照我的这篇博文&#xff1a;https://www.cnblogs.com/tszr/p/12112777.html其中操作Mysql使用到的python模块是pymysql,下面是有关这个模块的使用说明&#xff1a;创建一个数据库testcreate DATABASE taobao;Navicat…...

临沂网站建设制作/网络营销推广方案策划书

[20191227]别把数据库当作垃圾场.txt--//最近一直在我一个项目的优化工作,看到开发写的模式有时候真心无语!!xxxxx> select count(*) from BBB_QQQQ_FFFFF_TTTTTT;COUNT(*)----------1xxxxx> select count(*) from BBB_QQQQ_FFFFF_TTTTTT;COUNT(*)----------0--//可以发现…...

盐城市规划建设局网站/百度爱采购优化

公众号关注 「奇妙的 Linux 世界」设为「星标」&#xff0c;每天带你玩转 Linux &#xff01;据BleepingComputer 2月10日消息&#xff0c;Clop 勒索软件组织最近利用 GoAnywhere MFT 安全文件传输工具中的零日漏洞&#xff0c;从 130 多个企业组织中窃取了数据。该安全漏洞被追…...

个人做网站做什么样的话/百度指数的数值代表什么

Reader Sharer Monkey 在上次的回到旧版Google Reader外观中&#xff0c;解决了新版Google Reader的外观问题。 这次把keakon的启用分享功能的Chrome插件Reader Sharer移植成了油猴脚本&#xff0c;解决了分享问题。 另外显示了被Google隐藏起来的People you follow&#xff0c…...