中间代码生成

一.实验题目
DO-WHILE循环语句的中间代码生成
二.实验目的
通过设计、编制、调试一个 do-while 循环语句的语法及语义分析程序,加深对
法及语义分析原理的理解,并实现词法分析程序对单词序列的词法检查和分析。

三. 实验内容及结果

  1. 根据给出的样例程序,补充填写部分并运行;
    (1)程序清单,填写部分用红色标注
#include<string>
#include<iostream>
#include <fstream>
#include<cctype>
using namespace std;
int const ACC = 1 << 31 - 1;
string filename; //用来输入文件名用
string symbol[200];
string blankCharacter = " ";
int num = 0;
//int start; //用在输出输入串时确定开始的位置
//------------------------------------------------------
struct stateStack //定义状态栈
{
	int top;
	int m[100];
};
void InitStateStack(stateStack& s)//建立状态栈
{
	s.top = 0;
}
int PushState(stateStack& s, int i)//把元素压入栈
{
	if (s.top == 100) return -1;
	else
	{
		s.m[s.top] = i;
		s.top++;
	}
	return 0;
}
int GetStateTop(stateStack& s) //取栈顶符号
{
	int i;
	if (s.top == 0) return -1;
	else
	{

		i = s.m[s.top - 1];
	}
	return i;
}
void PopStateTop(stateStack& s)//删除栈顶元素
{
	if (s.top == 0) cout << "wrong!";
	else
		--s.top;
}
//-----------------------------------------------------------------
//定义一个用于四元式输出的栈
struct quaternionStack
{
	int top;
	string s[5];
};
//-----------------------------------------------------------------
//
struct symbolStack//定义符号栈
{
	int top;
	string st[100];
};
void InitSymbolStack(symbolStack& s)//建立符号栈
{
	s.top = 0;
}
int PushSymbol(symbolStack& s, string str)//把元素压入栈
{
	if (s.top == 100) return -1;
	else
	{
		s.st[s.top] = str;
		s.top++;
	}
	return 0;
}
string GetSymbolTop(symbolStack& s) //取栈顶符号
{
	string str;
	if (s.top == 0) cout << "wrong!";

	else
	{
		str = s.st[s.top - 1];
	}
	return str;
}
void PopSymbolTop(symbolStack& s)//删除栈顶元素
{
	if (s.top == 0) cout << "wrong!";
	else
		--s.top;
}
//----------------------------------------------------------
//词法分析部分
const string keyWord[] = //定义关键字表
{
"int","double","float","void","long","for","if","else","while","include",
"return","break","continue","do","true","false","case","switch"
};
void showLex(string& s)
{
	symbol[num] = s;
	++num;
	ofstream fout("词法分析.txt", ios::out | ios::app);
	if (isdigit(s[0]))
	{
		fout << "< " << s << ",常数 >" << endl;
		s = "";
	}
	else
		for (int i = 0; i < 18; ++i)
		{
			if (s == keyWord[i])
			{
				fout << "< " << s << ",关键字 | 指向 " << s << " 的关键字表项的指针" << endl;
				break;
			}
			if (i == 17)
			{
				if (ispunct(s[0]) && s[0] != '_')
				{
					fout << "< " << s << ",运算符 | 指向 " << s << " 的运算符表项的指针 " << endl;
				}
				else
				{
					fout << "< id,标识符 | 指向 " << s << " 的符号表项的指针 >" <<
						endl;
				}
			}
		}
	s = "";
}
bool isDelimiters(char ch) //判断是否为界限符
{
	bool tag = 0;
	string s = "{[()]},;\'\"";
	for (int i = 0; i < s.size(); i++)
	{
		if (ch == s[i])
		{
			tag = 1;
			break;
		}
	}
	return tag;
}
bool isBlank(char ch) //判断是否为空
{
	bool tag = 0;
	if (ch == ' ')
		tag = 1;
	return tag;
}
bool isDecimalPoint(char ch) //判断是否为小数点
{
	bool tag = 0;
	if (ch == '.')
		tag = 1;
	return tag;
}
void lexAnalysis(string s)
{
	string yunsf, biaosf;
	for (int i = 0; i < s.size(); i++)
	{
		if (isBlank(s[i])) //判断是否为空
		{
			if (biaosf != "")
				showLex(biaosf);
		}
		else if (ispunct(s[i]))
		{//C 库函数 int isgraph(int c) 检查所传的字符是否有图形表示法。带有图形表
		//	示法的字符是除了空白字符(比如 ' ')以外的所有可打印的字符。
			if (isDelimiters(s[i]))
			{
				if (yunsf != "")
					showLex(yunsf);
				if (biaosf != "")
					showLex(biaosf);
				ofstream fout("词法分析.txt", ios::out | ios::app);
				fout << "< " << s[i] << ",界限符 | 指向 " << s[i] << " 的界限符的指针" << endl;
				symbol[num] = s[i];
				num++;
			}
			else if (isDecimalPoint(s[i]) || s[i] == '_')
			{
				biaosf += s[i];
}
			else
			{
				if (biaosf != "")
					showLex(biaosf);
				yunsf += s[i];
			}
		}//end ispunct( )
		else
		{
			if (yunsf != "")
				showLex(yunsf);
			biaosf += s[i];
		}
	}
	symbol[num] = "#";
}//词法分析结束
//12
//-------------------------------------------------------------------
//语法分析部分
//推导式部分
string production[18] = {
"S'-->S",
"S-->doAwhileB",
"A-->{F}",
"F-->M" ,
"F-->FM",
"M-->i=E;",
"E-->E+i",
"E-->E-i",
"E-->E*i",
"E-->E/i",
"E-->i",
"E-->(E)",
"B-->(iOi)",
"O--><",
"O--><=",
"O-->>",
"O-->>=",
"O-->!=",
};
//-----------------------------------------------------------------
//GOTO控制部分
void GOTO(int i, char b, stateStack& state_stack, symbolStack& symbol_stack)
{
	// cout<<"GOTOzhong fterminals wei: "<<b<<endl;
	if (i == 0 && b == 'S')
	{
		PushState(state_stack, 1);
	}
	else if (i == 2 && b == 'A')
	{
		PushState(state_stack, 3);
	}
	else if (i == 4 && b == 'B')
	{
		PushState(state_stack, 29);
	}
	else if (i == 5 && b == 'F')
	{

		PushState(state_stack, 6);
	}
	else if (i == 5 && b == 'M')
	{
		PushState(state_stack, 9);
	}
	else if (i == 6 && b == 'M')
	{
		PushState(state_stack, 8);
	}
	else if (i == 11 && b == 'E')
	{
		PushState(state_stack, 13);
	}
	else if (i == 24 && b == 'O')
	{
		PushState(state_stack, 26);
	}
	else if (i == 34 && b == 'E')
	{
		PushState(state_stack, 35);
	}
	string B = "";
	B = B + b;
	PushSymbol(symbol_stack, B);
}
//--------------------------------------------------------------------
//Action控制表
//n大于0表示移进
//n小于0则达标要进行规约,-n就代表用哪个推导式进行规约
//ACC代表规约成功 0表示出错
const int Action[38][19] = {
{2}, //状态0 入栈do
{0,0,0,0,0,0,0,0,0,0,0,0,0,ACC}, //状态1 # ACC
{0,0,0,0,0,0,0,0,0,5}, //状态2 入栈{
{0,4}, //状态3 入栈while
{0,0,0,0,0,0,0,0,0,0,0,23 }, //状态4 入栈 (
{0,0,10}, //状态5 入栈i
{0,0,10,0,0,0,0,0,0,0,7,0}, //状态6 入栈i }
{0,-2}, //状态7 规约 2. A→{F} //while
{0,0,-4,0,0,0,0,0,0,0,-4}, //状态8 规约4. F→FM //i }
{0,0,-3,0,0,0,0,0,0,0,-3}, //状态9 规约3. F→M //i }
{0,0,0,11}, //状态10 入栈=
{0,0,12,0,0,0,0,0,0,0,0,34},//状态11 入栈 i (
{0,0,0,-10,-10,-10,-10,-10,-10,0,0,0,-10},
//状态12规约10.E→i= + - * / ;
{0,0,0,0,15,16,17,18,14}, //状态13 入栈 + - * / ;
{0,0,-5,0,0,0,0,0,0,0,-5}, //状态14 //规约 5. M→i=E;//i }
{0,0,19}, //状态15 入栈i
{0,0,20}, //状态16 入栈i
{0,0,21}, //状态17 入栈i
{0,0,22}, //状态18 入栈i
{0,0,0,0,-6,-6,-6,-6,-6,0,0,0,-6},
//状态19 规约 6.E→E+i // + - * / ;
{0,0,0,0,-7,-7,-7,-7,-7,0,0,0,-7},
//状态20规约 7. E→E-i // + - * / ;
{0,0,0,0,-8,-8,-8,-8,-8,0,0,0,-8},
//状态21规约 8. E→E*i // + - * / ;
{0,0,0,0,-9,-9,-9,-9,-9,0,0,0,-9},
//状态22 规约 9.E→E/i // + - * / ;
{0,0,24}, //状态23 入栈i
{0,0,0,0,0,0,0,0,0,0,0,0,0,0,25,30,31,32,33},//入栈 < <= > >= !=
{0,0,-13}, //状态25 规约 13. O→< 
{0,0,27}, //状态26 入栈 i 
{0,0,0,0,0,0,0,0,0,0,0,0,28}, //状态27 入栈 )
{0,0,0,0,0,0,0,0,-12,0,0,0,0,0},//状态28 规约12. B→(iOi) //;
{0,0,0,0,0,0,0,0,37}, //状态29 入栈 ;
{0,0,-14}, //状态30 规约14. O→<= //i
{0,0,-15}, //状态31 规约15. O→> //i
{0,0,-16}, //状态32 规约16. O→>= //i
{0,0,-17}, //状态33 规约17. O→!= //i
{0,0,12,0,0,0,0,0,0,0,0,34}, //状态34 入栈 i (
{0,0,0,0,15,16,17,18,0,0,0,0,36},//状态35 入栈 + - * / )
{0,0,0,0,-11,-11,-11,-11,-11,0,0,0,-11},//状态36 规约
//11.E→(E)//+ - * / ;
{0,0,0,0,0,0,0,0,0,0,0,0,0,-1}//状态37 规约 1.S→doAwhileB; //#
};
//--------------------------------------------------------------
//终结符表
string terminals[19] =
{ "do","while","i","=","+","-","*","/",";","{","}","(",")","#","<","<=","> "," >= "," != " };
//--------------------------------------------------------------------
//输出每步的分析过程 存储在文件“语法分析.txt”中
void showResult(stateStack& state_stack, symbolStack& symbol_stack, int start)
{
	//每次归约完毕后查看当前符号栈栈顶状态
	cout << GetSymbolTop(symbol_stack) << " " << GetStateTop(state_stack) << endl;
	ofstream yffout("语法分析.txt", ios::out | ios::app);
	for (int i = 0; i < state_stack.top; i++)
	{
		if (state_stack.m[i] >= 10)
		{
			yffout << "(" << state_stack.m[i] << ")";
		}
		else
			yffout << state_stack.m[i];
	}
	yffout << " ";
	for (int j = 0; j < symbol_stack.top; j++)
		yffout << symbol_stack.st[j];
	yffout << " ";
	for (int k = start; k <= num + 1; k++)
		yffout << symbol[k];
	yffout << endl;
}
//-----------------------------------
//表达式规约部分
void Reduce()
{
	ofstream syfout("四元式.txt", ios::out | ios::app);
	int start = 0, now = 0;
	quaternionStack quaternion_stack;
	quaternion_stack.top = 0;
	int order = 0;
	int m = 0, n, j;
	stateStack state_stack; //建状态栈
	InitStateStack(state_stack);
	PushState(state_stack, m);
	symbolStack symbol_stack;//建符号栈
	InitSymbolStack(symbol_stack);
	PushSymbol(symbol_stack, "#");
	//对栈进行初始化
	for (int i = 0; i <= num; i++)
	{
		showResult(state_stack, symbol_stack, i); //i+1代表已归约现在可查看新的状态
		string temp = symbol[i];
		j = 0;
		while (terminals[j] != temp) //查找终结符对应的下标
		{
			++j;
			if (j >= 19)
			{
				j = 2; //如果是变量或者常量,令:j = 2,即对应终结符 i
				break;
			}
		}
		m = GetStateTop(state_stack); //查看当前状态栈的栈顶
		n = Action[m][j];
		int rightLength;
		while (n < 0)
{
			n = -n;
			if (n == 14 || n == 16 || n == 17)
				rightLength = production[n].size() - 5;
			else if (n == 1)
				rightLength = production[n].size() - 8;
			else
				rightLength = production[n].size() - 4;
			//cout<<"表达式"<<(n-40)<<"的右部长度为"<<rightLength<<endl;
			//----------------------------------------------------------
			//四元式输出控制部分
			string ss0, ss1, ss2;
			string t[] = { "t0","t1","t2","t3","t4","t5","t6","t7","t8","t9","t10" };
			if (n == 10) //当用 10.E→i 式归约时,开始建立栈
			{
				quaternion_stack.s[quaternion_stack.top] = symbol[i - 1];
				++quaternion_stack.top;
			}
			else if (n >= 6 && n <= 9)//6. E→E+i 7.E→E-i 8.E→E*I 9.E→E/i
			{
				--quaternion_stack.top;
				ss0 = quaternion_stack.s[quaternion_stack.top];
				--quaternion_stack.top;
				ss1 = quaternion_stack.s[quaternion_stack.top];
				--quaternion_stack.top;
				ss2 = quaternion_stack.s[quaternion_stack.top];
					syfout << now << " (" << ss1 << "," << ss2 << "," << ss0 << "," << t[order] << ")" << endl;//运算的四元式
				++now;
				quaternion_stack.s[quaternion_stack.top] = t[order];
				++quaternion_stack.top;
				++order;
			}
			else if (n == 5) //赋值语句的四元式;5. M→i=E;
			{
				int l = symbol_stack.top - 4;
				quaternion_stack.top = 0;
				syfout << now << " (=:," << quaternion_stack.s[quaternion_stack.top]
					<< ",-," << symbol_stack.st[l] << ")" << endl;
				++now;
			}
			else if (n == 13 || n == 14 || n == 15 || n == 16)//判断语句的四元式
				syfout << now << " if " << symbol[i - 2] << symbol[i - 1] << symbol[i]
				<< " goto " << start << endl;
			//------------------------------------------------------
			for (int k = 1; k <= rightLength; k++)
			{
				PopSymbolTop(symbol_stack);
				PopStateTop(state_stack);
			}
			// showLex(state_stack,symbol_stack,i); 
			GOTO(GetStateTop(state_stack), production[n][0], state_stack,
				symbol_stack);//此处用到了状态栈和符号的引用
			showResult(state_stack, symbol_stack, i);
			m = GetStateTop(state_stack); //while xunhuanblankCharacterzhibufen 
			n = Action[m][j];
		}
		if (n == 0)
{
			cout << "归约出错";
			break;
		}
		if (n == ACC)
			cout << "规约成功" << endl;
		else
		{
			PushState(state_stack, n);
			// cout<<n<<endl;
			PushSymbol(symbol_stack, temp);
			//每次移进后都重新输出状态栈,符号栈和符号串
			if (quaternion_stack.top > 0)
			{
				quaternion_stack.s[quaternion_stack.top] = temp;
				// cout<<quaternion_stack.s[quaternion_stack.top];
				++quaternion_stack.top;
			}
		}
	}
}
//------------------------------------------------------------------
//主函数
int main()
{
//	cout << "输入需要进行分析的程序的名称:\n";
//	cin >> filename;
	filename = "test.cpp";
	ifstream fin(filename.c_str()); //待添加当文件不存在 的处理
	string line, s;
	fin >> line; //直接读取到空格,并且省略回车,最后至少要有空格或省略号
	while (!fin.eof())
	{
		s = s + line + blankCharacter;
		fin >> line;
	}
	fin.close();
	ofstream fout("词法分析.txt");
	fout << "";
	cout << s << "--------" << endl; //在字符界面查看需要分析的字符串,可以删除
	lexAnalysis(s); //词法分析
	for (int i = 0; i <= num; i++)
		cout << i << ": " << symbol[i] << endl;
	ofstream yffout("语法分析.txt");
	yffout << "状态栈" << "\t\t符号栈" << "\t\t\t\t输入串" << endl;
	ofstream syfout("四元式.txt");
	syfout << "";
	Reduce(); //语法分析,进行规约
	return 0;
}2)程序测试用例
 int a = 1, b = 2, c = 3;
do
{
	a = a * b + b - c;
	i=i+100;
} while ( i < i ) ; #

(3)词法分析生成文件内容截图
在这里插入图片描述
(4)语法分析生成文件内容截图

在这里插入图片描述
(5)中间代码生成文件内容截图

在这里插入图片描述

2.根据所设计的分析程序和所给定的测试用例,自行构造识别活前缀的DFA、ACTION表和GOTO表,上机测试并通过所设计的分析程序。
(1)自行构造的识别活前缀的DFA图:

在这里插入图片描述

(2)自行设计的ACTION表和ACTION表所对应的C语言源代码:

在这里插入图片描述

//Action控制表
//n大于0表示移进
//n小于0则达标要进行规约,-n就代表用哪个推导式进行规约
//ACC代表规约成功 0表示出错
const int Action[38][19] = {
{2}, //状态0 入栈do
{0,0,0,0,0,0,0,0,0,0,0,0,0,ACC}, //状态1 # ACC
{0,0,0,0,0,0,0,0,0,5}, //状态2 入栈{
{0,4}, //状态3 入栈while
{0,0,0,0,0,0,0,0,0,0,0,23 }, //状态4 入栈 (
{0,0,10}, //状态5 入栈i
{0,0,10,0,0,0,0,0,0,0,7,0}, //状态6 入栈i }
{0,-2}, //状态7 规约 2. A→{F} //while
{0,0,-4,0,0,0,0,0,0,0,-4}, //状态8 规约4. F→FM //i }
{0,0,-3,0,0,0,0,0,0,0,-3}, //状态9 规约3. F→M //i }
{0,0,0,11}, //状态10 入栈=
{0,0,12,0,0,0,0,0,0,0,0,34},//状态11 入栈 i (
{0,0,0,-10,-10,-10,-10,-10,-10,0,0,0,-10},
//状态12规约10.E→i= + - * / ;
{0,0,0,0,15,16,17,18,14}, //状态13 入栈 + - * / ;
{0,0,-5,0,0,0,0,0,0,0,-5}, //状态14 //规约 5. M→i=E;//i }
{0,0,19}, //状态15 入栈i
{0,0,20}, //状态16 入栈i
{0,0,21}, //状态17 入栈i
{0,0,22}, //状态18 入栈i
{0,0,0,0,-6,-6,-6,-6,-6,0,0,0,-6},
//状态19 规约 6.E→E+i // + - * / ;
{0,0,0,0,-7,-7,-7,-7,-7,0,0,0,-7},
//状态20规约 7. E→E-i // + - * / ;
{0,0,0,0,-8,-8,-8,-8,-8,0,0,0,-8},
//状态21规约 8. E→E*i // + - * / ;
{0,0,0,0,-9,-9,-9,-9,-9,0,0,0,-9},
//状态22 规约 9.E→E/i // + - * / ;
{0,0,24}, //状态23 入栈i
{0,0,0,0,0,0,0,0,0,0,0,0,0,0,25,30,31,32,33},//入栈 < <= > >= !=
{0,0,-13}, //状态25 规约 13. O→< 
{0,0,27}, //状态26 入栈 i 
{0,0,0,0,0,0,0,0,0,0,0,0,28}, //状态27 入栈 )
{0,0,0,0,0,0,0,0,-12,0,0,0,0,0},//状态28 规约12. B→(iOi) //;
{0,0,0,0,0,0,0,0,37}, //状态29 入栈 ;
{0,0,-14}, //状态30 规约14. O→<= //i
{0,0,-15}, //状态31 规约15. O→> //i
{0,0,-16}, //状态32 规约16. O→>= //i
{0,0,-17}, //状态33 规约17. O→!= //i
{0,0,12,0,0,0,0,0,0,0,0,34}, //状态34 入栈 i (
{0,0,0,0,15,16,17,18,0,0,0,0,36},//状态35 入栈 + - * / )
{0,0,0,0,-11,-11,-11,-11,-11,0,0,0,-11},//状态36 规约
//11.E→(E)//+ - * / ;
{0,0,0,0,0,0,0,0,0,0,0,0,0,-1}//状态37 规约 1.S→doAwhileB; //#
};
//--------------------------------------------------------------

(3)自行设计的GOTO表和GOTO表所对应的C语言源代码:

![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/975fcc31c00c4b439eae8992f725ae58.png)

//GOTO控制部分
void GOTO(int i, char b, stateStack& state_stack, symbolStack& symbol_stack)
{
	// cout<<"GOTOzhong fterminals wei: "<<b<<endl;
	if (i == 0 && b == 'S')
	{
		PushState(state_stack, 1);
	}
	else if (i == 2 && b == 'A')
	{
		PushState(state_stack, 3);
	}
	else if (i == 4 && b == 'B')
	{
		PushState(state_stack, 29);
	}
	else if (i == 5 && b == 'F')
	{

		PushState(state_stack, 6);
	}
	else if (i == 5 && b == 'M')
	{
		PushState(state_stack, 9);
	}
	else if (i == 6 && b == 'M')
	{
		PushState(state_stack, 8);
	}
	else if (i == 11 && b == 'E')
	{
		PushState(state_stack, 13);
	}
	else if (i == 24 && b == 'O')
	{
		PushState(state_stack, 26);
	}
	else if (i == 34 && b == 'E')
	{
		PushState(state_stack, 35);
	}
	string B = "";
	B = B + b;
	PushSymbol(symbol_stack, B);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/691681.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

c++【入门】正多边形每个内角的度数

限制 时间限制 : 1 秒 内存限制 : 128 MB 题目 根据多边形内角和定理&#xff0c;正多边形内角和等于&#xff1a;&#xff08;n &#xff0d; 2&#xff09;180(n大于等于3且n为整数&#xff09;&#xff08;如下图所示是三角形、四边形、五边形、六边形的形状&#xff09…

云服务器CPU和内存直接被zzh恶意挖矿程序打满,如何解决?

回顾 最近在服务器上面部署网站&#xff0c;刚开始使用还是没问题的&#xff0c;当时一段时间之后发现CPU和内存总是被打满&#xff0c;本地没有跑大的应用&#xff0c;主要有mysql、nginx、redis&#xff0c;一度还以为是nginx 的问题&#xff0c;但是后来排除了。之后使用ht…

Python私教张大鹏 Vue3整合AntDesignVue之Anchor 锚点

用于跳转到页面指定位置。 何时使用 需要展现当前页面上可供跳转的锚点链接&#xff0c;以及快速在锚点之间跳转。 案例&#xff1a;锚点的基本使用 核心代码&#xff1a; <template><a-anchor:items"[{key: part-1,href: #part-1,title: () > h(span, {…

GAT1399协议分析(10)--单图像删除

一、官方接口 由于批量删除的接口&#xff0c;图像只能单独删除。 二、wireshark实例 这个接口比较简单&#xff0c;调用request delete即可 文本化&#xff1a; DELETE /VIID/Images/34078100001190001002012024060513561300065 HTTP/1.1 Host: 10.0.201.56:31400 User-Age…

【Proteus8.16】Proteus8.16.SP3.exe的安装包,安装方法

下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/14ZlETF7g4Owh8djLaHwBOw?pwd2bo3 提取码&#xff1a;2bo3 管理员打开proteus8.16.SP3.exe一路装就行了&#xff0c;许可证选Licence2.lxk,点安装后关闭&#xff0c;然后继续装完。 然后打开Patch-Proteus-8.16-…

树莓派4B 零起点(一) 树莓派 无屏 从购买到启动

目录 背景 一. 准备工作 二、烧录系统 三、连接系统 背景 准备开发ROS机器人&#xff0c;在淘宝上购买的树莓派4B(4G)到货了&#xff0c;配件都很齐全&#xff0c;那么就直接开箱验货。 一. 准备工作 1 、硬件&#xff1a;(如下图) (我的购买链接: 树莓派4B 4g 套件) 2…

pikachu靶场全流程

目录​​​​​​​ 暴力破解&#xff1a; 1.基于表单的暴力破解&#xff1a; 2.验证码绕过(on server)&#xff1a; 3.验证码绕过(on client)&#xff1a; token防爆破&#xff1a; XSS&#xff1a; 1.反射型xss(get)&#xff1a; 2.反射性xss(post)&#xff1a; 3.存…

搭建python虚拟环境,并在VSCode中使用

创建环境 python -m venv E:\python\flask\venv激活环境 运行下图所示的bat文件 退出环境 执行下面的语句 deactivateVSCode中配置&#xff1a; ①使用CTRLshiftp命令&#xff0c;使用CTRLshiftp命令&#xff0c;输入&#xff1a; Python: Select Interpreter②选择之前创建…

据报道,FTC 和 DOJ 对微软、OpenAI 和 Nvidia 展开反垄断调查

据《纽约时报》报道&#xff0c;联邦贸易委员会 (FTC) 和司法部 (DOJ) 同意分担调查微软、OpenAI 和 Nvidia 潜在反垄断违规行为的职责。 美国司法部将牵头对英伟达进行调查&#xff0c;而联邦贸易委员会将调查 OpenAI 与其最大投资者微软之间的交易。 喜好儿网 今年 1 月&a…

电子电气架构——车载诊断DTC一文通

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 没有人关注你。也无需有人关注你。你必须承认自己的价值,你不能站在他人的角度来反对自己。人生在世,最怕的就是把别人的眼光当成自己生活的唯一标…

不确定性+电动汽车!含高比例新能源和多类型电动汽车的配电网能量管理程序代码!

前言 能源供应的可持续性和清洁性是当今世界共同关注的议题&#xff0c;配电网与可再生能源发电相结合&#xff0c;通过多能互补和梯级利用&#xff0c;在不同时空取长补短&#xff0c;提高能源利用率&#xff0c;减少温室气体排放&#xff0c;是解决能源短缺和环境问题的有效…

Ruoyi-Vue-Plus 下载启动后菜单无法点击展开,

1.Ruoyi-Vue-Plus框架下载后运行 2.使用mock数据 3.进入页面后无法点击菜单 本以为是动态路由或者菜单逻辑出了问题&#xff0c;最后发现是websocket的问题 解决办法 把这两行代码注释 页面菜单即可点击。 以上。

htb_office

端口扫描 namp -sSVC 10.10.11.1380&#xff0c;445 80端口 robots.txt 只有/administrator可以访问 Joomla joomscan扫描 joomscan --url http://10.10.11.3/ 版本为4.2.7&#xff0c;存在cve CVE-2023-23752 Joomla未授权访问Rest API漏洞 访问路径 /api/index.php/…

推荐系统三十六式学习笔记:原理篇.内容推荐05|从文本到用户画像有多远?

目录 从文本开始构建用户画像一、结构化文本1、TF-IDF2、TextRank3、内容分类&#xff1a;4、实体识别5、聚类6、词嵌入 二、标签选择1、卡方检验2、信息增益 总结 对于一个早期的推荐系统来说&#xff0c;基于内容推荐离不开用户构建一个初级的画像&#xff0c;这种初级的画像…

JAVA高级-反射与动态代理(十五)

观看尚硅谷视频做的视频笔记 一、高级-反射与动态代理&#xff08;十四&#xff09; 1、反射概述 1&#xff09;java程序中&#xff0c;所有的对象都有两种类型&#xff1a;编译时类型&#xff0c;运行时类型&#xff0c;而很多时候对象的编译类型和运行时类型不一致。 此处…

数据库分库分表mycat

为啥要分库分表 IO瓶颈&#xff1a;热点数据太多&#xff0c;数据库缓存不足&#xff0c;产生大量磁盘IO&#xff0c;效率较低。 请求数据太多&#xff0c;带宽不够&#xff0c;网络IO瓶颈。 CPU瓶颈&#xff1a;排序、分组、连接查询、聚合统计等SQL会耗费大量的CPU资源&#…

pre-commit 慢

执行这个命令 pre-commit run --all-files 有时候会卡在Initializing environment for https://github.com/xxx那里&#xff0c;如下图&#xff1a; 这个情况可以这样复现&#xff1a; git clone gitgithub.com:TheKevJames/coveralls-python cd coveralls-python python3.1…

c# 学习 2

常量 转义字符 类型转换

关于python中的关键字参数

在python语言中存在两种传参方式&#xff1a; 第一种是按照先后顺序来传参&#xff0c;这种传参风格&#xff0c;称为“位置参数”这是各个编程语言中最普遍的方式。 关键字传参~按照形参的名字来进行传参&#xff01; 如上图所示&#xff0c;在函数中使用关键字传参的最大作…

微服务开发与实战Day03

一、导入黑马商城项目 资料文档&#xff1a;Docs 1. 安装MySQL ①删除root目录下的mysql rm -rf mysql/ ②把课前资料里的mysql目录上传到root目录下 ③创建一个通用网络 docker network create hm-net ④使用下面的命令安装MySQL docker run -d \--name mysql \-p 330…