技术标签: c++ visual studio 开发语言
创建项目
创建文件:源文件中添加新建项,在选中C++文件(.cpp)
编写代码
#include<iostream>
using namespace std;
int main()
{
cout << "hello world" << endl;
system("pause");
return 0;
}
int main()//单行注释
int a = 10;//创建变量
#include<iostream>
using namespace std;
#define day 7//宏常量
int main()//单行注释
{
cout << "hello world" << endl;
int a = 10;//创建变量
const int b = 5;//关键字修饰的变量
system("pause");
return 0;
}
#include<iostream>
using namespace std;
#define day 7//宏常量
int main()//单行注释
{
cout << "hello world" << endl;
int a = 10;//创建变量
const int b = 5;//关键字修饰的变量
cout << "变量a所占内存大小:" << sizeof(a) << endl;
system("pause");
return 0;
}
#include<iostream>
using namespace std;
#define day 7//宏常量
int main()//单行注释
{
cout << "hello world" << ends;//输出结束空格
cout << "变量a所占内存大小:" << sizeof(a) << endl;//输出结束换行
int a = 10;//创建变量
const int b = 5;//关键字修饰的变量
system("pause");
return 0;
}
操作系统根据变量的数据类型来分配内存
各种变量类型在内存中存储值时需要占用的内存
我们可以使用typedef来为已经存在的数据类型定义别名
typedef int f;//f的作用和int一样
f a=3;//a是一个整型变量
enum color {
red,
green,
blue
} c;
c = blue;
#include <iostream>
using namespace std;
#include <iomanip>
using std::setw;
int main ()
{
int n[ 10 ]; // 定义数组:n 是一个包含 10 个整数的数组
// 初始化数组元素
for ( int i = 0; i < 10; i++ )
{
n[ i ] = i + 100; // 设置元素 i 为 i + 100
}
cout << "Element" << setw( 13 ) << "Value" << endl;
// 输出数组中每个元素的值
for ( int j = 0; j < 10; j++ )
{
cout << setw( 7 )<< j << setw( 13 ) << n[ j ] << endl;
}
return 0;
}
输出结果:
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
// 开头设置宽度为 4,后面的 runoob 字符长度大于 4,所以不起作用
cout << setw(4) << "runoob" << endl;
// 中间位置设置宽度为 4,后面的 runoob 字符长度大于 4,所以不起作用
cout << "runoob" << setw(4) << "runoob" << endl;
// 开头设置间距为 14,后面 runoob 字符数为6,前面补充 8 个空格
cout << setw(14) << "runoob" << endl;
// 中间位置设置间距为 14 ,后面 runoob 字符数为6,前面补充 8 个空格
cout << "runoob" << setw(14) << "runoob" << endl;
return 0;
}
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
cout << setfill('*') << setw(14) << "runoob" << endl;
return 0;
}
结果:
指针是用来指向地址的:double Array[10];实际上Array是指向&Array[0]的指针,及数组Array的第一个地址。
把 p 赋值为 Aarray 的第一个元素的地址:一旦把第一个元素的地址存储在 p 中,您就可以使用 p、(p+1)、*(p+2) 等来访问数组元素。下面的实例演示了上面讨论到的这些概念:
double *p;
double Aarray[10];
p = Aarray;
#include <iostream>
using namespace std;
int main ()
{
// 带有 5 个元素的双精度浮点型数组
double runoobAarray[5] = {
1000.0, 2.0, 3.4, 17.0, 50.0};
double *p;
p = runoobAarray;
// 输出数组中每个元素的值
cout << "使用指针的数组值 " << endl;
for ( int i = 0; i < 5; i++ )
{
cout << "*(p + " << i << ") : ";
cout << *(p + i) << endl;
}
cout << "使用 runoobAarray 作为地址的数组值 " << endl;
for ( int i = 0; i < 5; i++ )
{
cout << "*(runoobAarray + " << i << ") : ";
cout << *(runoobAarray + i) << endl;
}
return 0;
}
void myFunction(int *param)
{
.
.
.
}
void myFunction(int param[10])
{
.
.
.
}
void myFunction(int param[])
{
.
.
.
}
#include<iostream>
using namespace std;
int getAverage(int arr[],int size)
{
int i, sum = 0;
double aver;
for ( i = 0; i < size; i++)
{
sum += arr[i];
}
aver = double(sum) / size;
return aver;
}
int main()
{
// 带有 5 个元素的整型数组
int balance[5] = {
1000, 2, 3, 17, 50 };
double avg;
// 传递一个指向数组的指针作为参数
avg = getAverage(balance, 5);
// 输出返回值
cout << "平均值是:" << avg << endl;
return 0;
}
#include<iostream>
using namespace std;
void swap(int& a, int& b);
#include "head.h"//包含头文件
void swap(int &a, int &b)
{
int temp;
temp = a;
a = b;
b = temp;
}
7.main.cpp
#include<iostream>
#include "head.h"
using namespace std;
int main()
{
int x, y;
x = 10;
y = 7;
cout << x << y << endl;
swap(x, y);
cout << x << y << endl;
}
int *ip; /* 一个整型的指针 */
double *dp; /* 一个 double 型的指针 */
float *fp; /* 一个浮点型的指针 */
char *ch; /* 一个字符型的指针 */`
#include <iostream>
using namespace std;
int main ()
{
int var = 20; // 实际变量的声明
int *ip; // 指针变量的声明
ip = &var; // 在指针变量中存储 var 的地址
cout << "Value of var variable: ";
cout << var << endl;
// 输出在指针变量中存储的地址
cout << "Address stored in ip variable: ";
cout << ip << endl;
// 访问指针中地址的值
cout << "Value of *ip variable: ";
cout << *ip << endl;
return 0;
}
int var[MAX] = {
10, 100, 200};
int *ptr;
// 指针中的数组地址
ptr = var;
// 移动到下一个位置
ptr++;
#include <iostream>
using namespace std;
const int MAX = 3;
int main ()
{
int var[MAX] = {
10, 100, 200};
int *ptr[MAX];//定义指针数组
for (int i = 0; i < MAX; i++)
{
ptr[i] = &var[i]; // 赋值为整数的地址
}
for (int i = 0; i < MAX; i++)
{
cout << "Value of var[" << i << "] = ";
cout << *ptr[i] << endl;
}
return 0;
}
Value of var[0] = 10
Value of var[1] = 100
Value of var[2] = 200
#include <iostream>
using namespace std;
int main ()
{
int var;
int *ptr;
int **pptr;
var = 3000;
// 获取 var 的地址
ptr = &var;
// 使用运算符 & 获取 ptr 的地址
pptr = &ptr;
// 使用 pptr 获取值
cout << "var 值为 :" << var << endl;
cout << "*ptr 值为:" << *ptr << endl;
cout << "**pptr 值为:" << **pptr << endl;
return 0;
}
#include<iostream>
#include<string>
using namespace std;
//结构体定义
struct student {
string name;
int age;
int score;
}stu3;//结构体变量创建方式3
int main() {
//结构体变量创建方式1
struct student stu1;//struct关键字可以省略
stu1.age = 20;
stu1.name = "jack";
stu1.score = 82;
cout << stu1.name <<" " << stu1.age << " " << stu1.score<<endl;
//结构体变量创建方式2
struct student stu2 = {
"李四",18,90};
cout << stu2.name << " " << stu2.age << " " << stu2.score;
}
#include<iostream>
#include<string>
using namespace std;
//1.定义结构体
struct Student {
string name;
int age;
int score;
};
int main() {
//2.1创建结构体数组,方法一,定义时赋值
struct Student stuArray[3] = {
{
"张三",18,80},
{
"李四",20,62},
{
"王五",23,72}
};
//2.2结构体数组元素单独赋值
stuArray[2].age = 50;
//3.遍历数组成员
for(int i = 0; i<3; i++ ){
cout << "姓名" << stuArray[i].name << endl;
}
}
struct Books *struct_pointer;
struct_pointer = &Book1;
struct_pointer->title;
#include<iostream>
#include<string>
using namespace std;
//1.定义结构体
struct Student {
string name;
int age;
int score;
};
int main() {
//创建结构体变量
struct Student stu1 = {
"张三",18,100};
//通过指针指向结构体变量,struct可以省略
struct Student* p=&stu1;
//指针访问结构体属性
cout << "姓名:" << p->name << endl;
}
#include<iostream>
#include<string>
using namespace std;
//定义学生结构体
struct Student {
string name;
int age;
int score;
};
//定义老师结构体并嵌套学生结构体
struct Teacher {
string name;
int age;
int id;
struct Student stu1;//学生
};
int main() {
//结构体变量创建方式1
struct Teacher t1;//struct关键字可以省略
t1.age = 20;
t1.name = "jack";
t1.id = 123;
t1.stu1.score = 80;
t1.stu1.age = 17;
t1.stu1.name = "小王";
cout << "老师姓名" <<t1.name<< "老师年龄" << t1.age << "老师工号" <<t1.id<< endl;
cout <<t1.stu1.name << " " << t1.stu1.age << " " << t1.stu1.score;
}
typedef struct Books
{
char title[50];
char author[50];
char subject[100];
int book_id;
}Books2;
Books2 Book1, Book2;//创建结构体变量
#include<iostream>
#include<string>
using namespace std;
//1.定义结构体
struct Student {
string name;
int age;
int score;
};
//创建函数
void printStudent(struct Student s) {
cout << "姓名:" << s.name << endl;
}
int main() {
//创建结构体变量
struct Student stu1 = {
"张三",18,100};
printStudent(stu1);
}
#include<iostream>
#include<string>
using namespace std;
//1.定义结构体
struct Student {
string name;
int age;
int score;
};
//创建函数
void printStudent(struct Student *p)//更改2
{
cout << "姓名:" << p->name << endl;
cout << "年龄:" << p->age << endl;
cout << "分数:" << p->score << endl;
}
int main() {
//创建结构体变量
struct Student stu1 = {
"张三",18,100};
printStudent(&stu1);//更改1
}
#include<iostream>
#include<string>
using namespace std;
//1.定义结构体
struct Student {
string name;
int age;
int score;
};
//创建函数
void printStudent(struct Student *p)//更改2
{
p->age = 80;//对结构体变量的数值进行修改
cout << "修改后的年龄:" << p->age << endl;
}
int main() {
//创建结构体变量
struct Student stu1 = {
"张三",18,100};
cout << "修改前的年龄:" << stu1.age<< endl;
printStudent(&stu1);//更改1
}
文章浏览阅读1k次。通过使用ajax方法跨域请求是浏览器所不允许的,浏览器出于安全考虑是禁止的。警告信息如下:不过jQuery对跨域问题也有解决方案,使用jsonp的方式解决,方法如下:$.ajax({ async:false, url: 'http://www.mysite.com/demo.do', // 跨域URL ty..._nginx不停的xhr
文章浏览阅读2k次。关于在 Oracle 中配置 extproc 以访问 ST_Geometry,也就是我们所说的 使用空间SQL 的方法,官方文档链接如下。http://desktop.arcgis.com/zh-cn/arcmap/latest/manage-data/gdbs-in-oracle/configure-oracle-extproc.htm其实简单总结一下,主要就分为以下几个步骤。..._extproc
文章浏览阅读1.5w次。linux下没有上面的两个函数,需要使用函数 mbstowcs和wcstombsmbstowcs将多字节编码转换为宽字节编码wcstombs将宽字节编码转换为多字节编码这两个函数,转换过程中受到系统编码类型的影响,需要通过设置来设定转换前和转换后的编码类型。通过函数setlocale进行系统编码的设置。linux下输入命名locale -a查看系统支持的编码_linux c++ gbk->utf8
文章浏览阅读750次。今天准备从生产库向测试库进行数据导入,结果在imp导入的时候遇到“ IMP-00009:导出文件异常结束” 错误,google一下,发现可能有如下原因导致imp的数据太大,没有写buffer和commit两个数据库字符集不同从低版本exp的dmp文件,向高版本imp导出的dmp文件出错传输dmp文件时,文件损坏解决办法:imp时指定..._imp-00009导出文件异常结束
文章浏览阅读143次。当下是一个大数据的时代,各个行业都离不开数据的支持。因此,网络爬虫就应运而生。网络爬虫当下最为火热的是Python,Python开发爬虫相对简单,而且功能库相当完善,力压众多开发语言。本次教程我们爬取前程无忧的招聘信息来分析Python程序员需要掌握那些编程技术。首先在谷歌浏览器打开前程无忧的首页,按F12打开浏览器的开发者工具。浏览器开发者工具是用于捕捉网站的请求信息,通过分析请求信息可以了解请..._初级python程序员能力要求
文章浏览阅读7.6k次,点赞2次,收藏6次。@Service标注的bean,类名:ABDemoService查看源码后发现,原来是经过一个特殊处理:当类的名字是以两个或以上的大写字母开头的话,bean的名字会与类名保持一致public class AnnotationBeanNameGenerator implements BeanNameGenerator { private static final String C..._@service beanname
文章浏览阅读6.9w次,点赞73次,收藏463次。1.前序创建#include<stdio.h>#include<string.h>#include<stdlib.h>#include<malloc.h>#include<iostream>#include<stack>#include<queue>using namespace std;typed_二叉树的建立
文章浏览阅读7.1k次。在Asp.net上使用Excel导出功能,如果文件名出现中文,便会以乱码视之。 解决方法: fileName = HttpUtility.UrlEncode(fileName, System.Text.Encoding.UTF8);_asp.net utf8 导出中文字符乱码
文章浏览阅读2.1k次,点赞4次,收藏23次。第一次实验 词法分析实验报告设计思想词法分析的主要任务是根据文法的词汇表以及对应约定的编码进行一定的识别,找出文件中所有的合法的单词,并给出一定的信息作为最后的结果,用于后续语法分析程序的使用;本实验针对 PL/0 语言 的文法、词汇表编写一个词法分析程序,对于每个单词根据词汇表输出: (单词种类, 单词的值) 二元对。词汇表:种别编码单词符号助记符0beginb..._对pl/0作以下修改扩充。增加单词
文章浏览阅读773次。我在使用adb.exe时遇到了麻烦.我想使用与bash相同的adb.exe shell提示符,所以我决定更改默认的bash二进制文件(当然二进制文件是交叉编译的,一切都很完美)更改bash二进制文件遵循以下顺序> adb remount> adb push bash / system / bin /> adb shell> cd / system / bin> chm..._adb shell mv 权限
文章浏览阅读6.8k次,点赞12次,收藏125次。1. 单目相机标定引言相机标定已经研究多年,标定的算法可以分为基于摄影测量的标定和自标定。其中,应用最为广泛的还是张正友标定法。这是一种简单灵活、高鲁棒性、低成本的相机标定算法。仅需要一台相机和一块平面标定板构建相机标定系统,在标定过程中,相机拍摄多个角度下(至少两个角度,推荐10~20个角度)的标定板图像(相机和标定板都可以移动),即可对相机的内外参数进行标定。下面介绍张氏标定法(以下也这么称呼)的原理。原理相机模型和单应矩阵相机标定,就是对相机的内外参数进行计算的过程,从而得到物体到图像的投影_相机-投影仪标定
文章浏览阅读2.2k次。文章目录Wayland 架构Wayland 渲染Wayland的 硬件支持简 述: 翻译一篇关于和 wayland 有关的技术文章, 其英文标题为Wayland Architecture .Wayland 架构若是想要更好的理解 Wayland 架构及其与 X (X11 or X Window System) 结构;一种很好的方法是将事件从输入设备就开始跟踪, 查看期间所有的屏幕上出现的变化。这就是我们现在对 X 的理解。 内核是从一个输入设备中获取一个事件,并通过 evdev 输入_wayland