-
🍓前言 面对一夜爆火的 ChatGPT ,我最终也没抵得住诱惑,决定体验一下,不过这玩意要注册需要外国手机号以及科学上网,将许多人拦在门外,本篇博客将体验当下爆火的 ChatGPT 以及无需注册和科学上网,拿来即用的 ChatGPT 使用攻略,快来试试吧! 🍒ChatGPT 是什么? 被炒得火爆的ChatGPT到底是什么? 美国人工智能公司OpenAI发布免费机器人对话模型ChatGPT(GPT-3.5系列),模型中首次采用RLHF(从人类反馈中强化学习)方式。模型目前处于测试阶段,用户与ChatGPT之间的对话互动包括普通聊天、信息咨询、撰写诗词作文、修改代码等。功能如此“全面”的ChatGPT被称作“最强AI(人工智能)”,面世5天便已有超过100万用户使用。 就是一个功能强大的 “AI机器人” ,到底有多强大,怎么体验,一起来看看吧! 🍒 vscode ChatGPT 中文版插件安装 没错,这个号称最强AI的机器人在vscode中已经有中文版插件了,赶紧装一个体验一下吧! 打开你的vscode,搜索ChatGPT安装这个插件: 可以看到他的使用方法在这个插件中写的十分详细,甚至还有附有小破站的视频教程,实在不会的小白可以去看看! 🍒 ChatGPT 初体验 可以看到,这个功能还是很多的,最常用的就是提问,我们来体验一下! 快捷键ctrl+shift+p 或者 command+shift+p打开命令面板,输入"ChatGPT"。 回车后在这里输入你的问题,当然也可以直接点击左侧小方块,在下面的输入框直接输入问题! 🍅测试一:聊天 嘿嘿嘿!强! 🍅测试二:用c语言求1-100之间素数的代码 我们来体验一下问答写代码! 先来一个简单的! 我直呼好家伙,还真写出来了,而且注释很详细!这代码都不用验证,完全没有问题哇! 我们把代码提取出来,跑一下吧! #include <stdio.h> int main() { // 定义一个变量用来保存当前数字 int num; // 使用一个循环来遍历1-100之间的所有数字 for (num = 1; num <= 100; num++) { // 定义一个变量用来保存当前数字是否为素数,默认为true int is_prime = 1; // 使用另一个循环来遍历2-num-1之间的所有数字 for (int i = 2; i < num; i++) { // 如果当前数字能够被i整除,那么它不是素数 if (num % i == 0) { is_prime = 0; break; } } // 如果is_prime仍然为true,那么当前数字是素数,输出它 if (is_prime) { printf("%d is a prime number\n", num); } } return 0; } 我倒要看看这个AI有多强,给他上难度! 🍅测试三:写一个C语言管理系统 用c 语言写一个会员信息管理系统。录入会员信息并可选择功能查询。会员信息包括会员号,会员姓和名,什么时间加入的,从2017年至2021年缴纳的会员费(注:maloc , calloc , realloc , free 等函数希望可以用上)! 具体包含功能如下: 1.增加新会员 2.移除会员 3.更新某一会员信息 4.输出所有会员信息 5.查询某一会员信息 6.退出会员系统 只能说,蒸的c,只是这个插件代码格式化功能不太好,代码块显示不太好,但也很明显的看到用结构体存储数据,实现了基础的增删改查! 需要注意的是,当本次输出达到上限,你需要输入“继续”,他会继续接着输出! 本题代码庞大,我就不测试了,感兴趣的可以去尝试! 🍅测试四:询问代码功能 total = 0 num_list = [1,2,3,4] for i in num_list: for j in num_list: for k in num_list: if (i!=j) and (i!=k) and (j!=k): print(i,j,k) total += 1 print(total) 确实没啥问题! 🍓 结语 ChatGPT 的强大毫无疑问,确实可以帮助我们写代码,前提是你的需求要足够清晰,简直就是开发的一大利器,可以借助它实现基础功能,然后拿来修改,关键是它啥语言都能写…,并且注释很详细,利用得当也可以帮助小白学习!那么你认为程序员最终会被人工智能替代吗? 赶紧去体验体验体验吧!只有体验了才能感触到它的强大!当然也有现成的网站可以直接体验,链接我放评论区了哦! ———————————————— 版权声明:本文为CSDN博主「馆主阿牛」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/qq_57421630/article/details/128272956
-
1.list的介绍 list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。 list和forward_list非常相似:最主要的不同在于forward_list是单链表,只能朝前迭代,已让其更简单高效。 与其他序列式容器相比(array,vector,deque),list通常在任意位置插入,移除元素的执行效率更好。 与其他序列式容器相比,list和forward_list最大的缺陷是不支持任意位置的随机访问 2.list的使用 2.1.list的构造 构造函数 接口说明 list(size_type n,const value_type& val = value_type()) 构造的list中包含n个值为val的元素 list 构造空的list list(const list& x) 拷贝构造函数 list(InputIterator first,InputIterator last) 用[first,last)区间中的元素构造list 2.2.list iterator的使用 函数声明 接口说明 begin + end 返回第一个元素的迭代器+返回最后一个元素的下一个位置的迭代器 rbegin + rend 返回最后一个数据的位置迭代器+返回第一个数据的前一个位置的迭代器 2.3.list capacity 函数声明 接口说明 empty 检测list是否为空,是返回true,不是返回false size 返回list节点中有效节点的个数 2.4.list element access 函数声明 接口说明 front 返回list的第一个节点中值的引用 back 返回list的最后一个节点中值的引用 2.5.list modifiers 函数声明 接口说明 push_front 在list首元素前插入值为list的元素 pop_front 删除list中的第一个元素 push_back 在list尾部插入值为val的元素 pop_back 删除list的最后一个元素 insert 在list position位置插入值为val的元素 erase 删除list position位置的元素 swap 交换两个list中的元素 clear 清空list中的有效元素 3.list的迭代器失效 我们可以类似先把迭代器暂时理解成指针。则迭代器失效即迭代器所指向的节点无效。即该节点被删除了。因为list的底层结构为带头节点的双向循环链表,因此在list中进行插入不会导致list迭代器失效的,只有在删除时才会失效,并且失效的只是指向删除节点的迭代器,其他迭代器不会受到影响。 4.list和vector的对比 list和vector都是STL中非常重要的序列式容器,由于两个容器的底层结构不一样,导致其特性以及应用场景不同 vector list 底层结构 动态顺序表,一段连续空间 带头节点的双向循环链表 随机访问 支持随机访问,访问某个元素的效率O(1) 不支持随机访问,访问某个元素的效率O(N) 插入和删除 任意位置插入和删除效率低,需要移动元素,时间复杂度为O(N),插入时有可能需要增容,增容:开辟新空间,拷贝元素,释放旧空间,导致效率更低 任意位置插入和删除效率高,不需要移动元素,时间复杂度为O(1) 空间利用率 底层为连续空间,不容易造成内存碎片,空间利用率高,缓存利用率高 底层节点动态开辟,小节点容易造成内存碎片,空间利用率低,缓存利用率低 迭代器 原生态指针 对原生态指针进行封装 迭代器失效 在插入元素时,要给所有的迭代器重新赋值,因为插入元素有可能导致重新扩容,导致原来迭代器失效,删除时,当前迭代器需要重新赋值否则会失效 插入元素不会导致迭代器失效,删除元素时,只会导致当前迭代器失效,其他迭代器不受影响 使用场景 需要高效存储,支持随机访问,不关心插入和删除 大量的插入和删除,不关心随机访问 5.list的模拟实现 #define _CRT_SECURE_NO_WARNINGS #include <iostream> #include <algorithm> #include <assert.h> using namespace std; namespace smk { //一个一个的节点 template <class T> struct ListNode { ListNode* next; ListNode* prev; T data; ListNode(const T& x) :next(nullptr) ,prev(nullptr) ,data(x) {} }; //封装 + 运算符重载 template <class T,class Ref,class Ptr> struct list_iterator { typedef ListNode<T> Node; typedef list_iterator<T ,Ref,Ptr> Self; list_iterator(Node* p) :_pNode(p) {} Ref operator*() { return _pNode->data; } //找到节点的指针 Self& operator++() { _pNode = _pNode->next; return *this; } Self& operator--() { _pNode = _pNode->prev; return *this; } bool operator!=(const Self& it) { return _pNode != it._pNode; } bool operator==(const Self& it) { return _pNode == it._pNode; } Ptr operator->() { return &_pNode->data; } //节点的指针 Node* _pNode; }; //带头双向循环链表 template <class T> class list { typedef ListNode<T> Node; public: typedef list_iterator<T,T&,T*> iterator; typedef list_iterator<T, const T&,const T*> const_iterator; iterator begin() { return iterator(_head->next); } const_iterator begin() const { return const_iterator(_head->next); } iterator end() { return iterator(_head); } const_iterator end() const { return const_iterator(_head); } void Initialize() { _head = new Node(T()); _head->next = _head; _head->prev = _head; _size = 0; } list() { Initialize(); } template <class Interiterator> list(Interiterator first, Interiterator last) { Initialize(); while (first != last) { push_back(*first); ++first; } } void swap(list<T>& st) { std::swap(_head, st._head); std::swap(_size, st._size); } //现代写法的拷贝构造 list(const list<T>& st) { Initialize(); list<T> tmp(st.begin(), st.end()); swap(tmp); } //拷贝构造 /*list(const list<T>& st) { Initialize(); for (auto& e : st) { push_back(e); } }*/ list<T>& operator=(list<T> st) { swap(st); return *this; } //传统写法的赋值重载 /*list<int>& operator=(const list<T>& st) { if (this != &st) { clear(); for (auto& e : st) { push_back(e); } } return *this; }*/ void clear() { iterator it = begin(); while (it != end()) { it = erase(it); } } ~list() { clear(); delete _head; _head = nullptr; } size_t size() const { return _size; } bool empty() const { return _size == 0; } void push_back(const T& val) { //Node* newNode = new Node(val); //Node* tail = _head->prev; _head tail newNode //tail->next = newNode; //newNode->prev = tail; //newNode->next = _head; //_head->prev = newNode; insert(end(),val); } void push_front(const T& val) { insert(begin(), val); } void pop_front() { erase(begin()); } void pop_back() { erase(--end()); } iterator insert(iterator pos, const T& val) { Node* newnode = new Node(val); Node* cur = pos._pNode; Node* prev = cur->prev; //链接 prev newnode cur prev->next = newnode; newnode->prev = prev; newnode->next = cur; cur->prev = newnode; ++_size; return iterator(newnode); } iterator erase(iterator pos) { assert(pos._pNode != _head); Node* prev = pos._pNode->prev; Node* next = pos._pNode->next; prev->next = next; next->prev = prev; --_size; return iterator(next); } private: //链表的指针 Node* _head; size_t _size; }; ———————————————— 版权声明:本文为CSDN博主「孙梦康」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/SASCII/article/details/128315305
-
【问题来源】【必填】浙公院【问题简要】【必填】c#在win7调用ccgateway的https任意接口报错,SSL通道无法创建。调用AgentClient-20210419005736.jar包8443端口的https接口是正常的。排查发现请求端必须是tls1.2版本,但现在win7系统的Schannel套件默认不开启该版本,希望ccgateway的tls版本能支持,非互联网应用。【问题类别】【必填】CTI平台提供的cc-gateway接口【AICC解决方案版本】【必填】AICC 8.15.0 CC-Gateway开发指南 (RESTful)【问题现象描述】【必填】调用jar包和ccgateway不同结果参考如下图,调用ccgateway的8043端口出错,调用agentclient.jar包的返回数据正常
-
🎄auto推导规则1️⃣如果auto声明的变量是按值初始化,则推导出的类型会忽略const、volatile限定符。进一步解释为,在使用auto声明变量时,既没有使用引用,也没有使用指针,那么编译器在推导的时候会忽略const和volatile限定符。当然auto本身也支持添加const、volatile限定const int i = 10; auto j = i; // auto推导类型为int auto &m = i; // auto推导类型为const int& auto *k = i; // auto推导类型为const int const auto n = j; // auto推导类型为int✨✨解释:因为在进行类型推导时忽略了const、volatile,所以i虽然我const int类型结果却是int类型 而m和k分别为引用和指针初始化,所以原本的const和volatile属性得以保留 最后,const auto结合让n的类型推导为const int2️⃣在使用auto声明变量初始化时,目标对象如果是引用&,则引用属性会被忽略:int i = 10; int &j = i; auto m = j; // auto推导类型为int✨✨解释:虽然j是i的引用,j的类型为int&但是在推导m的时候auto会直接忽略掉其中的引用推导为int类型,也就是说明对谁的引用就会直接推导成谁本身的类型3️⃣使用auto和万能引用声明变量时,对于左值会将auto推导为引用类型:int i = 10; auto&& k = i; // auto推导类型为int& auto&& j = 10; // auto推导类型为int解释: 因为i是一个左值,所以k的类型会被推导为int&,auto被推导为int&,这其中用到了引用折叠的规则。而5是一个右值,因此j的类型被推导为int&&,auto被推导为int4️⃣使用auto声明变量,如果目标对象是一个数组或者函数,则auto会被推导为对应的指针类型int i[10]; auto m = i; // auto推导类型为int* int add(int A, int A){ return A+A; } auto j = add // auto推导类型为int (__cdecl *)(int,int)解释: i[10]是数组类型,但是在推导时变为int*,m化为指针类型指向i的首地址,同样,j也退为函数指针类型5️⃣当auto关键字与列表初始化组合时直接使用列表初始化,列表中必须为单元素,否则无法编译,auto类型被推导为单元素的类型。用等号加列表初始化,列表中可以包含单个或者多个元素,auto类型被推导为**std::initializer_list**,其中T是元素类型。请注意,在列表中包含多个元素的时候,元素的类型必须相同,否则编译器会报错。auto A1 = { 10, 12 }; // x1类型为 std::initializer_list auto A2 = { 10, 12.0 }; // 编译失败,花括号中元素类型不同 auto A3{ 10, 12 }; // 编译失败,不是单个元素 auto A4 = { 13 }; // x4类型为std::initializer_list auto A5{ 13 }; // x5类型为int
-
✨一起来看看重新定义的auto关键字🎁auto作为一个在c++98标准就已经开始存在的关键字,因为现在我们已经几乎不再去使用去声明自动变量,于是乎在c++11中我们重新对其进行定义赋予了它新的含义:🎄声明变量时根据初始化表达式自动推断该变量的类型、声明函数时函数返回值的占位符。🎈例如:auto A = 1;这里没有对A去声明类型,但是通过auto进行推导时已经将A推导为int类型的变量🎈再以字符为例:auto str="hello world";在这里同样是auto自动进行推导,推导类型为 const char*🎈再以函数返回值为例:auto add(int A,int B)->int{return A+B;}再这里add函数声明采用了函数返回类型后置的方法,在这里同样可以看出返回值A+B为int型推导出的函数类型为int型✨但是我们在使用auto时一定要注意,在进行类型推导时一定要对变量进行初始化,比如下面没有初始化就不能编译通过auto A;A=1;✨这里很明显没有进行初始化,也就导致了编译器无法推导具体类型而报错除此之外auto在进行编译推导时还有以下4点规则1️⃣当我们使用auto声明多个变量时,编译器遵循从左往右的推导规则,以最左边的表达式推断auto的具体类型:auto n=12,m=10;在上面的代码因为是以左边的表达式类型推导auto的具体类型,n=12可以推导出为int型,于是m这个时候同样也被声明成int类型,在这种情况下,要注意声明多个变量时要保证声明的变量都是相同的,比如下面的变量类型不同就编译不通过;auto n=12,m=10.0;在这种情况下由于n为int型,m为浮点型,前后不同所以报错2️⃣当使用条件表达式初始化auto声明的变量时要注意,编译器往往会初始化为表达能力更强的类型而并不是是我们想的条件表达式的返回类型,例如:auto A=true?10:12.0;在上面的代码种,虽然条件表达式的返回类型为int但是A的类型依然会被推导为double3️⃣在C++11中静态成员变量是可以用auto声明并且初始化的,不过前提是auto必须使用const限定符: 例如:struct nametype { static const auto A = 12; };一旦使用const就将导致变量的常量化,为了解决这一问题,在c++17中就已经提出了响应的解决方法,代码如下:struct nametype{ static inline auto A=12; }4️⃣无法在形参列表中使用auto声明形参void sum(auto A,auto B){ ...... }
-
内联命名空间的定义和使用✨✨在进行大型开发过程中,我们偶尔发现会遇到函数重名或者类型同名造成的编译冲突问题。为了解决类似的问题,我们需要合理使用命名空间,于是我们可以将函数和类型纳入命名空间中,这样,因为不在同一命名空间下就不会产生函数和类型的冲突比如:namespace name1 { void foo() {} } namespace name2 { void foo() {} } using namespace name1; int main(){ stu(); name2::stu(); }✨✨在上面的例子中我们用有俩个命名空间name1、name2,在两块空间下都具有相同的函数stu()于是我们可以使用命名空间的名称去调用空间内的函数,也可以去通过using关键字去打开命名空间,但是在每次使用空间都需要打开空间就显得有些复杂了,于是在c++11中就增强了命名空间的特性;✨✨在c++11中提出了内联空间的概念,我们可以使用inline关键字将空间内的函数和类型导出在父空间中,这样内联空间内的函数就可以直接通过父空间直接调用,则样就是即使不指定子命名空间也可以使用其子命名空间内的函数和类型了例如:#include #include namespace Parent { namespace name1 { void stu() { std::cout << "命名空间1.0" << std::endl; } } inline namespace name2 { void stu() { std::cout << "命名空间2.0" << std::endl; } } } int main(){ Parent::name1::stu(); Parent::stu(); }✨✨在上面的代码中在对name2使用了inline关键字标记为内联命名空间,所以调用name1的stu函数需要明确指定所属的命名空间。而在调用name2当中的stu函数就显得十分方便了,可以直接通过父空间进行调用但是这一点好像目前看来并没有太大的作用,那么内联命名空间的作用到底是上面呢?其实内联函数命名空间的这一特性在版本的迭代方面就可以看出作用,给大家举个例子看看当我们在进行版本迭代的时候,就比如下面的这段代码#include #inculde namespace Parent { void stu() { std::cout << "版本1.0" << std::endl; } } int main(){ Parent::stu(); }✨✨在对这段代码进行的时候我们就需要对这代代码进行大量的删改操作,但是问题来了,当我们想要再次体验老版本时候就很难再找回原来的版本,那么我们就可以通过内联命名命名空间这样一个特性进行新老版本的更迭比如下面这段代码:namespace Parent { namespace name1 { void stu() { std::cout << "版本1.0" << std::endl; } } inline namespace name2 { void stu() { std::cout << "版本2.0" << std::endl; } } } int main(){ Parent::stu(); }✨✨从上面的代码中可以看出,当我们需要将版本升级到2.0时只需要在将Parent::stu()改为Parent::name2::stu()。我们就可以使用新的版本,不光如此我们也可以在同一个父空间下创建版本3.0、版本4.0、版本5.0,我们只需要创建对应的内联命名空间就好;🎃🎃值得注意的是在同一个父命名空间下只允许一个内联命名空间,不然编译时就会因为不知道使用那个内联命名空间而报错🎃🎃
-
请问,想要获取到DataGridView表格内的所有内容,是否存在一次性获取表格内所有内容的方式,由于是数据是动态的所以无法去循环遍历表格内每一个单元格的内容,还请各位大佬们支支招,万般感谢!!!
-
请问,想要获取到DataGridView表格内的所有内容,是否存在一次性获取表格内所有内容的方式,由于是数据是动态的所以无法去循环遍历表格内每一个单元格的内容,还请各位大佬们支支招,万般感谢!!!
-
镜头型号:M2241-QL软件版本:SDC_3519A_8.0.2.SPC119HWPuSDK版本:SDC Development Kit 8.0.RC3网页可以设置OSD水印距离左上,左下,右上,右下多少个像素,字体大小可以手动输入大小问题:C# 用HWPuSDK 怎么实现?使用 IVS_PU_GetOsdTextExV3 获取OSD修改文字以后 使用IVS_PU_SetOsdTextExV3 ,OSD位置与大小就就都变样了有没有配置OSD方面的demo呢?
-
今天的做C#项目时,突然要对list列表的列表进行合并汇总,哈哈,写linq和lambda不多,试过几个方法都不行.具体代码如下就是对List<Coio> list中的列表ReportItems进行合并!一般情况下,如果是两个list列表,直接是union即可,但是现在List中的列表呢.当然用最简单的方法就遍历这个list,然后对列表进行AddRange即可,如下代码var list = new List<Coio>();for (int i = 0; i < 10; i++){list.Add(new Coio());}var listItem = new List<ReportItem>();foreach (var item in list){listItem.AddRange(item.ReportItems);}方法自然是没问题了,但就是想有没有更简单的.其实你想到的,微软也想到了.用SelectMany方法即可: var listResult = list.SelectMany(n => n.ReportItems).ToList();看看是不是原来四五行代码,现在就一行代码就解决了~转载自https://www.home1024.com/article/union-a-list-of-lists.html
-
【功能模块】SDC Development Kit Demo 8.0.T9 中C#demo--实况+云镜控制(Live Video + PTZ Control)引用IPC SDK V200R002C00SPC616_sdksIPC SDK V200R002C00SPC628_sdkSDC Development Kit 8.0.RC3_sdk【操作步骤&问题现象】1、运行报错2、找不到制定模块,3、请问需要加载哪个SDK,这个sdk不对【截图信息】【日志信息】(可选,上传日志内容或者附件)
-
The request signature we calculated does not match the signature you provided. Check your key and signing method.
-
*学习敏捷上云开发要点,提升就业机会**体验Java,Node.JS,C#真实应用上云开发案例**收获华为无线耳机、拍立得、机械键盘、京东卡等丰富好礼* △适合人群:对敏捷DevOps开发有转型需求,渴望提升云上研发能力的开发者△活动时间:2022.5.16-2022.6.30△活动参与方式: 报名活动:点此链接,填写报名表即完成报名,点此了解活动详细规则;加入学习社群:完成本报名后请务必扫码进入学习群,专家全程跟踪辅导,伙伴比肩共同进步; 完成学习任务,赢取积分奖励本帖为C#项目上云实践“C#上云体验:云上部署超级冷笑话网站”截图回复帖,如实验顺利完成,只提交部署成功的截图即可。请按实验手册示例进行截图,截图右上角露出华为云账号,将截图回复至本帖。如无法完成实验,做到哪一步提交哪一步的截图即可,将根据实验完成进度奖励积分。回复要求:华为云账号+截图加油~~华为云PaaS服务小智 发表于2022-05-05 19:36:28 2022-05-05 19:36:28 最后回复 xuexiaozhaoyh 2022-06-26 12:37:301076 35
-
C#中如何使用IVS_PU_GetAlarmPara?参数IntPtr arg该如何传入呢?需要怎样转换?
-
原文链接:https://thenewstack.io/microsofts-programming-language-czar-anders-hejlsberg-the-interview/ https://blog.csdn.net/m0_66023967/article/details/123068356?spm=1000.2115.3001.5927Anders Hejlsberg是世界上最重要的计算机程序员之一。作为Turbo Pascal、Delphi、C#和TypeScript等编程语言的创造者,在构建微软.NET等开发环境方面极具影响力,Hejlsberg影响了数以百万计的软件开发人员。近日,Hejlsberg与TNS新闻编辑Darryl K.Taft进行了一场线上对话,围绕微软低代码/无代码、Web3等话题,分享了他对许多与软件开发相关的事情的看法。Excel是一种低代码/无代码工具问:您对于低代码,无代码有什么看法?Anders Hejlsberg:我认为这个领域的潜力巨大。我们常会忽略,其实我们已经拥有了世界上最好的编程语言之一,或许这取决于你如何定义Excel中编程语言。可以说Excel是一种低代码/无代码的程序编写方式,人们运行程序,而他们使用的电子表格就是程序。你可以做一些事情,输入一些东西,然后运行程序,程序会在电子表格的底层运行,并且给出结果。所以我认为挑战其实一直在于这些工具。当达到低代码环境的极限时,你需要找到设置合适的逃生舱口的方法,才不会陷入困境。而且这个逃生舱口,可以转移到一个更完整或完整的编程环境,这意味着有意义的可扩展性模型是必须的。因此,我们需要思考的事情还有很多,但这些事情往往不是最重要的,因为人们往往会转而关注绘制方框和线条,以及这些示例的演示效果。但我常常很好奇,这些工具是否能适应现实世界?很多都不能,但有些可以。这是有趣的地方。问:我的意思是,整体的主旨是努力让更多人进入开发的世界。其中一部分人想要走的更远,成为专业人士,或者至少更加熟练。Anders Hejlsberg:是的。如果你去问所有的Excel用户,他们都不会自称程序员。但是,从某种意义上来说,他们是。问:没错,我比较喜欢把这比作“Blue Apron”和“HelloFresh”这样的套餐服务——它们会让你开始学习烹饪,并且自己动手,做得更好。你认为在软件开发中下一个要克服的挑战是什么?Anders Hejlsberg:在我们写代码的方式和机器学习的可能够帮助我们的方式之间,仍然有非常大的差距。因为我们的大脑以及神经网络的工作方式,从来没有真正关于0和1以及绝对正确的答案,而都是统计和模糊逻辑。然而,所有的编程语言都牢固地扎根于逻辑和可证明性等等。这两种世界观之间存在着巨大的差距。看看我们最终如何弥合这一差距的(如果说我们最终做到了的话)。软件开发中的安全性问:下面我们来谈谈安全问题。在软件开发中,安全性和整个shift left的作用有多重要?Anders Hejlsberg:这取决于你在堆栈中的位置。对于编程语言来说,安全性非常重要,起码这对我的工作影响很大。甚至可以说类型检查器是一种安全形式。这是软件中可利用的漏洞。所以从这个意义上来说,编程语言间接地考虑了安全性。创造可以分析代码,并且指出可能存在的安全漏洞的工具,是我们看待安全性的其他方式。但很显然,这是个现实问题。我是说,世界各地也有人每天上班,他们的工作就是黑入西方国家的公司,从而获得薪水。这细思极恐。有很多人靠滥用科技谋生。虽然这一点令人难过,但这就是现实。Web3的开发问:您对Web3有什么看法?您认为是否需要新的工具进行Web3的开发呢?Anders Hejlsberg:首先,我们要对Web3的概念达成共识,因为人们对此总是各持己见。我喜欢奖励创造者概念,以及创造数字资产并获得奖励的能力。但是,在这个领域也有很多骗子、挂羊头卖狗肉的人和急功近利的人。而且还会造成大量的环境污染,虽然可以将其归因于一些正在进行的采矿活动和能源的使用,所以这是一个多样的世界。我们将看到这一切的结果。因此,我喜欢它的某些部分,也反对它的某些部分。潜力巨大的项目:GitHub构建的Copilot问:我知道您在微软需要做的事情很多,但在微软以外,有没有什么很棒的项目或者工作吸引您的关注?Anders Hejlsberg:我认为微软肯定有一些非常有趣的项目。比如开发者工具、人工智能、机器学习,还有很多其他有意思的事。不知道你是否了解GitHub正在构建的Copilot的项目,能够在世界上所有的开源代码上训练一个机器学习网络,然后让它给出答案,是不是很棒?当然,这仍然有点像西大荒,因为有各种机遇和不可掌控的发展,以及知识产权的未解决的问题,但它展现出巨大的潜力。所以我认为这很吸引人,我正在密切关注这个问题。问:我认为这是2021年的最好的编程项目,涉及到相当大的领域。Anders Hejlsberg:是的,这个项目确实很吸引人。尤其是作为一名程序员,它在很大程度上让人洞察到我们谈论的是什么样的智能。从某种意义上说,用智能这个词有点不恰当,因为如果有人以前写过这段代码,这种机器学习模型的聚合内存可能是正确的,这值得我们注意。它可以在其内存中找到那段代码。但是,如果以前没有人写过,它必须要思考解决方案,结果可能出人意料,所以在这方面还有很多需要思考的地方。但这是一个了不起的工具,因为它把再利用的概念提升到了一个新的水平,让我们不用重复做别人已经做过的事。
上滑加载中
推荐直播
-
全面解析华为云EI-API服务:理论基础与实践应用指南
2024/11/29 周五 18:20-20:20
Alex 华为云学堂技术讲师
本期直播给大家带来的是理论与实践结合的华为云EI-API的服务介绍。从“主要功能,应用场景,实践案例,调用流程”四个维度来深入解析“语音交互API,文字识别API,自然语言处理API,图像识别API及图像搜索API”五大场景下API服务,同时结合实验,来加深开发者对API服务理解。
正在直播 -
企业员工、应届毕业生、在读研究生共探项目实践
2024/12/02 周一 19:00-21:00
姚圣伟 在职软件工程师 昇腾社区优秀开发者 华为云云享专家 HCDG天津地区发起人
大神带你一键了解和掌握LeakyReLU自定义算子在ONNX网络中应用和优化技巧,在线分享如何入门,以及在工作中如何结合实际项目进行学习
即将直播 -
昇腾云服务ModelArts深度解析:理论基础与实践应用指南
2024/12/03 周二 14:30-16:30
Alex 华为云学堂技术讲师
如何快速创建和部署模型,管理全周期AI工作流呢?本期直播聚焦华为昇腾云服务ModelArts一站式AI开发平台功能介绍,同时结合基于ModelArts 的实践性实验,帮助开发者从理论到实验更好地理解和使用ModelArts。
去报名
热门标签